-
Notifications
You must be signed in to change notification settings - Fork 144
/
std.prelude
204 lines (175 loc) · 6.94 KB
/
std.prelude
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
val _ = quietdec := true;
(* ----------------------------------------------------------------------
Establish the basic environment and bring in the HOL kernel
---------------------------------------------------------------------- *)
load "PP";
structure MosmlPP = PP
(* ----------------------------------------------------------------------
Set interactive flag to true
---------------------------------------------------------------------- *)
val _ = load "Globals";
val _ = Globals.interactive := true;
val _ = app load
["Mosml", "Process", "Path", "boolLib", "proofManagerLib", "Arbrat"];
open HolKernel Parse boolLib proofManagerLib;
(* Loading HolKernel installs the "standard" set of infixes, which are
set up in src/0/Overlay.sml *)
(*---------------------------------------------------------------------------*
* Install prettyprinters *
*---------------------------------------------------------------------------*)
local
fun pp_from_stringfn sf pps x = PP.add_string (sf x)
fun gprint0 g t = let
val tyg = Parse.type_grammar()
val (_, ppt) = Parse.print_from_grammars (tyg,g)
in
ppt t
end
val gprint = (fn g => fn t => smpp.lift (gprint0 g) t)
fun ppg g = Parse.mlower (term_grammar.prettyprint_grammar gprint g)
fun ppgrules grs =
Parse.mlower (term_grammar.prettyprint_grammar_rules gprint grs)
fun timepp t = PP.add_string (Time.toString t ^ "s")
fun locpp l = PP.add_string (locn.toShortString l)
structure MPP = MosmlPP
open PrettyImpl
in
fun mosmlpp ppfn pps x = let
val slist = ref ([] : string list)
fun output_slist () = (app (MPP.add_string pps) (List.rev (!slist));
slist := [])
fun consume_string s = let
open Substring
val (pfx,sfx) = splitl (fn c => c <> #"\n") (full s)
in
if size sfx = 0 then slist := s :: !slist
else
(output_slist();
MPP.add_newline pps;
if size sfx > 1 then consume_string (string (triml 1 sfx))
else ())
end
in
MPP.begin_block pps MPP.INCONSISTENT 0;
HOLPP.prettyPrint(consume_string, !Globals.linewidth) (ppfn x);
MPP.end_block pps;
output_slist()
end
val _ = installPP (mosmlpp Pretype.pp_pretype)
val _ = installPP (mosmlpp (Parse.term_pp_with_delimiters Hol_pp.pp_term))
val _ = installPP (mosmlpp (Parse.type_pp_with_delimiters Hol_pp.pp_type))
val _ = installPP (mosmlpp Hol_pp.pp_thm)
val _ = installPP (mosmlpp Hol_pp.pp_theory)
val _ = installPP (mosmlpp type_grammar.prettyprint_grammar)
val _ = installPP (mosmlpp ppg)
val _ = installPP (mosmlpp ppgrules)
val _ = installPP (mosmlpp proofManagerLib.pp_proof)
val _ = installPP (mosmlpp proofManagerLib.pp_proofs)
val _ = installPP (mosmlpp Rewrite.pp_rewrites)
val _ = installPP (mosmlpp TypeBasePure.pp_tyinfo)
val _ = installPP (mosmlpp Arbnum.pp_num)
val _ = installPP (mosmlpp Arbint.pp_int)
val _ = installPP (mosmlpp Arbrat.pp_rat)
val _ = installPP (mosmlpp timepp)
val _ = installPP (mosmlpp locpp)
end;
(*---------------------------------------------------------------------------*
* Set up the help paths. *
*---------------------------------------------------------------------------*)
local
open Path
fun HELP s = toString(fromString(concat(HOLDIR, concat("help",s))))
val SIGOBJ = toString(fromString(concat(HOLDIR, "sigobj")))
in
val () = indexfiles := HELP "HOL.Help" :: !indexfiles
val () = helpdirs := HOLDIR :: SIGOBJ :: !helpdirs
val () = Help.specialfiles :=
{file = "help/Docfiles/HOL.help",
term = "hol", title = "HOL Overview"}
:: !Help.specialfiles
end
(*---------------------------------------------------------------------------*
* Set parameters for parsing and help. *
*---------------------------------------------------------------------------*)
val _ = quotation := true
val _ = Help.displayLines := 60;
(*---------------------------------------------------------------------------*
* Set up compile_theory function *
*---------------------------------------------------------------------------*)
fun compile_theory () = let
val name = current_theory()
val signame = name^"Theory.sig"
val smlname = name^"Theory.sml"
fun readable f = FileSys.access(f, [FileSys.A_READ])
in
if readable signame andalso readable smlname then let
in
Meta.compileStructure ["Overlay"] signame;
Meta.compileStructure ["Overlay"] smlname;
print ("Compiled "^name^" theory files.\n")
end
else
print "No theory files on disk; perhaps export_theory() required.\n"
end
(*---------------------------------------------------------------------------*
* Print a banner. *
*---------------------------------------------------------------------------*)
val build_stamp =
let open TextIO Path
val stampstr = openIn (concat(HOLDIR, concat("tools", "build-stamp")))
val stamp = inputAll stampstr before closeIn stampstr
in
stamp
end handle _ => "";
val exit_string =
if Systeml.OS = "winNT" then
"To exit type <Control>-Z <Return> (*not* quit();)"
else
"To exit type <Control>-D (*not* quit();)"
(* ----------------------------------------------------------------------
if present, look at a Holmakefile in the current directory to see
if we should extend the loadPath
---------------------------------------------------------------------- *)
structure HOL_Interactive : sig
val toggle_quietdec : unit -> bool
val amquiet : unit -> bool
val print_banner : unit -> unit
end =
struct
fun toggle_quietdec () = (Meta.quietdec := not (!Meta.quietdec) ;
!Meta.quietdec)
fun amquiet () = !Meta.quietdec
fun print_banner() =
TextIO.output(TextIO.stdOut,
"\n---------------------------------------------------------------------\n"
^" HOL4 ["
^Globals.release^" "^Lib.int_to_string(Globals.version)
^" ("^Thm.kernelid^", "^build_stamp
^")]\n\n"
^" For introductory HOL help, type: help \"hol\";\n"
^" "^exit_string
^"\n---------------------------------------------------------------------\
\\n\n")
end;
val _ = HOL_Interactive.print_banner()
local
open Path
in
val _ = loadPath := concat (HOLDIR, concat ("tools", "Holmake")) :: !loadPath
val _ = load "ReadHMF.uo"
val _ = loadPath := tl (!loadPath)
end;
val _ = let
val lpsize0 = length (!loadPath)
in
ReadHMF.extend_path_with_includes {verbosity = 0, lpref = loadPath};
if length (!loadPath) <> lpsize0 then
print ("** Load path (see loadPath variable) now contains " ^
Int.toString (length (!loadPath)) ^
" entries\n** after consulting Holmakefiles\n\n")
else ()
end;
use (Path.concat(Globals.HOLDIR, "tools/check-intconfig.sml"));
(* Local variables: *)
(* mode: sml *)
(* end: *)