git.annexia.org
/
ocaml-ancient.git
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
Fix error path if realloc call fails.
[ocaml-ancient.git]
/
ancient.ml
diff --git
a/ancient.ml
b/ancient.ml
index
dfce30c
..
eda7874
100644
(file)
--- a/
ancient.ml
+++ b/
ancient.ml
@@
-1,21
+1,32
@@
-(* Mark objects as 'ancient' so they are taken out of the OCaml heap.
- * $Id: ancient.ml,v 1.4 2006-09-28 12:40:07 rich Exp $
- *)
+(* Mark objects as 'ancient' so they are taken out of the OCaml heap. *)
type 'a ancient
type 'a ancient
-external mark : 'a -> 'a ancient = "ancient_mark"
+type info = {
+ i_size : int;
+}
+
+external mark_info : 'a -> 'a ancient * info = "ancient_mark_info"
+
+let mark obj = fst (mark_info obj)
external follow : 'a ancient -> 'a = "ancient_follow"
external delete : 'a ancient -> unit = "ancient_delete"
external follow : 'a ancient -> 'a = "ancient_follow"
external delete : 'a ancient -> unit = "ancient_delete"
+external is_ancient : 'a -> bool = "ancient_is_ancient"
+
+external address_of : 'a -> nativeint = "ancient_address_of"
+
type md
external attach : Unix.file_descr -> nativeint -> md = "ancient_attach"
external detach : md -> unit = "ancient_detach"
type md
external attach : Unix.file_descr -> nativeint -> md = "ancient_attach"
external detach : md -> unit = "ancient_detach"
-external share : md -> int -> 'a -> 'a ancient = "ancient_share"
+external share_info : md -> int -> 'a -> 'a ancient * info
+ = "ancient_share_info"
+
+let share md key obj = fst (share_info md key obj)
external get : md -> int -> 'a ancient = "ancient_get"
external get : md -> int -> 'a ancient = "ancient_get"