src/Pure/Tools/find_consts.ML
author wenzelm
Thu, 12 Nov 2020 11:46:53 +0100
changeset 72595 c806eeb9138c
parent 69349 7cef9e386ffe
child 74232 1091880266e5
permissions -rw-r--r--
clarified messages;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
     1
(*  Title:      Pure/Tools/find_consts.ML
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
     2
    Author:     Timothy Bourke and Gerwin Klein, NICTA
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
     3
68224
1f7308050349 prefer HTTPS;
wenzelm
parents: 64556
diff changeset
     4
Hoogle-like (https://www-users.cs.york.ac.uk/~ndm/hoogle) searching by
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
     5
type over constants, but matching is not fuzzy.
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
     6
*)
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
     7
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
     8
signature FIND_CONSTS =
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
     9
sig
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    10
  datatype criterion =
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    11
      Strict of string
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    12
    | Loose of string
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    13
    | Name of string
62848
e4140efe699e clarified bootstrap -- more uniform use of ML files;
wenzelm
parents: 61335
diff changeset
    14
  val pretty_consts: Proof.context -> (bool * criterion) list -> Pretty.T
e4140efe699e clarified bootstrap -- more uniform use of ML files;
wenzelm
parents: 61335
diff changeset
    15
  val query_parser: (bool * criterion) list parser
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
    16
  val read_query: Position.T -> string -> (bool * criterion) list
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    17
  val find_consts : Proof.context -> (bool * criterion) list -> unit
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    18
end;
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    19
33301
1fe9fc908ec3 less hermetic ML;
wenzelm
parents: 33158
diff changeset
    20
structure Find_Consts : FIND_CONSTS =
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    21
struct
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    22
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    23
(* search criteria *)
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    24
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    25
datatype criterion =
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    26
    Strict of string
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    27
  | Loose of string
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    28
  | Name of string;
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    29
31684
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    30
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    31
(* matching types/consts *)
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    32
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    33
fun matches_subtype thy typat =
38335
630f379f2660 misc tuning and simplification;
wenzelm
parents: 38334
diff changeset
    34
  Term.exists_subtype (fn ty => Sign.typ_instance thy (ty, typat));
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    35
61335
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
    36
fun check_const pred (c, (ty, _)) =
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
    37
  if pred (c, ty) then SOME (Term.size_of_typ ty) else NONE;
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    38
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    39
fun opt_not f (c as (_, (ty, _))) =
38335
630f379f2660 misc tuning and simplification;
wenzelm
parents: 38334
diff changeset
    40
  if is_some (f c) then NONE else SOME (Term.size_of_typ ty);
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    41
46979
ef4b0d6b2fb6 sort via string_ord (as secondary key), not fast_string_ord via Symtab.fold;
wenzelm
parents: 46961
diff changeset
    42
fun filter_const _ _ NONE = NONE
ef4b0d6b2fb6 sort via string_ord (as secondary key), not fast_string_ord via Symtab.fold;
wenzelm
parents: 46961
diff changeset
    43
  | filter_const c f (SOME rank) =
31684
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    44
      (case f c of
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    45
        NONE => NONE
46979
ef4b0d6b2fb6 sort via string_ord (as secondary key), not fast_string_ord via Symtab.fold;
wenzelm
parents: 46961
diff changeset
    46
      | SOME i => SOME (Int.min (rank, i)));
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    47
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    48
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    49
(* pretty results *)
29895
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    50
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    51
fun pretty_criterion (b, c) =
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    52
  let
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    53
    fun prfx s = if b then s else "-" ^ s;
69349
7cef9e386ffe more accurate positions for "name" (quoted string) and "embedded" (cartouche): refer to content without delimiters, which is e.g. relevant for systematic selection/renaming of scope groups;
wenzelm
parents: 68224
diff changeset
    54
    val show_pat = quote o #1 o Input.source_content o Syntax.read_input;
29895
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    55
  in
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    56
    (case c of
60667
d86c449d30ba plain string output, without funny control chars;
wenzelm
parents: 60664
diff changeset
    57
      Strict pat => Pretty.str (prfx "strict: " ^ show_pat pat)
d86c449d30ba plain string output, without funny control chars;
wenzelm
parents: 60664
diff changeset
    58
    | Loose pat => Pretty.str (prfx (show_pat pat))
29895
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    59
    | Name name => Pretty.str (prfx "name: " ^ quote name))
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    60
  end;
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    61
49886
0dc57c05bf4e more formal markup;
wenzelm
parents: 48646
diff changeset
    62
fun pretty_const ctxt (c, ty) =
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    63
  let
35845
e5980f0ad025 renamed varify/unvarify operations to varify_global/unvarify_global to emphasize that these only work in a global situation;
wenzelm
parents: 33301
diff changeset
    64
    val ty' = Logic.unvarifyT_global ty;
61335
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
    65
    val markup = Name_Space.markup (Proof_Context.const_space ctxt) c;
29895
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    66
  in
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    67
    Pretty.block
49886
0dc57c05bf4e more formal markup;
wenzelm
parents: 48646
diff changeset
    68
     [Pretty.mark markup (Pretty.str c), Pretty.str " ::", Pretty.brk 1,
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    69
      Pretty.quote (Syntax.pretty_typ ctxt ty')]
29895
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    70
  end;
0e70a29d3e02 find_consts: display the search criteria. (by Timothy Bourke)
kleing
parents: 29884
diff changeset
    71
31684
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    72
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    73
(* find_consts *)
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    74
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
    75
fun pretty_consts ctxt raw_criteria =
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    76
  let
42360
da8817d01e7c modernized structure Proof_Context;
wenzelm
parents: 42012
diff changeset
    77
    val thy = Proof_Context.theory_of ctxt;
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    78
    val low_ranking = 10000;
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    79
30207
c56d27155041 Implement Makarius's suggestion for improved type pattern parsing.
Timothy Bourke
parents: 30206
diff changeset
    80
    fun make_pattern crit =
c56d27155041 Implement Makarius's suggestion for improved type pattern parsing.
Timothy Bourke
parents: 30206
diff changeset
    81
      let
c56d27155041 Implement Makarius's suggestion for improved type pattern parsing.
Timothy Bourke
parents: 30206
diff changeset
    82
        val raw_T = Syntax.parse_typ ctxt crit;
31684
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    83
        val t =
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    84
          Syntax.check_term
42360
da8817d01e7c modernized structure Proof_Context;
wenzelm
parents: 42012
diff changeset
    85
            (Proof_Context.set_mode Proof_Context.mode_pattern ctxt)
31684
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    86
            (Term.dummy_pattern raw_T);
30207
c56d27155041 Implement Makarius's suggestion for improved type pattern parsing.
Timothy Bourke
parents: 30206
diff changeset
    87
      in Term.type_of t end;
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    88
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    89
    fun make_match (Strict arg) =
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    90
          let val qty = make_pattern arg; in
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    91
            fn (_, (ty, _)) =>
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
    92
              let
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    93
                val tye = Sign.typ_match thy (qty, ty) Vartab.empty;
31684
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    94
                val sub_size =
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
    95
                  Vartab.fold (fn (_, (_, t)) => fn n => Term.size_of_typ t + n) tye 0;
32790
a7b92f98180b handle Type.TYPE_MATCH, not arbitrary exceptions;
wenzelm
parents: 31687
diff changeset
    96
              in SOME sub_size end handle Type.TYPE_MATCH => NONE
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    97
          end
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    98
      | make_match (Loose arg) =
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
    99
          check_const (matches_subtype thy (make_pattern arg) o snd)
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   100
      | make_match (Name arg) = check_const (match_string arg o fst);
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   101
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   102
    fun make_criterion (b, crit) = (if b then I else opt_not) (make_match crit);
30206
48507466d9d2 find_consts: fold in preference to foldl; hide internal constants; remove redundant exception catch
Timothy Bourke
parents: 30190
diff changeset
   103
    val criteria = map make_criterion raw_criteria;
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   104
61335
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
   105
    fun user_visible (c, _) =
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
   106
      if Consts.is_concealed (Proof_Context.consts_of ctxt) c
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
   107
      then NONE else SOME low_ranking;
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
   108
31684
d5d830979a54 minor tuning according to Isabelle/ML conventions;
wenzelm
parents: 30207
diff changeset
   109
    fun eval_entry c =
61335
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
   110
      fold (filter_const c) (user_visible :: criteria) (SOME low_ranking);
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   111
61335
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
   112
    val {constants, ...} = Consts.dest (Sign.consts_of thy);
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
   113
    val matches =
56062
8ae2965ddc80 tuned signature;
wenzelm
parents: 56025
diff changeset
   114
      fold (fn c => (case eval_entry c of NONE => I | SOME rank => cons (rank, c))) constants []
59058
a78612c67ec0 renamed "pairself" to "apply2", in accordance to @{apply 2};
wenzelm
parents: 58928
diff changeset
   115
      |> sort (prod_ord (rev_order o int_ord) (string_ord o apply2 fst))
46979
ef4b0d6b2fb6 sort via string_ord (as secondary key), not fast_string_ord via Symtab.fold;
wenzelm
parents: 46961
diff changeset
   116
      |> map (apsnd fst o snd);
56912
293cd4dcfebc some position markup to help locating the query context, e.g. from "Info" dockable;
wenzelm
parents: 56908
diff changeset
   117
293cd4dcfebc some position markup to help locating the query context, e.g. from "Info" dockable;
wenzelm
parents: 56908
diff changeset
   118
    val position_markup = Position.markup (Position.thread_data ()) Markup.position;
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   119
  in
56891
48899c43b07d tuned message -- more context for detached window etc.;
wenzelm
parents: 56763
diff changeset
   120
    Pretty.block
56912
293cd4dcfebc some position markup to help locating the query context, e.g. from "Info" dockable;
wenzelm
parents: 56908
diff changeset
   121
      (Pretty.fbreaks
293cd4dcfebc some position markup to help locating the query context, e.g. from "Info" dockable;
wenzelm
parents: 56908
diff changeset
   122
        (Pretty.mark position_markup (Pretty.keyword1 "find_consts") ::
293cd4dcfebc some position markup to help locating the query context, e.g. from "Info" dockable;
wenzelm
parents: 56908
diff changeset
   123
          map pretty_criterion raw_criteria)) ::
38335
630f379f2660 misc tuning and simplification;
wenzelm
parents: 38334
diff changeset
   124
    Pretty.str "" ::
56908
734f7e6151c9 tuned message: more compact, imitate actual command line;
wenzelm
parents: 56891
diff changeset
   125
    (if null matches then [Pretty.str "found nothing"]
734f7e6151c9 tuned message: more compact, imitate actual command line;
wenzelm
parents: 56891
diff changeset
   126
     else
734f7e6151c9 tuned message: more compact, imitate actual command line;
wenzelm
parents: 56891
diff changeset
   127
       Pretty.str ("found " ^ string_of_int (length matches) ^ " constant(s):") ::
734f7e6151c9 tuned message: more compact, imitate actual command line;
wenzelm
parents: 56891
diff changeset
   128
       grouped 10 Par_List.map (Pretty.item o single o pretty_const ctxt) matches)
61335
43848476063c pretty_const: proper local name space;
wenzelm
parents: 61223
diff changeset
   129
  end |> Pretty.chunks;
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   130
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   131
fun find_consts ctxt args = Pretty.writeln (pretty_consts ctxt args);
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   132
30142
8d6145694bb5 moved find_theorems.ML and find_consts.ML to Pure/Tools, collecting main implementation in one place each;
wenzelm
parents: 29895
diff changeset
   133
30143
98a986b02022 observe basic Isabelle/ML coding conventions;
wenzelm
parents: 30142
diff changeset
   134
(* command syntax *)
30142
8d6145694bb5 moved find_theorems.ML and find_consts.ML to Pure/Tools, collecting main implementation in one place each;
wenzelm
parents: 29895
diff changeset
   135
38334
c677c2c1d333 simplified/unified command setup;
wenzelm
parents: 36953
diff changeset
   136
local
30142
8d6145694bb5 moved find_theorems.ML and find_consts.ML to Pure/Tools, collecting main implementation in one place each;
wenzelm
parents: 29895
diff changeset
   137
8d6145694bb5 moved find_theorems.ML and find_consts.ML to Pure/Tools, collecting main implementation in one place each;
wenzelm
parents: 29895
diff changeset
   138
val criterion =
62969
9f394a16c557 eliminated "xname" and variants;
wenzelm
parents: 62848
diff changeset
   139
  Parse.reserved "name" |-- Parse.!!! (Parse.$$$ ":" |-- Parse.name) >> Name ||
60664
263a8f15faf3 proper outer syntax category, e.g. relevant for PIDE markup;
wenzelm
parents: 60610
diff changeset
   140
  Parse.reserved "strict" |-- Parse.!!! (Parse.$$$ ":" |-- Parse.typ) >> Strict ||
263a8f15faf3 proper outer syntax category, e.g. relevant for PIDE markup;
wenzelm
parents: 60610
diff changeset
   141
  Parse.typ >> Loose;
30142
8d6145694bb5 moved find_theorems.ML and find_consts.ML to Pure/Tools, collecting main implementation in one place each;
wenzelm
parents: 29895
diff changeset
   142
63429
baedd4724f08 tuned signature: more uniform Keyword.spec;
wenzelm
parents: 62969
diff changeset
   143
val query_keywords =
64556
851ae0e7b09c more symbols;
wenzelm
parents: 63429
diff changeset
   144
  Keyword.add_keywords [((":", \<^here>), Keyword.no_spec)] Keyword.empty_keywords;
58905
55160ef37e8f more frugal keywords;
wenzelm
parents: 58903
diff changeset
   145
38334
c677c2c1d333 simplified/unified command setup;
wenzelm
parents: 36953
diff changeset
   146
in
c677c2c1d333 simplified/unified command setup;
wenzelm
parents: 36953
diff changeset
   147
62848
e4140efe699e clarified bootstrap -- more uniform use of ML files;
wenzelm
parents: 61335
diff changeset
   148
val query_parser = Scan.repeat ((Scan.option Parse.minus >> is_none) -- criterion);
e4140efe699e clarified bootstrap -- more uniform use of ML files;
wenzelm
parents: 61335
diff changeset
   149
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   150
fun read_query pos str =
59083
88b0b1f28adc tuned signature;
wenzelm
parents: 59058
diff changeset
   151
  Token.explode query_keywords pos str
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   152
  |> filter Token.is_proper
62848
e4140efe699e clarified bootstrap -- more uniform use of ML files;
wenzelm
parents: 61335
diff changeset
   153
  |> Scan.error (Scan.finite Token.stopper (Parse.!!! (query_parser --| Scan.ahead Parse.eof)))
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   154
  |> #1;
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   155
29884
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   156
end;
74c183927054 added ML file for the find_consts command
kleing
parents:
diff changeset
   157
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   158
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   159
(* PIDE query operation *)
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   160
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   161
val _ =
60610
f52b4b0c10c4 improved scheduling for urgent tasks, using farm of replacement threads (may lead to factor 2 overloading, but CPUs are usually hyperthreaded);
wenzelm
parents: 59936
diff changeset
   162
  Query_Operation.register {name = "find_consts", pri = Task_Queue.urgent_pri}
61223
dfccf6c06201 clarified markup;
wenzelm
parents: 60667
diff changeset
   163
    (fn {state, args, writeln_result, ...} =>
60610
f52b4b0c10c4 improved scheduling for urgent tasks, using farm of replacement threads (may lead to factor 2 overloading, but CPUs are usually hyperthreaded);
wenzelm
parents: 59936
diff changeset
   164
      (case try Toplevel.context_of state of
f52b4b0c10c4 improved scheduling for urgent tasks, using farm of replacement threads (may lead to factor 2 overloading, but CPUs are usually hyperthreaded);
wenzelm
parents: 59936
diff changeset
   165
        SOME ctxt =>
f52b4b0c10c4 improved scheduling for urgent tasks, using farm of replacement threads (may lead to factor 2 overloading, but CPUs are usually hyperthreaded);
wenzelm
parents: 59936
diff changeset
   166
          let
f52b4b0c10c4 improved scheduling for urgent tasks, using farm of replacement threads (may lead to factor 2 overloading, but CPUs are usually hyperthreaded);
wenzelm
parents: 59936
diff changeset
   167
            val [query_arg] = args;
f52b4b0c10c4 improved scheduling for urgent tasks, using farm of replacement threads (may lead to factor 2 overloading, but CPUs are usually hyperthreaded);
wenzelm
parents: 59936
diff changeset
   168
            val query = read_query Position.none query_arg;
61223
dfccf6c06201 clarified markup;
wenzelm
parents: 60667
diff changeset
   169
          in writeln_result (Pretty.string_of (pretty_consts ctxt query)) end
60610
f52b4b0c10c4 improved scheduling for urgent tasks, using farm of replacement threads (may lead to factor 2 overloading, but CPUs are usually hyperthreaded);
wenzelm
parents: 59936
diff changeset
   170
      | NONE => error "Unknown context"));
56758
d203b9c400a2 PIDE support for find_consts;
wenzelm
parents: 56062
diff changeset
   171
38334
c677c2c1d333 simplified/unified command setup;
wenzelm
parents: 36953
diff changeset
   172
end;