blob: 8a2a467aac38d37f0dc9d4b8c2a8c453f8523a1a (
plain)
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
|
(************************************************************************)
(* v * The Coq Proof Assistant / The Coq Development Team *)
(* <O___,, * INRIA - CNRS - LIX - LRI - PPS - Copyright 1999-2010 *)
(* \VV/ **************************************************************)
(* // * This file is distributed under the terms of the *)
(* * GNU Lesser General Public License Version 2.1 *)
(************************************************************************)
(* $Id: dyn.ml 13323 2010-07-24 15:57:30Z herbelin $ *)
open Util
(* Dynamics, programmed with DANGER !!! *)
type t = string * Obj.t
let dyntab = ref ([] : string list)
let create s =
if List.mem s !dyntab then
anomaly ("Dyn.create: already declared dynamic " ^ s);
dyntab := s :: !dyntab;
((fun v -> (s,Obj.repr v)),
(fun (s',rv) ->
if s = s' then Obj.magic rv else failwith "dyn_out"))
let tag (s,_) = s
|