src/Pure/ProofGeneral/preferences.ML
author wenzelm
Sat, 10 Jan 2009 21:32:30 +0100
changeset 29435 a5f84ac14609
parent 28591 790d1863be28
child 29858 c8cee17d7e50
permissions -rw-r--r--
added parallel_proofs flag (default true, cf. usedir option -Q), which can be disabled in low-memory situations;
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
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
     9
  type preference =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    10
   {name: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    11
    descr: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    12
    default: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    13
    pgiptype: PgipTypes.pgiptype,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    14
    get: unit -> string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    15
    set: string -> unit}
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    16
  val generic_pref: ('a -> string) -> (string -> 'a) -> PgipTypes.pgiptype ->
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    17
    'a ref -> string -> string -> preference
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    18
  val string_pref: string ref -> string -> string -> preference
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    19
  val int_pref: int ref -> string -> string -> preference
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    20
  val nat_pref: int ref -> string -> string -> preference
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    21
  val bool_pref: bool ref -> string -> string -> preference
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    22
  type T = (string * preference list) list
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    23
  val pure_preferences: T
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    24
  val remove: string -> T -> T
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    25
  val add: string -> preference -> T -> T
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    26
  val set_default: string * string -> T -> T
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    27
end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    28
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    29
structure Preferences: PREFERENCES =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    30
struct
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    31
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    32
(* preferences and preference tables *)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    33
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    34
type preference =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    35
 {name: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    36
  descr: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    37
  default: string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    38
  pgiptype: PgipTypes.pgiptype,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    39
  get: unit -> string,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    40
  set: string -> unit};
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    41
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    42
fun mkpref raw_get raw_set typ name descr : preference =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    43
  let
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    44
    fun get () = CRITICAL raw_get;
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    45
    fun set x = CRITICAL (fn () => raw_set x);
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    46
  in {name = name, descr = descr, pgiptype = typ, get = get, set = set, default = get ()} end;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    47
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    48
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    49
(* generic preferences *)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    50
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    51
fun generic_pref read write typ r =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    52
  mkpref (fn () => read (! r)) (fn x => r := write x) typ;
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    53
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    54
val string_pref = generic_pref I I PgipTypes.Pgipstring;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    55
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
    56
val int_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    57
  generic_pref PgipTypes.int_to_pgstring (PgipTypes.read_pgipint (NONE, NONE))
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    58
    (PgipTypes.Pgipint (NONE, NONE));
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    59
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    60
val nat_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    61
  generic_pref PgipTypes.int_to_pgstring PgipTypes.read_pgipnat PgipTypes.Pgipnat;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    62
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    63
val bool_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    64
  generic_pref PgipTypes.bool_to_pgstring PgipTypes.read_pgipbool PgipTypes.Pgipbool;
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    65
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    66
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    67
(* preferences of Pure *)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    68
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    69
val proof_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    70
  let
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    71
    fun get () = PgipTypes.bool_to_pgstring (! Proofterm.proofs >= 2);
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    72
    fun set s = Proofterm.proofs := (if PgipTypes.read_pgipbool s then 2 else 1);
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    73
  in mkpref get set PgipTypes.Pgipbool "full-proofs" "Record full proof objects internally" end;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    74
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    75
val thm_depsN = "thm_deps";
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
    76
val thm_deps_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    77
  let
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    78
    fun get () = PgipTypes.bool_to_pgstring (print_mode_active thm_depsN);
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    79
    fun set s =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    80
      if PgipTypes.read_pgipbool s then change print_mode (insert (op =) thm_depsN)
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    81
      else change print_mode (remove (op =) thm_depsN);
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    82
  in
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    83
    mkpref get set PgipTypes.Pgipbool "theorem-dependencies"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    84
      "Track theorem dependencies within Proof General"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    85
  end;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    86
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    87
val print_depth_pref =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    88
  let
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    89
    fun get () = PgipTypes.int_to_pgstring (get_print_depth ());
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    90
    val set = print_depth o PgipTypes.read_pgipnat;
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    91
  in mkpref get set PgipTypes.Pgipnat "print-depth" "Setting for the ML print depth" end;
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    92
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    93
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
    94
val display_preferences =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    95
 [bool_pref show_types
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    96
    "show-types"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    97
    "Include types in display of Isabelle terms",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    98
  bool_pref show_sorts
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
    99
    "show-sorts"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   100
    "Include sorts in display of Isabelle terms",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   101
  bool_pref show_consts
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   102
    "show-consts"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   103
    "Show types of consts in Isabelle goal display",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   104
  bool_pref long_names
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   105
    "long-names"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   106
    "Show fully qualified names in Isabelle terms",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   107
  bool_pref show_brackets
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   108
    "show-brackets"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   109
    "Show full bracketing in Isabelle terms",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   110
  bool_pref Proof.show_main_goal
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   111
    "show-main-goal"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   112
    "Show main goal in proof state display",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   113
  bool_pref Syntax.eta_contract
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   114
    "eta-contract"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   115
    "Print terms eta-contracted"];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   116
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   117
val advanced_display_preferences =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   118
 [nat_pref goals_limit
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   119
    "goals-limit"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   120
    "Setting for maximum number of goals printed",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   121
  int_pref ProofContext.prems_limit
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   122
    "prems-limit"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   123
    "Setting for maximum number of premises printed",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   124
  print_depth_pref,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   125
  bool_pref show_question_marks
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   126
    "show-question-marks"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   127
    "Show leading question mark of variable name"];
