src/Pure/term_xml.ML
author wenzelm
Fri, 19 Jul 2024 11:29:05 +0200
changeset 80589 7849b6370425
parent 80566 446b887e23c7
permissions -rw-r--r--
clarified signature, following zterm.ML;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/term_xml.ML
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     2
    Author:     Makarius
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     3
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     4
XML data representation of lambda terms.
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     5
*)
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     6
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     7
signature TERM_XML_OPS =
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     8
sig
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
     9
  type 'a T
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    10
  type 'a P
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    11
  val indexname: indexname P
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    12
  val sort: sort T
70842
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    13
  val typ: typ T
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    14
  val term_raw: term T
70784
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
    15
  val term: Consts.T -> term T
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    16
end
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    17
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    18
signature TERM_XML =
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    19
sig
43779
47bec02c6762 more uniform Term and Term_XML modules;
wenzelm
parents: 43778
diff changeset
    20
  structure Encode: TERM_XML_OPS
47bec02c6762 more uniform Term and Term_XML modules;
wenzelm
parents: 43778
diff changeset
    21
  structure Decode: TERM_XML_OPS
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    22
end;
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    23
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    24
structure Term_XML: TERM_XML =
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    25
struct
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    26
43731
70072780e095 inner syntax supports inlined YXML according to Term_XML (particularly useful for producing text under program control);
wenzelm
parents: 43730
diff changeset
    27
structure Encode =
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    28
struct
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    29
43767
e0219ef7f84c tuned XML modules;
wenzelm
parents: 43731
diff changeset
    30
open XML.Encode;
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    31
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    32
fun indexname (a, b) = if b = 0 then [a] else [a, int_atom b];
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    33
43730
a0ed7bc688b5 lambda terms with XML data representation in Scala;
wenzelm
parents: 43729
diff changeset
    34
val sort = list string;
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    35
70842
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    36
fun typ T = T |> variant
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    37
 [fn Type (a, b) => ([a], list typ b),
43778
ce9189450447 more compact representation of XML data (notably sort/typ/term), using properties as vector of atomic values;
wenzelm
parents: 43767
diff changeset
    38
  fn TFree (a, b) => ([a], sort b),
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    39
  fn TVar (a, b) => (indexname a, sort b)];
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    40
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    41
fun term_raw t = t |> variant
70842
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    42
 [fn Const (a, b) => ([a], typ b),
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    43
  fn Free (a, b) => ([a], typ b),
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    44
  fn Var (a, b) => (indexname a, typ b),
70844
f95a85446a24 more compact XML;
wenzelm
parents: 70842
diff changeset
    45
  fn Bound a => ([], int a),
70842
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    46
  fn Abs (a, b, c) => ([a], pair typ term_raw (b, c)),
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    47
  fn op $ a => ([], pair term_raw term_raw a)];
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    48
80589
7849b6370425 clarified signature, following zterm.ML;
wenzelm
parents: 80566
diff changeset
    49
fun var_type T = if T = dummyT then [] else typ T;
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    50
70784
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
    51
fun term consts t = t |> variant
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
    52
 [fn Const (a, b) => ([a], list typ (Consts.typargs consts (a, b))),
80589
7849b6370425 clarified signature, following zterm.ML;
wenzelm
parents: 80566
diff changeset
    53
  fn Free (a, b) => ([a], var_type b),
7849b6370425 clarified signature, following zterm.ML;
wenzelm
parents: 80566
diff changeset
    54
  fn Var (a, b) => (indexname a, var_type b),
70844
f95a85446a24 more compact XML;
wenzelm
parents: 70842
diff changeset
    55
  fn Bound a => ([], int a),
70784
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
    56
  fn Abs (a, b, c) => ([a], pair typ (term consts) (b, c)),
80566
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    57
  fn t as op $ a =>
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    58
    if can Logic.match_of_class t then raise Match
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    59
    else ([], pair (term consts) (term consts) a),
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    60
  fn t =>
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    61
    let val (T, c) = Logic.match_of_class t
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    62
    in ([c], typ T) end];
70784
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
    63
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    64
end;
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    65
43731
70072780e095 inner syntax supports inlined YXML according to Term_XML (particularly useful for producing text under program control);
wenzelm
parents: 43730
diff changeset
    66
structure Decode =
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    67
struct
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    68
43767
e0219ef7f84c tuned XML modules;
wenzelm
parents: 43731
diff changeset
    69
open XML.Decode;
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    70
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    71
fun indexname [a] = (a, 0)
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    72
  | indexname [a, b] = (a, int_atom b);
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    73
43730
a0ed7bc688b5 lambda terms with XML data representation in Scala;
wenzelm
parents: 43729
diff changeset
    74
val sort = list string;
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    75
70842
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    76
fun typ body = body |> variant
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    77
 [fn ([a], b) => Type (a, list typ b),
43778
ce9189450447 more compact representation of XML data (notably sort/typ/term), using properties as vector of atomic values;
wenzelm
parents: 43767
diff changeset
    78
  fn ([a], b) => TFree (a, sort b),
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    79
  fn (a, b) => TVar (indexname a, sort b)];
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
    80
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    81
fun term_raw body = body |> variant
70842
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    82
 [fn ([a], b) => Const (a, typ b),
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    83
  fn ([a], b) => Free (a, typ b),
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    84
  fn (a, b) => Var (indexname a, typ b),
70844
f95a85446a24 more compact XML;
wenzelm
parents: 70842
diff changeset
    85
  fn ([], a) => Bound (int a),
70842
c5caf81aa523 more compact XML;
wenzelm
parents: 70828
diff changeset
    86
  fn ([a], b) => let val (c, d) = pair typ term_raw b in Abs (a, c, d) end,
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    87
  fn ([], a) => op $ (pair term_raw term_raw a)];
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    88
80589
7849b6370425 clarified signature, following zterm.ML;
wenzelm
parents: 80566
diff changeset
    89
fun var_type [] = dummyT
7849b6370425 clarified signature, following zterm.ML;
wenzelm
parents: 80566
diff changeset
    90
  | var_type body = typ body;
70828
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    91
cb70d84a9f5e more compact XML representation;
wenzelm
parents: 70784
diff changeset
    92
fun term consts body = body |> variant
70784
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
    93
 [fn ([a], b) => Const (a, Consts.instance consts (a, list typ b)),
80589
7849b6370425 clarified signature, following zterm.ML;
wenzelm
parents: 80566
diff changeset
    94
  fn ([a], b) => Free (a, var_type b),
7849b6370425 clarified signature, following zterm.ML;
wenzelm
parents: 80566
diff changeset
    95
  fn (a, b) => Var (indexname a, var_type b),
70844
f95a85446a24 more compact XML;
wenzelm
parents: 70842
diff changeset
    96
  fn ([], a) => Bound (int a),
70784
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
    97
  fn ([a], b) => let val (c, d) = pair typ (term consts) b in Abs (a, c, d) end,
80566
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    98
  fn ([], a) => op $ (pair (term consts) (term consts) a),
446b887e23c7 clarified data representation: prefer explicit OFCLASS constructor, following datatype zterm;
wenzelm
parents: 70844
diff changeset
    99
  fn ([a], b) => Logic.mk_of_class (typ b, a)];
70784
799437173553 Term_XML.Encode/Decode.term uses Const "typargs";
wenzelm
parents: 43789
diff changeset
   100
43729
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
   101
end;
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
   102
07d3c6afa865 XML data representation of lambda terms;
wenzelm
parents:
diff changeset
   103
end;