src/HOL/TPTP/TPTP_Parser/ml-yacc/lib/stream.sml
author paulson <lp15@cam.ac.uk>
Thu, 27 Aug 2020 16:48:21 +0100
changeset 72221 98ef41a82b73
parent 46845 6431a93ffeb6
permissions -rw-r--r--
just a bit of streamlining

(* ML-Yacc Parser Generator (c) 1989 Andrew W. Appel, David R. Tarditi *)

(* 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(ref(EVAL t)) = t
     | get(s as ref(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;