corrected semantics of presentation_stmt_names; do not print includes on presentation selection
authorhaftmann
Thu, 26 Aug 2010 10:23:25 +0200
changeset 38772 eb7bc47f062b
parent 38771 f9cd27cbe8a4
child 38773 f9837065b5e8
corrected semantics of presentation_stmt_names; do not print includes on presentation selection
src/Tools/Code/code_scala.ML
--- a/src/Tools/Code/code_scala.ML	Thu Aug 26 10:16:22 2010 +0200
+++ b/src/Tools/Code/code_scala.ML	Thu Aug 26 10:23:25 2010 +0200
@@ -446,8 +446,8 @@
       ([str ("object " ^ base ^ " {")] @ the_list (print_implicits implicits)
         @ [p, str ("} /* object " ^ base ^ " */")]);
     fun print_node (_, Dummy) = NONE
-      | print_node (name, Stmt stmt) = if not (not (null presentation_stmt_names)
-          andalso member (op =) presentation_stmt_names name)
+      | print_node (name, Stmt stmt) = if null presentation_stmt_names
+          orelse member (op =) presentation_stmt_names name
           then SOME (print_stmt (name, stmt))
           else NONE
       | print_node (name, Module (_, (implicits, nodes))) = if null presentation_stmt_names
@@ -462,8 +462,9 @@
       in if null ps then NONE else SOME (Pretty.chunks2 ps) end;
 
     (* serialization *)
-    val p = Pretty.chunks2 (map (fn (base, p) => print_module base [] p) includes
-      @ the_list (print_nodes sca_program));
+    val p_includes = if null presentation_stmt_names
+      then map (fn (base, p) => print_module base [] p) includes else [];
+    val p = Pretty.chunks2 (p_includes @ the_list (print_nodes sca_program));
   in
     Code_Target.mk_serialization target
       (fn NONE => code_writeln | SOME file => File.write file o code_of_pretty)