src/Pure/ProofGeneral/preferences.ML
author wenzelm
Tue, 14 May 2013 21:40:25 +0200
changeset 51992 5c179451c445
parent 51991 5b814dd90f7f
permissions -rw-r--r--
more elementary pgiptype;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     1
(*  Title:      Pure/ProofGeneral/preferences.ML
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     2
    Author:     David Aspinall and Markus Wenzel
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     3
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     4
User preferences for Isabelle which are maintained by the interface.
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     5
*)
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     6
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
     7
signature PREFERENCES =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     8
sig
30980
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
     9
  val category_display: string
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    10
  val category_advanced_display: string
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    11
  val category_tracing: string
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    12
  val category_proof: string
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    13
  type preference =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    14
   {name: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    15
    descr: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    16
    default: string,
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    17
    pgiptype: string,
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    18
    get: unit -> string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    19
    set: string -> unit}
51944
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    20
  val options_pref: string -> string -> string -> preference
32738
15bb09ca0378 explicit indication of Unsynchronized.ref;
wenzelm
parents: 32061
diff changeset
    21
  val string_pref: string Unsynchronized.ref -> string -> string -> preference
40292
ba13793594f0 support for real valued preferences;
wenzelm
parents: 39616
diff changeset
    22
  val real_pref: real Unsynchronized.ref -> string -> string -> preference
32738
15bb09ca0378 explicit indication of Unsynchronized.ref;
wenzelm
parents: 32061
diff changeset
    23
  val int_pref: int Unsynchronized.ref -> string -> string -> preference
15bb09ca0378 explicit indication of Unsynchronized.ref;
wenzelm
parents: 32061
diff changeset
    24
  val bool_pref: bool Unsynchronized.ref -> string -> string -> preference
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    25
  type T = (string * preference list) list
51970
f08366cb9fd1 tuned signature;
wenzelm
parents: 51960
diff changeset
    26
  val thm_depsN: string
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    27
  val pure_preferences: T
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    28
  val add: string -> preference -> T -> T
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    29
end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    30
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    31
structure Preferences: PREFERENCES =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    32
struct
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    33
30980
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    34
(* categories *)
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    35
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    36
val category_display = "Display";
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    37
val category_advanced_display = "Advanced Display";
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    38
val category_tracing = "Tracing";
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    39
val category_proof = "Proof"
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    40
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
    41
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    42
(* preferences and preference tables *)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    43
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    44
type preference =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    45
 {name: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    46
  descr: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    47
  default: string,
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    48
  pgiptype: string,
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    49
  get: unit -> string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    50
  set: string -> unit};
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    51
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    52
val pgipbool = "pgipbool";
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    53
val pgipint = "pgipint";
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    54
val pgipfloat = "pgipint";  (*NB: PG 3.7.x and 4.0 lack pgipfloat, but accept floats as pgipint*)
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    55
val pgipstring = "pgipstring";
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    56
51944
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    57
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    58
(* options as preferences *)
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    59
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    60
fun options_pref option_name pgip_name descr : preference =
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    61
  let
51946
449fbf64f4a5 tuned signature;
wenzelm
parents: 51944
diff changeset
    62
    val typ = Options.default_typ option_name;
51944
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    63
    val pgiptype =
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    64
      if typ = Options.boolT then pgipbool
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    65
      else if typ = Options.intT then pgipint
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    66
      else if typ = Options.realT then pgipfloat
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    67
      else pgipstring;
51944
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    68
  in
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    69
   {name = pgip_name,
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    70
    descr = descr,
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    71
    default = Options.get_default option_name,
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    72
    pgiptype = pgiptype,
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    73
    get = fn () => Options.get_default option_name,
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    74
    set = Options.put_default option_name}
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    75
  end;
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    76
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    77
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    78
(* generic preferences *)
45b972dc7888 support for options as preferences;
wenzelm
parents: 51553
diff changeset
    79
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    80
fun mkpref raw_get raw_set typ name descr : preference =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    81
  let
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    82
    fun get () = CRITICAL raw_get;
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    83
    fun set x = CRITICAL (fn () => raw_set x);
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    84
  in {name = name, descr = descr, pgiptype = typ, get = get, set = set, default = get ()} end;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    85
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    86
fun generic_pref read write typ r =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    87
  mkpref (fn () => read (! r)) (fn x => r := write x) typ;
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    88
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    89
val bool_pref = generic_pref Markup.print_bool Markup.parse_bool pgipbool;
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    90
val int_pref = generic_pref Markup.print_int Markup.parse_int pgipint;
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    91
val real_pref = generic_pref Markup.print_real Markup.parse_real pgipfloat;
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
    92
val string_pref = generic_pref I I pgipstring;
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    93
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    94
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    95
(* preferences of Pure *)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    96
39616
8052101883c3 renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
wenzelm
parents: 39165
diff changeset
    97
