blob: cfc38ff9c96693ff9cf6a069ed622cd35b2b9a90 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
(* A more advanced example of how to explore the structure of terms of
type constr is given in the coq-dpdgraph plugin. *)
let simple_body_access gref =
match gref with
| Globnames.VarRef _ ->
failwith "variables are not covered in this example"
| Globnames.IndRef _ ->
failwith "inductive types are not covered in this example"
| Globnames.ConstructRef _ ->
failwith "constructors are not covered in this example"
| Globnames.ConstRef cst ->
let cb = Environ.lookup_constant cst (Global.env()) in
match Global.body_of_constant_body cb with
| Some(e, _) -> e
| None -> failwith "This term has no value"
|