/usr/lib/ocaml/galax/dynamic_buffer.mli is in libgalax-ocaml-dev 1.1-13build1.
This file is owned by root:root, with mode 0o644.
The actual contents of the file can be viewed below.
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 | (***********************************************************************)
(* *)
(* GALAX *)
(* XQuery Engine *)
(* *)
(* Copyright 2001-2007. *)
(* Distributed only by permission. *)
(* *)
(***********************************************************************)
(* $Id: dynamic_buffer.mli,v 1.2 2007/02/01 22:08:45 simeon Exp $ *)
(* Module: Dynamic_buffer
Description:
This module implements a buffer that automatically grows (if need
be) when adding new elements. The buffer itself is composed of an
array of arrays (chunks) the index space of which is exposed to
the outside world as being linear.
The buffer maintains a single internal cursor for keeping track
of the current position; usage should adhere to the following
protocol:
- create the buffer
- add values to the buffer
- position the cursor, read values etc.
- reset the buffer, then start again
The allocated buffer space will never shrink (even in case of a
reset). This behaviour is intentional.
- Michael *)
(* The structure holding the actual data. *)
type 'a t
(* Signals that the end of the buffer has been reached. *)
exception Exhausted
(* Creates a new buffer, using the specified (int that order)
- number of chunks
- chunk size
- increment
- initial value. *)
val make :
int -> int -> int -> 'a -> 'a t
(* Sets the internal cursor to the specified index position. *)
val position :
'a t -> int -> unit
(* Returns the value currently pointed at by the internal cursor,
then increments that cursor. *)
val next :
'a t -> 'a
(* Adds a value at the end of the buffer. *)
val add :
'a t -> 'a -> unit
(* Resets the internal cursor to position 0. *)
val reset :
'a t -> unit
(* True just after creation or after reset has been applied. *)
val is_empty :
'a t -> bool
(* Returns the index position currently pointed at by the internal cursor. *)
val get_position :
'a t -> int
|