Skip to content

Commit

Permalink
cleanup libobject (fix #253)
Browse files Browse the repository at this point in the history
  • Loading branch information
gares committed Jul 30, 2022
1 parent b36bfad commit 0668e1b
Show file tree
Hide file tree
Showing 5 changed files with 66 additions and 21 deletions.
3 changes: 3 additions & 0 deletions _CoqProject.test
Original file line number Diff line number Diff line change
Expand Up @@ -31,3 +31,6 @@ tests/test_COQ_ELPI_ATTRIBUTES.v
tests/perf_calls.v
tests/test_require_bad_order.v
tests/test_ctx_cache.v
tests/test_libobject_A.v
tests/test_libobject_B.v
tests/test_libobject_C.v
49 changes: 28 additions & 21 deletions src/coq_elpi_vernacular.ml
Original file line number Diff line number Diff line change
Expand Up @@ -295,7 +295,8 @@ let append_to_prog name nature l =
seen, nature, prog

let in_program : qualified_name * nature option * src list -> Libobject.obj =
Libobject.declare_object @@ Libobject.global_object_nodischarge "ELPI"
let open Libobject in
declare_object @@ global_object_nodischarge "ELPI"
~cache:(fun (name,nature,src_ast) ->
program_src :=
SLMap.add name (append_to_prog name nature src_ast) !program_src)
Expand Down Expand Up @@ -330,21 +331,22 @@ type snippet = {
}

let in_db : Names.Id.t -> snippet -> Libobject.obj =
let open Libobject in
let cache ((_,kname), { program = name; code = p; _ }) =
db_name_src := SLMap.add name (append_to_db name (kname,p)) !db_name_src in
let import i (_, s as o) = if Int.equal i 1 || s.scope = Coq_elpi_utils.SuperGlobal then cache o in
Libobject.declare_named_object @@ { (Libobject.default_object "ELPI-DB") with
Libobject.classify_function = (fun { scope; program; _ } ->
declare_named_object @@ { (default_object "ELPI-DB") with
classify_function = (fun { scope; program; _ } ->
match scope with
| Coq_elpi_utils.Local -> Libobject.Dispose
| Coq_elpi_utils.Regular -> Libobject.Substitute
| Coq_elpi_utils.Global -> Libobject.Keep
| Coq_elpi_utils.SuperGlobal -> Libobject.Keep);
Libobject.load_function = import;
Libobject.cache_function = cache;
Libobject.subst_function = (fun (_,o) -> o);
Libobject.open_function = Libobject.simple_open import;
Libobject.discharge_function = (fun (({ scope; program; vars; } as o)) ->
| Coq_elpi_utils.Local -> Dispose
| Coq_elpi_utils.Regular -> Substitute
| Coq_elpi_utils.Global -> Keep
| Coq_elpi_utils.SuperGlobal -> Keep);
load_function = import;
cache_function = cache;
subst_function = (fun (_,o) -> o);
open_function = simple_open import;
discharge_function = (fun (({ scope; program; vars; } as o)) ->
if scope = Coq_elpi_utils.Local || (List.exists (fun x -> Lib.is_in_section (Names.GlobRef.VarRef x)) vars) then None
else Some o);

Expand All @@ -357,8 +359,9 @@ let add_to_db program code vars scope =

let lp_command_ast = Summary.ref ~name:"elpi-lp-command" None
let in_lp_command_src : src -> Libobject.obj =
Libobject.declare_object { Libobject.(default_object "ELPI-LP-COMMAND") with
Libobject.load_function = (fun _ x -> lp_command_ast := Some x);
let open Libobject in
declare_object { (default_object "ELPI-LP-COMMAND") with
load_function = (fun _ x -> lp_command_ast := Some x);
}
let load_command s =
let elpi = ensure_initialized () in
Expand All @@ -375,8 +378,9 @@ let command_init () =

let lp_tactic_ast = Summary.ref ~name:"elpi-lp-tactic" None
let in_lp_tactic_ast : src -> Libobject.obj =
Libobject.declare_object { Libobject.(default_object "ELPI-LP-TACTIC") with
Libobject.load_function = (fun _ x -> lp_tactic_ast := Some x);
let open Libobject in
declare_object { (default_object "ELPI-LP-TACTIC") with
load_function = (fun _ x -> lp_tactic_ast := Some x);
}
let load_tactic s =
let elpi = ensure_initialized () in
Expand Down Expand Up @@ -437,8 +441,9 @@ let get x =

let lp_checker_ast = Summary.ref ~name:"elpi-lp-checker" None
let in_lp_checker_ast : EC.compilation_unit list -> Libobject.obj =
Libobject.declare_object { Libobject.(default_object "ELPI-LP-CHECKER") with
Libobject.load_function = (fun _ x -> lp_checker_ast := Some x);
let open Libobject in
declare_object { (default_object "ELPI-LP-CHECKER") with
load_function = (fun _ x -> lp_checker_ast := Some x);
}

let load_checker s =
Expand All @@ -454,8 +459,9 @@ let checker () =

let lp_printer_ast = Summary.ref ~name:"elpi-lp-printer" None
let in_lp_printer_ast : EC.compilation_unit -> Libobject.obj =
Libobject.declare_object { Libobject.(default_object "ELPI-LP-PRINTER") with
Libobject.load_function = (fun _ x -> lp_printer_ast := Some x);
let open Libobject in
declare_object { (default_object "ELPI-LP-PRINTER") with
load_function = (fun _ x -> lp_printer_ast := Some x);
}
let load_printer s =
let elpi = ensure_initialized () in
Expand Down Expand Up @@ -871,7 +877,8 @@ let subst_program = function
| _, (Program _,_,_) -> assert false

let in_exported_program : nature * qualified_name * string -> Libobject.obj =
Libobject.declare_object @@ Libobject.global_object_nodischarge "ELPI-EXPORTED"
let open Libobject in
declare_object @@ global_object_nodischarge "ELPI-EXPORTED"
~cache:cache_program
~subst:(Some subst_program)

Expand Down
7 changes: 7 additions & 0 deletions tests/test_libobject_A.v
Original file line number Diff line number Diff line change
@@ -0,0 +1,7 @@
From elpi Require Import elpi.

Elpi Db a.db lp:{{
pred a o:term.
:name "init" a {{ 0 }}.
a {{ 1 }}.
}}.
13 changes: 13 additions & 0 deletions tests/test_libobject_B.v
Original file line number Diff line number Diff line change
@@ -0,0 +1,13 @@
From elpi Require Import elpi.

From elpi.tests Require Import test_libobject_A.

Elpi Tactic tac.
Elpi Accumulate Db a.db.
Elpi Accumulate lp:{{
solve _ _ :-
a X, coq.say X.
}}.
Elpi Typecheck.

Ltac b := elpi tac.
15 changes: 15 additions & 0 deletions tests/test_libobject_C.v
Original file line number Diff line number Diff line change
@@ -0,0 +1,15 @@
From elpi.tests Require Import test_libobject_B.

Goal True.
b.
Abort.

Import elpi.

Elpi Accumulate a.db lp:{{
:before "init" a {{ 3 }}.
}}.

Goal True.
b.
Abort.

0 comments on commit 0668e1b

Please sign in to comment.