1999-02-16 01:07:26 -08:00
|
|
|
(***********************************************************************)
|
|
|
|
(* *)
|
|
|
|
(* Objective Caml *)
|
|
|
|
(* *)
|
1999-02-25 02:26:38 -08:00
|
|
|
(* Pierre Weis and Xavier Leroy, projet Cristal, INRIA Rocquencourt *)
|
1999-02-16 01:07:26 -08:00
|
|
|
(* *)
|
|
|
|
(* Copyright 1999 Institut National de Recherche en Informatique et *)
|
1999-11-17 10:59:06 -08:00
|
|
|
(* en Automatique. All rights reserved. This file is distributed *)
|
2001-12-07 05:41:02 -08:00
|
|
|
(* under the terms of the GNU Library General Public License, with *)
|
|
|
|
(* the special exception on linking described in file ../LICENSE. *)
|
1999-02-16 01:07:26 -08:00
|
|
|
(* *)
|
|
|
|
(***********************************************************************)
|
|
|
|
|
|
|
|
(* Extensible buffers *)
|
|
|
|
|
|
|
|
type t =
|
|
|
|
{mutable buffer : string;
|
|
|
|
mutable position : int;
|
|
|
|
mutable length : int;
|
1999-02-25 02:26:38 -08:00
|
|
|
initial_buffer : string}
|
1999-02-16 01:07:26 -08:00
|
|
|
|
1999-02-23 11:05:08 -08:00
|
|
|
let create n =
|
1999-10-02 05:09:43 -07:00
|
|
|
let n = if n < 1 then 1 else n in
|
|
|
|
let n = if n > Sys.max_string_length then Sys.max_string_length else n in
|
1999-02-23 11:05:08 -08:00
|
|
|
let s = String.create n in
|
2001-10-28 06:20:27 -08:00
|
|
|
{buffer = s; position = 0; length = n; initial_buffer = s}
|
1999-02-16 01:07:26 -08:00
|
|
|
|
1999-02-25 02:26:38 -08:00
|
|
|
let contents b = String.sub b.buffer 0 b.position
|
1999-02-16 01:07:26 -08:00
|
|
|
|
1999-02-25 02:26:38 -08:00
|
|
|
let length b = b.position
|
1999-02-23 11:05:08 -08:00
|
|
|
|
1999-02-25 02:26:38 -08:00
|
|
|
let clear b = b.position <- 0
|
1999-02-16 01:07:26 -08:00
|
|
|
|
1999-03-02 06:49:12 -08:00
|
|
|
let reset b =
|
|
|
|
b.position <- 0; b.buffer <- b.initial_buffer;
|
|
|
|
b.length <- String.length b.buffer
|
1999-02-16 01:07:26 -08:00
|
|
|
|
|
|
|
let resize b more =
|
1999-02-25 02:26:38 -08:00
|
|
|
let len = b.length in
|
|
|
|
let new_len = ref len in
|
|
|
|
while b.position + more > !new_len do new_len := 2 * !new_len done;
|
2002-03-29 06:24:22 -08:00
|
|
|
if !new_len > Sys.max_string_length then begin
|
|
|
|
if b.position + more <= Sys.max_string_length
|
|
|
|
then new_len := Sys.max_string_length
|
|
|
|
else failwith "Buffer.add: cannot grow buffer"
|
|
|
|
end;
|
1999-02-25 02:26:38 -08:00
|
|
|
let new_buffer = String.create !new_len in
|
1999-02-16 01:07:26 -08:00
|
|
|
String.blit b.buffer 0 new_buffer 0 b.position;
|
|
|
|
b.buffer <- new_buffer;
|
1999-02-25 02:26:38 -08:00
|
|
|
b.length <- !new_len
|
|
|
|
|
|
|
|
let add_char b c =
|
|
|
|
let pos = b.position in
|
|
|
|
if pos >= b.length then resize b 1;
|
|
|
|
b.buffer.[pos] <- c;
|
|
|
|
b.position <- pos + 1
|
|
|
|
|
|
|
|
let add_substring b s offset len =
|
|
|
|
if offset < 0 || len < 0 || offset + len > String.length s
|
|
|
|
then invalid_arg "Buffer.add_substring";
|
|
|
|
let new_position = b.position + len in
|
|
|
|
if new_position > b.length then resize b len;
|
|
|
|
String.blit s offset b.buffer b.position len;
|
|
|
|
b.position <- new_position
|
|
|
|
|
|
|
|
let add_string b s =
|
|
|
|
let len = String.length s in
|
|
|
|
let new_position = b.position + len in
|
|
|
|
if new_position > b.length then resize b len;
|
|
|
|
String.blit s 0 b.buffer b.position len;
|
|
|
|
b.position <- new_position
|
|
|
|
|
|
|
|
let add_buffer b bs =
|
|
|
|
add_substring b bs.buffer 0 bs.position
|
|
|
|
|
|
|
|
let add_channel b ic len =
|
|
|
|
if b.position + len > b.length then resize b len;
|
|
|
|
really_input ic b.buffer b.position len;
|
|
|
|
b.position <- b.position + len
|
|
|
|
|
|
|
|
let output_buffer oc b =
|
|
|
|
output oc b.buffer 0 b.position
|