src/Pure/pure_setup.ML
author wenzelm
Mon, 29 Sep 2008 21:26:44 +0200
changeset 28414 419954d26886
parent 28179 8e8313aededc
child 28557 6a661aeff564
permissions -rw-r--r--
install_pp Future.T (polyml only);
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
23828
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/pure_setup.ML
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
     2
    ID:         $Id$
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
     3
    Author:     Makarius
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
     4
24053
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
     5
Pure theory and ML toplevel setup.
23828
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
     6
*)
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
     7
24053
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
     8
(* ML toplevel use commands *)
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
     9
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    10
fun use name          = Toplevel.program (fn () => ThyInfo.use name);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    11
fun use_thys name     = Toplevel.program (fn () => ThyInfo.use_thys name);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    12
fun use_thy name      = Toplevel.program (fn () => ThyInfo.use_thy name);
24174
59a5ffec7078 theory loader: removed obsolete update_thy (coincides with use_thy);
wenzelm
parents: 24053
diff changeset
    13
fun time_use name     = Toplevel.program (fn () => ThyInfo.time_use name);
24053
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    14
fun time_use_thy name = Toplevel.program (fn () => ThyInfo.time_use_thy name);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    15
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    16
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    17
(* the Pure theories *)
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    18
26608
ff838a61dad6 val theory = ThyInfo.get_theory;
wenzelm
parents: 26463
diff changeset
    19
val theory = ThyInfo.get_theory;
ff838a61dad6 val theory = ThyInfo.get_theory;
wenzelm
parents: 26463
diff changeset
    20
26463
9283b4185fdf Context.>> : operate on Context.generic;
wenzelm
parents: 26435
diff changeset
    21
Context.>> (Context.map_theory
9283b4185fdf Context.>> : operate on Context.generic;
wenzelm
parents: 26435
diff changeset
    22
 (OuterSyntax.process_file (Path.explode "Pure.thy") #>
9283b4185fdf Context.>> : operate on Context.generic;
wenzelm
parents: 26435
diff changeset
    23
  Theory.end_theory));
26427
f33d1b522316 implicit setup of emerging theory Pure;
wenzelm
parents: 25223
diff changeset
    24
structure Pure = struct val thy = ML_Context.the_global_context () end;
f33d1b522316 implicit setup of emerging theory Pure;
wenzelm
parents: 25223
diff changeset
    25
Context.set_thread_data NONE;
f33d1b522316 implicit setup of emerging theory Pure;
wenzelm
parents: 25223
diff changeset
    26
ThyInfo.register_theory Pure.thy;
23828
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
    27
24053
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    28
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    29
(* ML toplevel pretty printing *)
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    30
28179
8e8313aededc human-readable printing of TaskQueue.task/group;
wenzelm
parents: 27776
diff changeset
    31
install_pp (make_pp ["TaskQueue", "task"] (Pretty.pprint o Pretty.str o TaskQueue.str_of_task));
8e8313aededc human-readable printing of TaskQueue.task/group;
wenzelm
parents: 27776
diff changeset
    32
install_pp (make_pp ["TaskQueue", "group"] (Pretty.pprint o Pretty.str o TaskQueue.str_of_group));
28414
419954d26886 install_pp Future.T (polyml only);
wenzelm
parents: 28179
diff changeset
    33
419954d26886 install_pp Future.T (polyml only);
wenzelm
parents: 28179
diff changeset
    34
if String.isPrefix "polyml" ml_system then
419954d26886 install_pp Future.T (polyml only);
wenzelm
parents: 28179
diff changeset
    35
  ML_Context.eval false Position.none
419954d26886 install_pp Future.T (polyml only);
wenzelm
parents: 28179
diff changeset
    36
    "install_pp ((make_pp [\"Future\", \"T\"] (Pretty.pprint o Pretty.str o Future.str_of)):\
419954d26886 install_pp Future.T (polyml only);
wenzelm
parents: 28179
diff changeset
    37
    \  ('a, 'a Future.T) pp)"
419954d26886 install_pp Future.T (polyml only);
wenzelm
parents: 28179
diff changeset
    38
else ();
419954d26886 install_pp Future.T (polyml only);
wenzelm
parents: 28179
diff changeset
    39
27776
644e03cb568d install_pp Position.T;
wenzelm
parents: 27341
diff changeset
    40
install_pp (make_pp ["Position", "T"] (Pretty.pprint o Pretty.enum "," "{" "}" o
644e03cb568d install_pp Position.T;
wenzelm
parents: 27341
diff changeset
    41
  map (fn (x, y) => Pretty.str (x ^ "=" ^ y)) o Position.properties_of));
24053
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    42
install_pp (make_pp ["Thm", "thm"] ProofDisplay.pprint_thm);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    43
install_pp (make_pp ["Thm", "cterm"] ProofDisplay.pprint_cterm);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    44
install_pp (make_pp ["Thm", "ctyp"] ProofDisplay.pprint_ctyp);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    45
install_pp (make_pp ["Context", "theory"] Context.pprint_thy);
27341
97e2ccba3b64 added pprint_thy_ref;
wenzelm
parents: 26957
diff changeset
    46
install_pp (make_pp ["Context", "theory_ref"] Context.pprint_thy_ref);
24053
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    47
install_pp (make_pp ["Context", "proof"] ProofDisplay.pprint_context);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    48
install_pp (make_pp ["Syntax", "ast"] Syntax.pprint_ast);
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    49
install_pp (make_pp ["typ"] (ProofDisplay.pprint_typ Pure.thy));
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    50
install_pp (make_pp ["Path", "T"] (Pretty.pprint o Pretty.str o quote o Path.implode));
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    51
install_pp (make_pp ["File", "ident"] (Pretty.pprint o Pretty.str o quote o File.rep_ident));
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    52
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    53
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    54
(* misc *)
af1dd276fae0 added ML toplevel use commands: Toplevel.program;
wenzelm
parents: 23828
diff changeset
    55
23828
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
    56
val cd = File.cd o Path.explode;
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
    57
ml_prompts "ML> " "ML# ";
a8a3962f8eeb Pure theory setup.
wenzelm
parents:
diff changeset
    58
25223
7463251e7273 qualified Proofterm.proofs;
wenzelm
parents: 24960
diff changeset
    59
Proofterm.proofs := 0;