val proof_pref = Unsynchronized.setmp Proofterm.proofs 1 (fn () =>
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    98
  let
51991
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
    99
    fun get () = Markup.print_bool (Proofterm.proofs_enabled ());
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
   100
    fun set s = Proofterm.proofs := (if Markup.parse_bool s then 2 else 1);
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
   101
  in mkpref get set pgipbool "full-proofs" "Record full proof objects internally" end) ();
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   102
32061
11f8ee55662d parallel_proofs: more fine-grained control with optional parallel checking of nested Isar proofs;
wenzelm
parents: 30985
diff changeset
   103
val parallel_proof_pref =
11f8ee55662d parallel_proofs: more fine-grained control with optional parallel checking of nested Isar proofs;
wenzelm
parents: 30985
diff changeset
   104
  let
51991
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
   105
    fun get () = Markup.print_bool (! Goal.parallel_proofs >= 1);
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
   106
    fun set s = Goal.parallel_proofs := (if Markup.parse_bool s then 1 else 0);
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
   107
  in mkpref get set pgipbool "parallel-proofs" "Check proofs in parallel" end;
32061
11f8ee55662d parallel_proofs: more fine-grained control with optional parallel checking of nested Isar proofs;
wenzelm
parents: 30985
diff changeset
   108
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   109
val thm_depsN = "thm_deps";
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
   110
val thm_deps_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   111
  let
51991
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
   112
    fun get () = Markup.print_bool (print_mode_active thm_depsN);
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   113
    fun set s =
51991
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
   114
      if Markup.parse_bool s
32738
15bb09ca0378 explicit indication of Unsynchronized.ref;
wenzelm
parents: 32061
diff changeset
   115
      then Unsynchronized.change print_mode (insert (op =) thm_depsN)
15bb09ca0378 explicit indication of Unsynchronized.ref;
wenzelm
parents: 32061
diff changeset
   116
      else Unsynchronized.change print_mode (remove (op =) thm_depsN);
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   117
  in
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
   118
    mkpref get set pgipbool "theorem-dependencies"
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   119
      "Track theorem dependencies within Proof General"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   120
  end;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   121
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   122
val print_depth_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   123
  let
51991
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
   124
    val get = Markup.print_int o get_print_depth;
5b814dd90f7f prefer Markup.parse/print operations -- slight change of exception behaviour;
wenzelm
parents: 51971
diff changeset
   125
    val set = print_depth o Markup.parse_int;
51992
5c179451c445 more elementary pgiptype;
wenzelm
parents: 51991
diff changeset
   126
  in mkpref get set pgipint "print-depth" "Setting for the ML print depth" end;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   127
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   128
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
   129
val display_preferences =
42289
dafae095d733 discontinued special status of structure Printer;
wenzelm
parents: 42284
diff changeset
   130
 [bool_pref Printer.show_types_default
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   131
    "show-types"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   132
    "Include types in display of Isabelle terms",
42289
dafae095d733 discontinued special status of structure Printer;
wenzelm
parents: 42284
diff changeset
   133
  bool_pref Printer.show_sorts_default
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   134
    "show-sorts"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   135
    "Include sorts in display of Isabelle terms",
42289
dafae095d733 discontinued special status of structure Printer;
wenzelm
parents: 42284
diff changeset
   136
  bool_pref Goal_Display.show_consts_default
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   137
    "show-consts"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   138
    "Show types of consts in Isabelle goal display",
51949
f6858bb224c9 some system options as context-sensitive config options;
wenzelm
parents: 51946
diff changeset
   139
  options_pref "names_long"
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   140
    "long-names"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   141
    "Show fully qualified names in Isabelle terms",
42289
dafae095d733 discontinued special status of structure Printer;
wenzelm
parents: 42284
diff changeset
   142
  bool_pref Printer.show_brackets_default
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   143
    "show-brackets"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   144
    "Show full bracketing in Isabelle terms",
39125
f45d332a90e3 pretty_goals: turned some global references and function arguments into configuration options (goals_limit = 10, goals_total = true, show_main_goal = false) depending on the context;
wenzelm
parents: 39050
diff changeset
   145
  bool_pref Goal_Display.show_main_goal_default
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   146
    "show-main-goal"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   147
    "Show main goal in proof state display",
42284
326f57825e1a explicit structure Syntax_Trans;
wenzelm
parents: 42012
diff changeset
   148
  bool_pref Syntax_Trans.eta_contract_default
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   149
    "eta-contract"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   150
    "Print terms eta-contracted"];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   151
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   152
val advanced_display_preferences =
51960
61ac1efe02c3 option "goals_limit", with more uniform description;
wenzelm
parents: 51949
diff changeset
   153
 [options_pref "goals_limit"
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   154
    "goals-limit"
51960
61ac1efe02c3 option "goals_limit", with more uniform description;
wenzelm
parents: 51949
diff changeset
   155
    "Setting for maximum number of subgoals to be printed",
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   156
  print_depth_pref,
51949
f6858bb224c9 some system options as context-sensitive config options;
wenzelm
parents: 51946
diff changeset
   157
  options_pref "show_question_marks"
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   158
    "show-question-marks"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   159
    "Show leading question mark of variable name"];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   160
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
   161
