Skip to content

Commit

Permalink
Fix Search is:Scheme
Browse files Browse the repository at this point in the history
  • Loading branch information
SkySkimmer committed Nov 21, 2023
1 parent 19367c7 commit 2ab7346
Show file tree
Hide file tree
Showing 3 changed files with 15 additions and 5 deletions.
2 changes: 1 addition & 1 deletion tactics/declareScheme.ml
Original file line number Diff line number Diff line change
Expand Up @@ -43,4 +43,4 @@ let declare_scheme kind indcl =

let lookup_scheme kind ind = CString.Map.find kind (Indmap.find ind !scheme_map)

let all_schemes () = Indmap.domain !scheme_map
let all_schemes () = !scheme_map
8 changes: 5 additions & 3 deletions tactics/declareScheme.mli
Original file line number Diff line number Diff line change
Expand Up @@ -8,6 +8,8 @@
(* * (see LICENSE file for the text of the license) *)
(************************************************************************)

val declare_scheme : string -> (Names.inductive * Names.Constant.t) -> unit
val lookup_scheme : string -> Names.inductive -> Names.Constant.t
val all_schemes : unit -> Names.Indset.t
open Names

val declare_scheme : string -> (inductive * Constant.t) -> unit
val lookup_scheme : string -> inductive -> Constant.t
val all_schemes : unit -> Constant.t CString.Map.t Indmap.t
10 changes: 9 additions & 1 deletion vernac/comSearch.ml
Original file line number Diff line number Diff line change
Expand Up @@ -45,7 +45,15 @@ let kind_searcher = Decls.(function
Inr (fun gr -> List.exists (fun c -> GlobRef.CanOrd.equal c.Structures.CSTable.solution gr) canonproj)
| IsDefinition Scheme ->
let schemes = DeclareScheme.all_schemes () in
Inr (fun gr -> Indset.exists (fun c -> GlobRef.CanOrd.equal (GlobRef.IndRef c) gr) schemes)
let schemes = lazy begin
Indmap.fold (fun _ schemes acc ->
CString.Map.fold (fun _ c acc -> Cset.add c acc) schemes acc)
schemes Cset.empty
end
in
Inr (function
| ConstRef c -> Cset.mem c (Lazy.force schemes)
| _ -> false)
| IsDefinition Instance ->
let instances = Typeclasses.all_instances () in
Inr (fun gr -> List.exists (fun c -> GlobRef.CanOrd.equal c.Typeclasses.is_impl gr) instances))
Expand Down

0 comments on commit 2ab7346

Please sign in to comment.