src/Pure/General/buffer.ML
author chaieb
Sat, 20 Oct 2007 12:09:30 +0200
changeset 25111 d52a58b51f1f
parent 23785 ea7c2ee8a47a
child 26502 7f64d8cf6707
permissions -rw-r--r--
neq0_conv removed from [iff] -- causes problems by simple goals with blast, auto etc...

(*  Title:      Pure/General/buffer.ML
    ID:         $Id$
    Author:     Markus Wenzel, TU Muenchen

Efficient string buffers.
*)

signature BUFFER =
sig
  type T
  val empty: T
  val add: string -> T -> T
  val markup: Markup.T -> (T -> T) -> T -> T
  val content: T -> string
  val write: Path.T -> T -> unit
  val output: (string -> unit) -> T -> unit
end;

structure Buffer: BUFFER =
struct

datatype T = Buffer of string list;

val empty = Buffer [];

fun add "" buf = buf
  | add x (Buffer xs) = Buffer (x :: xs);

fun markup m body =
  let val (bg, en) = Markup.output m
  in add bg #> body #> add en end;

fun content (Buffer xs) = implode (rev xs);

fun write path (Buffer xs) = File.write_list path (rev xs);

fun output f (Buffer xs) = List.app f (rev xs);

end;