val tracing_preferences =
41228
e1fce873b814 renamed structure MetaSimplifier to raw_Simplifer, to emphasize its meaning;
wenzelm
parents: 41227
diff changeset
   162
 [bool_pref Raw_Simplifier.simp_trace_default
35995
26e820d27e0a re-introduce reference to control simplifier tracing (needed for ProofGeneral settings menu) (cf. 12bb31230550)
boehmes
parents: 35979
diff changeset
   163
    "trace-simplifier"
26e820d27e0a re-introduce reference to control simplifier tracing (needed for ProofGeneral settings menu) (cf. 12bb31230550)
boehmes
parents: 35979
diff changeset
   164
    "Trace simplification rules.",
51971
716bb7e2e272 simplified preferences, removed obsolete operations;
wenzelm
parents: 51970
diff changeset
   165
  int_pref Raw_Simplifier.simp_trace_depth_limit_default
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   166
    "trace-simplifier-depth"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   167
    "Trace simplifier depth limit.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   168
  bool_pref Pattern.trace_unify_fail
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   169
    "trace-unification"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   170
    "Output error diagnostics during unification",
42012
2c3fe3cbebae structure Timing: covers former start_timing/end_timing and Output.timeit etc;
wenzelm
parents: 41698
diff changeset
   171
  bool_pref Toplevel.timing
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   172
    "global-timing"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   173
    "Whether to enable timing in Isabelle.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   174
  bool_pref Toplevel.debug
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   175
    "debugging"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   176
    "Whether to enable debugging.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   177
  thm_deps_pref];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   178
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
   179
val proof_preferences =
39616
8052101883c3 renamed setmp_noncritical to Unsynchronized.setmp to emphasize its meaning;
wenzelm
parents: 39165
diff changeset
   180
 [Unsynchronized.setmp quick_and_dirty true (fn () =>
30980
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
   181
    bool_pref quick_and_dirty
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
   182
      "quick-and-dirty"
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
   183
      "Take a few short cuts") (),
51553
63327f679cff more ambitious Goal.skip_proofs: covers Goal.prove forms as well, and do not insist in quick_and_dirty (for the sake of Isabelle/jEdit);
wenzelm
parents: 48634
diff changeset
   184
  bool_pref Goal.skip_proofs
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   185
    "skip-proofs"
48634
30a6e841390a explicit option skip_proofs;
wenzelm
parents: 42669
diff changeset
   186
    "Skip over proofs",
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   187
  proof_pref,
51971
716bb7e2e272 simplified preferences, removed obsolete operations;
wenzelm
parents: 51970
diff changeset
   188
  int_pref Multithreading.max_threads
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   189
    "max-threads"
29435
a5f84ac14609 added parallel_proofs flag (default true, cf. usedir option -Q), which can be disabled in low-memory situations;
wenzelm
parents: 28591
diff changeset
   190
    "Maximum number of threads",
32061
11f8ee55662d parallel_proofs: more fine-grained control with optional parallel checking of nested Isar proofs;
wenzelm
parents: 30985
diff changeset
   191
  parallel_proof_pref];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   192
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   193
val pure_preferences =
30980
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
   194
 [(category_display, display_preferences),
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
   195
  (category_advanced_display, advanced_display_preferences),
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
   196
  (category_tracing, tracing_preferences),
fe0855471964 misc cleanup of auto_solve and quickcheck:
wenzelm
parents: 29858
diff changeset
   197
  (category_proof, proof_preferences)];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   198
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   199
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   200
(* table of categories and preferences; names must be unique *)
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   201
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   202
type T = (string * preference list) list;
22214
6e9ab159512f Add operations on preference tables (remove, set_default).
aspinall
parents: 22130
diff changeset
   203
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   204
fun add cname (pref: preference) (tab: T) = tab |> map
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   205
  (fn (cat, prefs) =>
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   206
    if cat <> cname then (cat, prefs)
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   207
    else
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   208
      if exists (fn {name, ...} => name = #name pref) prefs
28591
790d1863be28 adding preferences is now permissive;
wenzelm
parents: 28587
diff changeset
   209
      then (warning ("Preference already exists: " ^ quote (#name pref)); (cat, prefs))
30985
2a22c6613dcf append prefs at end;
wenzelm
parents: 30980
diff changeset
   210
      else (cat, prefs @ [pref]));
28066
611e504c1191 extended interface to preferences to allow adding new ones
nipkow
parents: 25440
diff changeset
   211
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   212
end;