21637
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 tracing_preferences =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   130
 [bool_pref trace_simp
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   131
    "trace-simplifier"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   132
    "Trace simplification rules.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   133
  nat_pref trace_simp_depth_limit
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   134
    "trace-simplifier-depth"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   135
    "Trace simplifier depth limit.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   136
  bool_pref trace_rules
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   137
    "trace-rules"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   138
    "Trace application of the standard rules",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   139
  bool_pref Pattern.trace_unify_fail
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   140
    "trace-unification"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   141
    "Output error diagnostics during unification",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   142
  bool_pref Output.timing
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   143
    "global-timing"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   144
    "Whether to enable timing in Isabelle.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   145
  bool_pref Toplevel.debug
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   146
    "debugging"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   147
    "Whether to enable debugging.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   148
  bool_pref Quickcheck.auto
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   149
    "auto-quickcheck"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   150
    "Whether to enable quickcheck automatically.",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   151
  nat_pref Quickcheck.auto_time_limit
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   152
    "auto-quickcheck-time-limit"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   153
    "Time limit for automatic quickcheck (in milliseconds).",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   154
  thm_deps_pref];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   155
24329
f31594168d27 ML system provides get_print_depth;
wenzelm
parents: 24191
diff changeset
   156
val proof_preferences =
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   157
 [bool_pref quick_and_dirty
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   158
    "quick-and-dirty"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   159
    "Take a few short cuts",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   160
  bool_pref Toplevel.skip_proofs
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   161
    "skip-proofs"
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   162
    "Skip over proofs (interactive-only)",
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   163
  proof_pref,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   164
  nat_pref Multithreading.max_threads
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   165
    "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
   166
    "Maximum number of threads",
a5f84ac14609 added parallel_proofs flag (default true, cf. usedir option -Q), which can be disabled in low-memory situations;
wenzelm
parents: 28591
diff changeset
   167
  bool_pref Goal.parallel_proofs
a5f84ac14609 added parallel_proofs flag (default true, cf. usedir option -Q), which can be disabled in low-memory situations;
wenzelm
parents: 28591
diff changeset
   168
    "parallel-proofs"
a5f84ac14609 added parallel_proofs flag (default true, cf. usedir option -Q), which can be disabled in low-memory situations;
wenzelm
parents: 28591
diff changeset
   169
    "Check proofs in parallel"];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   170
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   171
val pure_preferences =
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   172
 [("Display", display_preferences),
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   173
  ("Advanced Display", advanced_display_preferences),
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   174
  ("Tracing", tracing_preferences),
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   175
  ("Proof", proof_preferences)];
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   176
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   177
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   178
(* table of categories and preferences; names must be unique *)
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   179
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   180
type T = (string * preference list) list;
22214
6e9ab159512f Add operations on preference tables (remove, set_default).
aspinall
parents: 22130
diff changeset
   181
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   182
fun remove name (tab: T) = tab |> map
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   183
  (fn (cat, prefs) => (cat, filter_out (curry op = name o #name) prefs));
22214
6e9ab159512f Add operations on preference tables (remove, set_default).
aspinall
parents: 22130
diff changeset
   184
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   185
fun set_default (setname, newdefault) (tab: T) = tab |> map
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   186
  (fn (cat, prefs) =>
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   187
    (cat, prefs |> map (fn (pref as {name, descr, default, pgiptype, get, set}) =>
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   188
      if name = setname then
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   189
        (set newdefault;
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   190
          {name =name , descr = descr, default = newdefault,
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   191
           pgiptype = pgiptype, get = get, set = set})
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   192
      else pref)));
22214
6e9ab159512f Add operations on preference tables (remove, set_default).
aspinall
parents: 22130
diff changeset
   193
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   194
fun add cname (pref: preference) (tab: T) = tab |> map
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   195
  (fn (cat, prefs) =>
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   196
    if cat <> cname then (cat, prefs)
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   197
    else
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   198
      if exists (fn {name, ...} => name = #name pref) prefs
28591
790d1863be28 adding preferences is now permissive;
wenzelm
parents: 28587
diff changeset
   199
      then (warning ("Preference already exists: " ^ quote (#name pref)); (cat, prefs))
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   200
      else (cat, pref :: prefs));
28066
611e504c1191 extended interface to preferences to allow adding new ones
nipkow
parents: 25440
diff changeset
   201
28587
52ec4c827ed4 export generic_pref etc.;
wenzelm
parents: 28315
diff changeset
   202
end;