src/Pure/ProofGeneral/pgip_output.ML
author wenzelm
Mon, 19 Mar 2012 18:18:42 +0100
changeset 47014 e203b7d7e08d
parent 41491 a2ad5b824051
child 51967 43fbd02eb9d0
permissions -rw-r--r--
allow keyword tags to be redefined, but not the command category;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     1
(*  Title:      Pure/ProofGeneral/pgip_output.ML
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     2
    Author:     David Aspinall
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     3
21940
fbd068dd4d29 minor tuning;
wenzelm
parents: 21929
diff changeset
     4
PGIP abstraction: output commands.
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     5
*)
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     6
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     7
signature PGIPOUTPUT =
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     8
sig
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
     9
    (* These are the PGIP messages which the prover emits. *) 
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    10
    datatype pgipoutput = 
26548
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
    11
      Normalresponse      of { content: XML.tree list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    12
    | Errorresponse       of { fatality: PgipTypes.fatality, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    13
                               location: PgipTypes.location option, 
26548
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
    14
                               content: XML.tree list }
22040
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
    15
    | Informfileloaded    of { url: PgipTypes.pgipurl, completed: bool }
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
    16
    | Informfileoutdated  of { url: PgipTypes.pgipurl, completed: bool }
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
    17
    | Informfileretracted of { url: PgipTypes.pgipurl, completed: bool }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    18
    | Metainforesponse    of { attrs: XML.attributes, 
26548
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
    19
                               content: XML.tree list }
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
    20
    | Lexicalstructure    of { content: XML.tree list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    21
    | Proverinfo          of { name: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    22
                               version: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    23
                               instance: string,
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    24
                               descr: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    25
                               url: Url.T, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    26
                               filenameextns: string }
21867
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    27
    | Setids              of { idtables: PgipTypes.idtable list  }
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    28
    | Delids              of { idtables: PgipTypes.idtable list }
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    29
    | Addids              of { idtables: PgipTypes.idtable list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    30
    | Hasprefs            of { prefcategory: string option, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    31
                               prefs: PgipTypes.preference list }
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    32
    | Prefval             of { name: string, value: string }
22161
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
    33
    | Setrefs             of { url: PgipTypes.pgipurl option,
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    34
                               thyname: PgipTypes.objname option,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    35
                               objtype: PgipTypes.objtype option,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    36
                               name: PgipTypes.objname option,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    37
                               idtables: PgipTypes.idtable list,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    38
                               fileurls : PgipTypes.pgipurl list }
22336
050ceb649207 <idvalue>: add name attribute to allow unsolicited updates.
aspinall
parents: 22161
diff changeset
    39
    | Idvalue             of { thyname: PgipTypes.objname option,
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    40
                               objtype: PgipTypes.objtype, 
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    41
                               name: PgipTypes.objname, 
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    42
                               text: XML.tree list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    43
    | Informguise         of { file : PgipTypes.pgipurl option,  
21867
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    44
                               theory: PgipTypes.objname option, 
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    45
                               theorem: PgipTypes.objname option, 
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    46
                               proofpos: int option }
21867
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    47
    | Parseresult         of { attrs: XML.attributes, doc:PgipMarkup.pgipdocument, 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    48
                               errs: XML.tree list } (* errs to become PGML *)
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    49
    | Usespgip            of { version: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    50
                               pgipelems: (string * bool * string list) list }
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    51
    | Usespgml            of { version: string }
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    52
    | Pgip                of { tag: string option, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    53
                               class: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    54
                               seq: int, id: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    55
                               destid: string option,
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    56
                               refid: string option,
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    57
                               refseq: int option,
26548
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
    58
                               content: XML.tree list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    59
    | Ready               of { }
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    60
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    61
    val output : pgipoutput -> XML.tree                                  
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    62
end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    63
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    64
structure PgipOutput : PGIPOUTPUT =
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    65
struct
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    66
open PgipTypes
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    67
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
    68
datatype pgipoutput = 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    69
         Normalresponse      of { content: XML.tree list }
23749
ac6d3a8d22b5 Track schema changes: remove cleardisplay, proofstate messages. Simplify attributes on cleardisplay, normalresponse.
aspinall
parents: 23610
diff changeset
    70
       | Errorresponse       of { fatality: fatality, 
ac6d3a8d22b5 Track schema changes: remove cleardisplay, proofstate messages. Simplify attributes on cleardisplay, normalresponse.
aspinall
parents: 23610
diff changeset
    71
                                  location: location option, 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    72
                                  content: XML.tree list }
22040
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
    73
       | Informfileloaded    of { url: Path.T, completed: bool }
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
    74
       | Informfileoutdated  of { url: Path.T, completed: bool }
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
    75
       | Informfileretracted of { url: Path.T, completed: bool }
26548
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
    76
       | Metainforesponse    of { attrs: XML.attributes, content: XML.tree list }
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
    77
       | Lexicalstructure    of { content: XML.tree list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    78
       | Proverinfo          of { name: string, version: string, instance: string,
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    79
                                  descr: string, url: Url.T, filenameextns: string }
21867
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    80
       | Setids              of { idtables: PgipTypes.idtable list  }
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    81
       | Delids              of { idtables: PgipTypes.idtable list }
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    82
       | Addids              of { idtables: PgipTypes.idtable list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    83
       | Hasprefs            of { prefcategory: string option, prefs: preference list }
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
    84
       | Prefval             of { name: string, value: string }
22336
050ceb649207 <idvalue>: add name attribute to allow unsolicited updates.
aspinall
parents: 22161
diff changeset
    85
       | Idvalue             of { thyname: PgipTypes.objname option,
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    86
                                  objtype: PgipTypes.objtype, 
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    87
                                  name: PgipTypes.objname, 
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    88
                                  text: XML.tree list }
22161
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
    89
       | Setrefs             of { url: PgipTypes.pgipurl option,
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    90
                                  thyname: PgipTypes.objname option,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    91
                                  objtype: PgipTypes.objtype option,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    92
                                  name: PgipTypes.objname option,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    93
                                  idtables: PgipTypes.idtable list,
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    94
                                  fileurls : PgipTypes.pgipurl list }
21867
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    95
       | Informguise         of { file : PgipTypes.pgipurl option,  
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    96
                                  theory: PgipTypes.objname option, 
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    97
                                  theorem: PgipTypes.objname option, 
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
    98
                                  proofpos: int option }
21867
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
    99
       | Parseresult         of { attrs: XML.attributes, doc: PgipMarkup.pgipdocument,
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   100
                                  errs: XML.tree list } (* errs to become PGML *)
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   101
       | Usespgip            of { version: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   102
                                  pgipelems: (string * bool * string list) list }
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   103
       | Usespgml            of { version: string }
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   104
       | Pgip                of { tag: string option, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   105
                                  class: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   106
                                  seq: int, id: string, 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   107
                                  destid: string option,
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   108
                                  refid: string option,
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   109
                                  refseq: int option,
26548
41bbcaf3e481 further cleanup of XML signature;
wenzelm
parents: 23834
diff changeset
   110
                                  content: XML.tree list }
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   111
       | Ready               of { }
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   112
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   113
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   114
(* Construct output XML messages *)
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   115
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   116
fun normalresponse (Normalresponse vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   117
    let 
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   118
        val content = #content vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   119
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   120
        XML.Elem (("normalresponse", []), content)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   121
    end
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   122
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   123
fun errorresponse (Errorresponse vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   124
    let 
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   125
        val fatality = #fatality vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   126
        val location = #location vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   127
        val content = #content vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   128
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   129
        XML.Elem (("errorresponse",
21940
fbd068dd4d29 minor tuning;
wenzelm
parents: 21929
diff changeset
   130
                 attrs_of_fatality fatality @
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   131
                 these (Option.map attrs_of_location location)),
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   132
                 content)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   133
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   134
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   135
fun informfileloaded (Informfileloaded vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   136
    let 
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   137
        val url = #url vs
22040
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   138
        val completed = #completed vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   139
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   140
        XML.Elem (("informfileloaded", 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   141
                  attrs_of_pgipurl url @ 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   142
                  (attr "completed" (PgipTypes.bool_to_pgstring completed))),
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   143
                  [])
22040
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   144
    end
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   145
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   146
fun informfileoutdated (Informfileoutdated vs) =
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   147
    let 
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   148
        val url = #url vs
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   149
        val completed = #completed vs
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   150
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   151
        XML.Elem (("informfileoutdated", 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   152
                  attrs_of_pgipurl url @ 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   153
                  (attr "completed" (PgipTypes.bool_to_pgstring completed))),
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   154
                  [])
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   155
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   156
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   157
fun informfileretracted (Informfileretracted vs) =
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   158
    let 
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   159
        val url = #url vs
22040
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   160
        val completed = #completed vs
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   161
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   162
        XML.Elem (("informfileretracted", 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   163
                  attrs_of_pgipurl url @ 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   164
                  (attr "completed" (PgipTypes.bool_to_pgstring completed))),
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   165
                  [])
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   166
    end
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   167
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   168
fun metainforesponse (Metainforesponse vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   169
    let 
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   170
        val attrs = #attrs vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   171
        val content = #content vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   172
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   173
        XML.Elem (("metainforesponse", attrs), content)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   174
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   175
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   176
fun lexicalstructure (Lexicalstructure vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   177
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   178
        val content = #content vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   179
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   180
        XML.Elem (("lexicalstructure", []), content)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   181
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   182
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   183
fun proverinfo (Proverinfo vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   184
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   185
        val name = #name vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   186
        val version = #version vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   187
        val instance = #instance vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   188
        val descr = #descr vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   189
        val url = #url vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   190
        val filenameextns = #filenameextns vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   191
    in 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   192
        XML.Elem (("proverinfo",
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   193
                 [("name", name),
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   194
                  ("version", version),
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   195
                  ("instance", instance), 
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   196
                  ("descr", descr),
21858
05f57309170c avoid conflict with Alice keywords: renamed pack -> implode, unpack -> explode, any -> many, avoided assert;
wenzelm
parents: 21655
diff changeset
   197
                  ("url", Url.implode url),
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   198
                  ("filenameextns", filenameextns)]),
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   199
                 [])
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   200
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   201
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   202
fun setids (Setids vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   203
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   204
        val idtables = #idtables vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   205
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   206
        XML.Elem (("setids", []), map idtable_to_xml idtables)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   207
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   208
22161
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   209
fun setrefs (Setrefs vs) =
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   210
    let
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   211
        val url = #url vs
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   212
        val thyname = #thyname vs
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   213
        val objtype = #objtype vs
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   214
        val name = #name vs
22161
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   215
        val idtables = #idtables vs
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   216
        val fileurls = #fileurls vs
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   217
        fun fileurl_to_xml url = XML.Elem (("fileurl", attrs_of_pgipurl url), [])
22161
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   218
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   219
        XML.Elem (("setrefs",
33035
15eab423e573 standardized basic operations on type option;
wenzelm
parents: 29606
diff changeset
   220
                  (the_default [] (Option.map attrs_of_pgipurl url)) @ 
15eab423e573 standardized basic operations on type option;
wenzelm
parents: 29606
diff changeset
   221
                  (the_default [] (Option.map attrs_of_objtype objtype)) @
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   222
                  (opt_attr "thyname" thyname) @
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   223
                  (opt_attr "name" name)),
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   224
                  (map idtable_to_xml idtables) @ 
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   225
                  (map fileurl_to_xml fileurls))
22161
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   226
    end
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   227
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   228
fun addids (Addids vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   229
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   230
        val idtables = #idtables vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   231
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   232
        XML.Elem (("addids", []), map idtable_to_xml idtables)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   233
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   234
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   235
fun delids (Delids vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   236
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   237
        val idtables = #idtables vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   238
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   239
        XML.Elem (("delids", []), map idtable_to_xml idtables)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   240
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   241
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   242
fun hasprefs (Hasprefs vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   243
  let 
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   244
      val prefcategory = #prefcategory vs
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   245
      val prefs = #prefs vs
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   246
  in 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   247
      XML.Elem (("hasprefs", opt_attr "prefcategory" prefcategory), map haspref prefs)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   248
  end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   249
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   250
fun prefval (Prefval vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   251
    let 
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   252
        val name = #name vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   253
        val value = #value vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   254
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   255
        XML.Elem (("prefval", attr "name" name), [XML.Text value])
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   256
    end 
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   257
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   258
fun idvalue (Idvalue vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   259
    let 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   260
        val objtype_attrs = attrs_of_objtype (#objtype vs)
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   261
        val thyname = #thyname vs
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   262
        val name = #name vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   263
        val text = #text vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   264
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   265
        XML.Elem (("idvalue", 
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   266
                 objtype_attrs @
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   267
                 (opt_attr "thyname" thyname) @
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   268
                 attr "name" name),
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   269
                 text)
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   270
    end
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   271
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   272
fun informguise (Informguise vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   273
  let
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   274
      val file = #file vs
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   275
      val theory = #theory vs
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   276
      val theorem = #theorem vs
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   277
      val proofpos = #proofpos vs
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   278
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   279
      fun elto nm attrfn xo = case xo of NONE => [] | SOME x => [XML.Elem ((nm, attrfn x), [])]
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   280
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   281
      val guisefile = elto "guisefile" attrs_of_pgipurl file
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   282
      val guisetheory = elto "guisetheory" (single o (pair "thyname")) theory
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   283
      val guiseproof = elto "guiseproof" 
21651
99f4a06184dc Fix typo. Some cleanup for XML attributes
aspinall
parents: 21649
diff changeset
   284
                            (fn thm=>(attr "thmname" thm) @
41491
a2ad5b824051 eliminated Int.toString;
wenzelm
parents: 38228
diff changeset
   285
                                     (opt_attr "proofpos" (Option.map string_of_int proofpos))) theorem
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   286
  in 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   287
      XML.Elem (("informguise", []), guisefile @ guisetheory @ guiseproof)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   288
  end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   289
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   290
fun parseresult (Parseresult vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   291
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   292
        val attrs = #attrs vs
21867
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
   293
        val doc = #doc vs
8750fbc28d5c Add abstraction for objtypes and documents.
aspinall
parents: 21858
diff changeset
   294
        val errs = #errs vs
28020
1ff5167592ba get rid of tabs;
wenzelm
parents: 26548
diff changeset
   295
        val xmldoc = PgipMarkup.output_doc doc
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   296
    in 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   297
        XML.Elem (("parseresult", attrs), errs @ xmldoc)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   298
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   299
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   300
fun acceptedpgipelems (Usespgip vs) = 
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   301
    let
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   302
        val pgipelems = #pgipelems vs
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   303
        fun async_attrs b = if b then attr "async" "true" else []
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   304
        fun attrs_attrs attrs = if attrs=[] then [] else attr "attributes" (space_implode "," attrs)
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   305
        fun singlepgipelem (e,async,attrs) = 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   306
            XML.Elem (("pgipelem", async_attrs async @ attrs_attrs attrs), [XML.Text e])
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   307
                                                      
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   308
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   309
        XML.Elem (("acceptedpgipelems", []), map singlepgipelem pgipelems)
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   310
    end
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   311
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   312
fun usespgip (Usespgip vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   313
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   314
        val version = #version vs
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   315
        val acceptedelems = acceptedpgipelems (Usespgip vs)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   316
    in 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   317
        XML.Elem (("usespgip", attr "version" version), [acceptedelems])
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   318
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   319
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   320
fun usespgml (Usespgml vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   321
    let
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   322
        val version = #version vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   323
    in 
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   324
        XML.Elem (("usespgml", attr "version" version), [])
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   325
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   326
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   327
fun pgip (Pgip vs) =
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   328
    let 
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   329
        val tag = #tag vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   330
        val class = #class vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   331
        val seq = #seq vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   332
        val id = #id vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   333
        val destid = #destid vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   334
        val refid = #refid vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   335
        val refseq = #refseq vs
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   336
        val content = #content vs
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   337
    in
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   338
        XML.Elem(("pgip",
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   339
                 opt_attr "tag" tag @
21651
99f4a06184dc Fix typo. Some cleanup for XML attributes
aspinall
parents: 21649
diff changeset
   340
                 attr "id" id @
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   341
                 opt_attr "destid" destid @
21651
99f4a06184dc Fix typo. Some cleanup for XML attributes
aspinall
parents: 21649
diff changeset
   342
                 attr "class" class @
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   343
                 opt_attr "refid" refid @
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   344
                 opt_attr_map string_of_int "refseq" refseq @
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   345
                 attr "seq" (string_of_int seq)),
21649
40e6fdd26f82 Support PGIP communication for preferences in Emacs mode.
aspinall
parents: 21637
diff changeset
   346
                 content)
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   347
    end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   348
38228
ada3ab6b9085 simplified type XML.tree: embed Markup.T directly, avoid slightly odd triple;
wenzelm
parents: 33035
diff changeset
   349
fun ready (Ready _) = XML.Elem (("ready", []), [])
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   350
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   351
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   352
fun output pgipoutput = case pgipoutput of
23749
ac6d3a8d22b5 Track schema changes: remove cleardisplay, proofstate messages. Simplify attributes on cleardisplay, normalresponse.
aspinall
parents: 23610
diff changeset
   353
    Normalresponse _        => normalresponse pgipoutput
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   354
  | Errorresponse _         => errorresponse pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   355
  | Informfileloaded _      => informfileloaded pgipoutput
22040
635aaa46b44d Add informfileoutdated and completed flag. This makes the PGIP messages match the Broker states.
aspinall
parents: 21940
diff changeset
   356
  | Informfileoutdated _    => informfileoutdated pgipoutput
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   357
  | Informfileretracted _   => informfileretracted pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   358
  | Metainforesponse _      => metainforesponse pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   359
  | Lexicalstructure _      => lexicalstructure pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   360
  | Proverinfo _            => proverinfo pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   361
  | Setids _                => setids pgipoutput
22161
b2117f4f2d39 Add askrefs, setrefs, error_with_pos
aspinall
parents: 22040
diff changeset
   362
  | Setrefs _               => setrefs pgipoutput
21902
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   363
  | Addids _                => addids pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   364
  | Delids _                => delids pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   365
  | Hasprefs _              => hasprefs pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   366
  | Prefval _               => prefval pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   367
  | Idvalue _               => idvalue pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   368
  | Informguise _           => informguise pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   369
  | Parseresult _           => parseresult pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   370
  | Usespgip _              => usespgip pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   371
  | Usespgml _              => usespgml pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   372
  | Pgip _                  => pgip pgipoutput
8e5e2571c716 made SML/NJ happy
haftmann
parents: 21867
diff changeset
   373
  | Ready _                 => ready pgipoutput
21637
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   374
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   375
end
a7b156c404e2 Revamped Proof General interface.
aspinall
parents:
diff changeset
   376