improved and tuned external codegen tool
authorhaftmann
Thu, 23 Sep 2010 10:37:28 +0200
changeset 39646 64fdbee67135
parent 39644 ad436fa9fc5b
child 39647 7bf0c7f0f24c
improved and tuned external codegen tool
src/Tools/Code/code_target.ML
src/Tools/Code/lib/Tools/codegen
--- a/src/Tools/Code/code_target.ML	Thu Sep 23 09:53:52 2010 +0200
+++ b/src/Tools/Code/code_target.ML	Thu Sep 23 10:37:28 2010 +0200
@@ -28,8 +28,6 @@
   val check_code: theory -> string list
     -> ((string * bool) * Token.T list) list -> unit
 
-  val shell_command: string (*theory name*) -> string (*export_code expr*) -> unit
-
   type serializer
   type literals = Code_Printer.literals
   val add_target: string * { serializer: serializer, literals: literals,
@@ -56,6 +54,8 @@
   val add_const_syntax: string -> string -> const_syntax option -> theory -> theory
   val add_reserved: string -> string -> theory -> theory
   val add_include: string -> string * (string * string list) option -> theory -> theory
+
+  val codegen_tool: string (*theory name*) -> bool -> string (*export_code expr*) -> unit
 end;
 
 structure Code_Target : CODE_TARGET =
@@ -683,13 +683,20 @@
   Outer_Syntax.command "export_code" "generate executable code for constants"
     Keyword.diag (Parse.!!! code_exprP >> (fn f => Toplevel.keep (f o Toplevel.theory_of)));
 
-fun shell_command thyname cmd = Toplevel.program (fn _ =>
-  (use_thy thyname; case Scan.read Token.stopper (Parse.!!! code_exprP)
-    ((filter Token.is_proper o Outer_Syntax.scan Position.none) cmd)
-   of SOME f => (writeln "Now generating code..."; f (Thy_Info.get_theory thyname))
-    | NONE => error ("Bad directive " ^ quote cmd)))
-  handle Runtime.TOPLEVEL_ERROR => OS.Process.exit OS.Process.failure;
-
 end; (*local*)
 
+
+(** external entrance point -- for codegen tool **)
+
+fun codegen_tool thyname qnd cmd_expr =
+  let
+    val thy = Thy_Info.get_theory thyname;
+    val _ = quick_and_dirty := qnd;
+    val parse = Scan.read Token.stopper (Parse.!!! code_exprP) o
+      (filter Token.is_proper o Outer_Syntax.scan Position.none);
+  in case parse cmd_expr
+   of SOME f => (writeln "Now generating code..."; f thy)
+    | NONE => error ("Bad directive " ^ quote cmd_expr)
+  end;
+
 end; (*struct*)
--- a/src/Tools/Code/lib/Tools/codegen	Thu Sep 23 09:53:52 2010 +0200
+++ b/src/Tools/Code/lib/Tools/codegen	Thu Sep 23 10:37:28 2010 +0200
@@ -10,27 +10,28 @@
 function usage()
 {
   echo
-  echo "Usage: isabelle $PRG [OPTIONS] IMAGE THY CMD"
+  echo "Usage: isabelle $PRG [OPTIONS] IMAGE THYNAME CMD"
   echo
   echo "  Options are:"
   echo "    -q    run in quick'n'dirty mode"
   echo
   echo "  Issues code generation using image IMAGE,"
-  echo "  theory THY,"
+  echo "  theory THYNAME,"
   echo "  with Isar command 'export_code CMD'"
   echo
   exit 1
 }
 
+
 ## process command line
 
-QUICK_AND_DIRTY=0
+QUICK_AND_DIRTY="false"
 
 while getopts "q" OPT
 do
   case "$OPT" in
     q)
-      QUICK_AND_DIRTY=1
+      QUICK_AND_DIRTY="true"
       ;;
     \?)
       usage
@@ -43,23 +44,20 @@
 [ "$#" -ne 3 ] && usage
 
 IMAGE="$1"; shift
-THY="$1"; shift
-CMD="$1"
+THYNAME="$1"; shift
+CODE_EXPR=$(echo "$1" | perl -pe 's/\\/\\\\/g; s/"/\\\"/g')
 
 
-## main
+## invoke code generation
 
-CODE_CMD=$(echo $CMD | perl -pe 's/\\/\\\\/g; s/"/\\\"/g')
+FORMAL_CMD="Toplevel.program (fn () => ML_Context.eval_text_in \
+  (SOME (ProofContext.init_global (Thy_Info.get_theory thyname))) false Position.none ml_cmd) \
+  handle _ => OS.Process.exit OS.Process.failure;"
 
-if [ "$QUICK_AND_DIRTY" -eq 1 ]
-then
-  QND_FLAG="true"
-else
-  QND_FLAG="false"
-fi
+ACTUAL_CMD="val thyname = \"$THYNAME\"; \
+  val qnd = $QUICK_AND_DIRTY; \
+  val cmd_expr = \"$CODE_EXPR\"; \
+  val ml_cmd = \"Code_Target.codegen_tool thyname qnd cmd_expr\"; \
+  $FORMAL_CMD"
 
-CTXT_CMD="ML_Context.eval_text_in (SOME (ProofContext.init_global (Thy_Info.get_theory \"HOL\"))) false Position.none \"Code_Target.shell_command thyname cmd\";"
-
-FULL_CMD="quick_and_dirty := $QND_FLAG; val thyname = \"$THY\"; val cmd = \"$CODE_CMD\"; $CTXT_CMD"
-
-"$ISABELLE_PROCESS" -q -e "$FULL_CMD" "$IMAGE" || exit 1
+"$ISABELLE_PROCESS" -r -q -e "$ACTUAL_CMD" "$IMAGE" || exit 1