X-Git-Url: http://matita.cs.unibo.it/gitweb/?a=blobdiff_plain;f=helm%2Fsoftware%2Flambda-delta%2Fbasic_rg%2FbrgEnvironment.ml;h=121da88da4d54e955fa480e68aa88ea31048704c;hb=e22808c929a9cebf5e4e2b7428ff0cbf89e1f92a;hp=29c6dd4754b86fc75875fe8148ee2e3d0bd26d64;hpb=0dc347a7742e40a828fa98acba70078dd2d7cbd5;p=helm.git diff --git a/helm/software/lambda-delta/basic_rg/brgEnvironment.ml b/helm/software/lambda-delta/basic_rg/brgEnvironment.ml index 29c6dd475..121da88da 100644 --- a/helm/software/lambda-delta/basic_rg/brgEnvironment.ml +++ b/helm/software/lambda-delta/basic_rg/brgEnvironment.ml @@ -11,20 +11,25 @@ module U = NUri module H = U.UriHash +module Y = Entity module B = Brg let hsize = 7000 let env = H.create hsize -let entry = ref 1 (* Internal functions *******************************************************) +let get_age = + let age = ref 0 in + fun () -> incr age; !age + (* Interface functions ******************************************************) -let set_obj f obj = - let _, uri, b = obj in - let obj = !entry, uri, b in - incr entry; H.add env uri obj; f obj +(* decps *) +let set_entity (a, uri, b) = + let age = get_age () in + let entity = (Y.Apix age :: a), uri, b in + H.add env uri entity; entity -let get_obj err f uri = - try f (H.find env uri) with Not_found -> err () +let get_entity uri = + try H.find env uri with Not_found -> [], uri, Y.Void