src/Pure/General/properties.ML
author wenzelm
Mon, 11 Sep 2023 19:30:48 +0200
changeset 78659 b5f3d1051b13
parent 77777 13cee8c2ed8d
child 80504 7ea69c26524b
permissions -rw-r--r--
tuned;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/General/properties.ML
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     3
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     4
Property lists.
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     5
*)
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     6
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     7
signature PROPERTIES =
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
     8
sig
50842
777c6026ca93 tuned signature;
wenzelm
parents: 46830
diff changeset
     9
  type entry = string * string
777c6026ca93 tuned signature;
wenzelm
parents: 46830
diff changeset
    10
  type T = entry list
71465
910a081cca74 more position information for oracles (e.g. "skip_proof" for 'sorry'), requires Proofterm.proofs := 1;
wenzelm
parents: 51665
diff changeset
    11
  val entry_ord: entry ord
910a081cca74 more position information for oracles (e.g. "skip_proof" for 'sorry'), requires Proofterm.proofs := 1;
wenzelm
parents: 51665
diff changeset
    12
  val ord: T ord
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    13
  val defined: T -> string -> bool
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    14
  val get: T -> string -> string option
50842
777c6026ca93 tuned signature;
wenzelm
parents: 46830
diff changeset
    15
  val put: entry -> T -> T
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    16
  val remove: string -> T -> T
77777
13cee8c2ed8d clarified signature;
wenzelm
parents: 77772
diff changeset
    17
  val make_string: string -> string -> T
13cee8c2ed8d clarified signature;
wenzelm
parents: 77772
diff changeset
    18
  val make_int: string -> int -> T
77772
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    19
  val get_string: T -> string -> string
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    20
  val get_int: T -> string -> int
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    21
  val get_seconds: T -> string -> Time.time
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    22
end;
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    23
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    24
structure Properties: PROPERTIES =
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    25
struct
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    26
50842
777c6026ca93 tuned signature;
wenzelm
parents: 46830
diff changeset
    27
type entry = string * string;
777c6026ca93 tuned signature;
wenzelm
parents: 46830
diff changeset
    28
type T = entry list;
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    29
71465
910a081cca74 more position information for oracles (e.g. "skip_proof" for 'sorry'), requires Proofterm.proofs := 1;
wenzelm
parents: 51665
diff changeset
    30
val entry_ord = prod_ord string_ord string_ord;
910a081cca74 more position information for oracles (e.g. "skip_proof" for 'sorry'), requires Proofterm.proofs := 1;
wenzelm
parents: 51665
diff changeset
    31
val ord = list_ord entry_ord;
910a081cca74 more position information for oracles (e.g. "skip_proof" for 'sorry'), requires Proofterm.proofs := 1;
wenzelm
parents: 51665
diff changeset
    32
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    33
fun defined (props: T) name = AList.defined (op =) props name;
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    34
fun get (props: T) name = AList.lookup (op =) props name;
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 29606
diff changeset
    35
fun put entry (props: T) = AList.update (op =) entry props;
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    36
fun remove name (props: T) = AList.delete (op =) name props;
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    37
77777
13cee8c2ed8d clarified signature;
wenzelm
parents: 77772
diff changeset
    38
fun make_string k s = if s = "" then [] else [(k, s)];
13cee8c2ed8d clarified signature;
wenzelm
parents: 77772
diff changeset
    39
fun make_int k i = if i = 0 then [] else [(k, Value.print_int i)];
13cee8c2ed8d clarified signature;
wenzelm
parents: 77772
diff changeset
    40
77772
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    41
val get_string = the_default "" oo get;
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    42
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    43
fun get_int props name =
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    44
  (case get props name of
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    45
    NONE => 0
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    46
  | SOME s => Value.parse_int s);
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    47
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    48
fun get_seconds props name =
7e0d920b4e6e tuned signature;
wenzelm
parents: 71465
diff changeset
    49
  (case get props name of
51665
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    50
    NONE => Time.zeroTime
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    51
  | SOME s => Time.fromReal (the_default 0.0 (Real.fromString s)));
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    52
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    53
end;