src/Pure/General/properties.ML
author wenzelm
Tue, 21 Jun 2022 14:51:17 +0200
changeset 75571 ac5e633ad9b3
parent 71465 910a081cca74
child 77772 7e0d920b4e6e
permissions -rw-r--r--
tuned signature: more operations;
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
51665
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    17
  val seconds: T -> string -> Time.time
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    18
end;
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    19
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    20
structure Properties: PROPERTIES =
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    21
struct
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    22
50842
777c6026ca93 tuned signature;
wenzelm
parents: 46830
diff changeset
    23
type entry = string * string;
777c6026ca93 tuned signature;
wenzelm
parents: 46830
diff changeset
    24
type T = entry list;
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    25
71465
910a081cca74 more position information for oracles (e.g. "skip_proof" for 'sorry'), requires Proofterm.proofs := 1;
wenzelm
parents: 51665
diff changeset
    26
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
    27
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
    28
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    29
fun defined (props: T) name = AList.defined (op =) props name;
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    30
fun get (props: T) name = AList.lookup (op =) props name;
43780
2cb2310d68b6 more uniform Properties in ML and Scala;
wenzelm
parents: 29606
diff changeset
    31
fun put entry (props: T) = AList.update (op =) entry props;
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    32
fun remove name (props: T) = AList.delete (op =) name props;
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    33
51665
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    34
fun seconds props name =
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    35
  (case AList.lookup (op =) props name of
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    36
    NONE => Time.zeroTime
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    37
  | SOME s => Time.fromReal (the_default 0.0 (Real.fromString s)));
cba83c9f72b9 tuned signature;
wenzelm
parents: 50842
diff changeset
    38
28019
359764333bf4 Property lists.
wenzelm
parents:
diff changeset
    39
end;