#lang sml (* ML-Yacc Parser Generator (c) 1989 Andrew W. Appel, David R. Tarditi * * $Log$ * Revision 1.1 2000/11/24 13:32:28 rossberg * *** empty log message *** * * Revision 1.2 1997/08/26 19:18:55 jhr * Replaced used of "abstraction" with ":>". * # Revision 1.1.1.1 1997/01/14 01:38:04 george # Version 109.24 # * Revision 1.1.1.1 1996/01/31 16:01:43 george * Version 109 * *) (* Stream: a structure implementing a lazy stream. The signature STREAM is found in base.sig *) structure Stream :> STREAM = struct datatype 'a str = EVAL of 'a * 'a str ref | UNEVAL of (unit->'a) type 'a stream = 'a str ref fun get s = case !s of EVAL t => t | UNEVAL f => let val t = (f(), ref(UNEVAL f)) in s := EVAL t; t end fun streamify f = ref(UNEVAL f) fun cons(a,s) = ref(EVAL(a,s)) end