merged
authorbulwahn
Tue, 27 Oct 2009 16:01:38 +0100
changeset 33260 f8d43d5215c2
parent 33259 2ac8ef0342b4 (current diff)
parent 33232 f93390060bbe (diff)
child 33261 cb3908614f7e
merged
--- a/doc-src/Nitpick/nitpick.tex	Tue Oct 27 13:51:22 2009 +0100
+++ b/doc-src/Nitpick/nitpick.tex	Tue Oct 27 16:01:38 2009 +0100
@@ -2091,11 +2091,11 @@
 \url{http://cs.technion.ac.il/~gershman/HaifaSat.htm}.
 
 \item[$\bullet$] \textbf{\textit{smart}}: If \textit{sat\_solver} is set to
-\textit{smart}, Nitpick selects the first solver among MiniSat, PicoSAT, zChaff,
-RSat, BerkMin, BerkMinAlloy, and Jerusat that is recognized by Isabelle. If none
-is found, it falls back on SAT4J, which should always be available. If
-\textit{verbose} is enabled, Nitpick displays which SAT solver was chosen.
-
+\textit{smart}, Nitpick selects the first solver among MiniSatJNI, MiniSat,
+PicoSAT, zChaffJNI, zChaff, RSat, BerkMin, BerkMinAlloy, and Jerusat that is
+recognized by Isabelle. If none is found, it falls back on SAT4J, which should
+always be available. If \textit{verbose} is enabled, Nitpick displays which SAT
+solver was chosen.
 \end{enum}
 \fussy
 
@@ -2381,7 +2381,7 @@
 (``genuine'', ``likely\_genuine'', ``potential'', ``none'', or ``unknown''). The
 \textit{params} type is a large record that lets you set Nitpick's options. The
 current default options can be retrieved by calling the following function
-defined in the \textit{NitpickIsar} structure:
+defined in the \textit{Nitpick\_Isar} structure:
 
 \prew
 $\textbf{val}\,~\textit{default\_params} :\,
@@ -2392,7 +2392,7 @@
 put into a \textit{params} record. Here is an example:
 
 \prew
-$\textbf{val}\,~\textit{params} = \textit{NitpickIsar.default\_params}~\textit{thy}~[(\textrm{``}\textrm{timeout}\textrm{''},\, \textrm{``}\textrm{none}\textrm{''})]$ \\
+$\textbf{val}\,~\textit{params} = \textit{Nitpick\_Isar.default\_params}~\textit{thy}~[(\textrm{``}\textrm{timeout}\textrm{''},\, \textrm{``}\textrm{none}\textrm{''})]$ \\
 $\textbf{val}\,~(\textit{outcome},\, \textit{state}') = \textit{Nitpick.pick\_nits\_in\_subgoal}~\begin{aligned}[t]
 & \textit{state}~\textit{params}~\textit{false} \\[-2pt]
 & \textit{subgoal}\end{aligned}$
--- a/src/HOL/Nitpick_Examples/Mono_Nits.thy	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Nitpick_Examples/Mono_Nits.thy	Tue Oct 27 16:01:38 2009 +0100
@@ -14,8 +14,8 @@
 ML {*
 exception FAIL
 
-val defs = NitpickHOL.all_axioms_of @{theory} |> #1
-val def_table = NitpickHOL.const_def_table @{context} defs
+val defs = Nitpick_HOL.all_axioms_of @{theory} |> #1
+val def_table = Nitpick_HOL.const_def_table @{context} defs
 val ext_ctxt =
   {thy = @{theory}, ctxt = @{context}, max_bisim_depth = ~1, boxes = [],
    user_axioms = NONE, debug = false, wfs = [], destroy_constrs = false,
--- a/src/HOL/Nitpick_Examples/Tests_Nits.thy	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Nitpick_Examples/Tests_Nits.thy	Tue Oct 27 16:01:38 2009 +0100
@@ -11,6 +11,6 @@
 imports Main
 begin
 
-ML {* NitpickTests.run_all_tests () *}
+ML {* Nitpick_Tests.run_all_tests () *}
 
 end
--- a/src/HOL/Tools/Nitpick/kodkod.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/kodkod.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -1043,6 +1043,10 @@
             let
               val code =
                 system ("env CLASSPATH=\"$KODKODI_CLASSPATH:$CLASSPATH\" \
+                        \JAVA_LIBRARY_PATH=\"$KODKODI_JAVA_LIBRARY_PATH:\
+                        \$JAVA_LIBRARY_PATH\" \
+                        \LD_LIBRARY_PATH=\"$KODKODI_JAVA_LIBRARY_PATH:\
+                        \$LD_LIBRARY_PATH\" \
                         \\"$ISABELLE_TOOL\" java \
                         \de.tum.in.isabelle.Kodkodi.Kodkodi" ^
                         (if ms >= 0 then " -max-msecs " ^ Int.toString ms
--- a/src/HOL/Tools/Nitpick/kodkod_sat.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/kodkod_sat.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -12,13 +12,15 @@
   val sat_solver_spec : string -> string * string list
 end;
 
-structure KodkodSAT : KODKOD_SAT =
+structure Kodkod_SAT : KODKOD_SAT =
 struct
 
 datatype sink = ToStdout | ToFile
+datatype availability = Java | JNI
+datatype mode = Batch | Incremental
 
 datatype sat_solver_info =
-  Internal of bool * string list |
+  Internal of availability * mode * string list |
   External of sink * string * string * string list |
   ExternalV2 of sink * string * string * string list * string * string * string
 
@@ -26,9 +28,11 @@
 
 (* (string * sat_solver_info) list *)
 val static_list =
-  [("MiniSat", ExternalV2 (ToFile, "MINISAT_HOME", "minisat", [], "SAT", "",
+  [("MiniSatJNI", Internal (JNI, Incremental, ["MiniSat"])),
+   ("MiniSat", ExternalV2 (ToFile, "MINISAT_HOME", "minisat", [], "SAT", "",
                            "UNSAT")),
    ("PicoSAT", External (ToStdout, "PICOSAT_HOME", "picosat", [])),
+   ("zChaffJNI", Internal (JNI, Batch, ["zChaff"])),
    ("zChaff", ExternalV2 (ToStdout, "ZCHAFF_HOME", "zchaff", [],
                           "Instance Satisfiable", "",
                           "Instance Unsatisfiable")),
@@ -40,10 +44,8 @@
                            "solution =", "UNSATISFIABLE          !!")),
    ("BerkMinAlloy", External (ToStdout, "BERKMINALLOY_HOME", "berkmin", [])),
    ("Jerusat", External (ToStdout, "JERUSAT_HOME", "Jerusat1.3", [])),
-   ("SAT4J", Internal (true, ["DefaultSAT4J"])),
-   ("MiniSatJNI", Internal (true, ["MiniSat"])),
-   ("zChaffJNI", Internal (false, ["zChaff"])),
-   ("SAT4JLight", Internal (true, ["LightSAT4J"])),
+   ("SAT4J", Internal (Java, Incremental, ["DefaultSAT4J"])),
+   ("SAT4JLight", Internal (Java, Incremental, ["LightSAT4J"])),
    ("HaifaSat", ExternalV2 (ToStdout, "HAIFASAT_HOME", "HaifaSat", ["-p", "1"],
                             "s SATISFIABLE", "v ", "s UNSATISFIABLE"))]
 
@@ -72,13 +74,27 @@
                           end)
 (* bool -> string * sat_solver_info
    -> (string * (unit -> string list)) option *)
-fun dynamic_entry_for_info false (name, Internal (_, ss)) = SOME (name, K ss)
+fun dynamic_entry_for_info incremental (name, Internal (Java, mode, ss)) =
+    if incremental andalso mode = Batch then NONE else SOME (name, K ss)
+  | dynamic_entry_for_info incremental (name, Internal (JNI, mode, ss)) =
+    if incremental andalso mode = Batch then
+      NONE
+    else
+      let
+        val lib_paths = getenv "KODKODI_JAVA_LIBRARY_PATH"
+                        |> space_explode ":"
+      in
+        if exists (fn path => File.exists (Path.explode (path ^ "/")))
+                  lib_paths then
+          SOME (name, K ss)
+        else
+          NONE
+      end
   | dynamic_entry_for_info false (name, External (dev, home, exec, args)) =
     dynamic_entry_for_external name dev home exec args []
   | dynamic_entry_for_info false (name, ExternalV2 (dev, home, exec, args,
                                                     m1, m2, m3)) =
     dynamic_entry_for_external name dev home exec args [m1, m2, m3]
-  | dynamic_entry_for_info true (name, Internal (true, ss)) = SOME (name, K ss)
   | dynamic_entry_for_info true _ = NONE
 (* bool -> (string * (unit -> string list)) list *)
 fun dynamic_list incremental =
--- a/src/HOL/Tools/Nitpick/minipick.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/minipick.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -14,10 +14,10 @@
 struct
 
 open Kodkod
-open NitpickUtil
-open NitpickHOL
-open NitpickPeephole
-open NitpickKodkod
+open Nitpick_Util
+open Nitpick_HOL
+open Nitpick_Peephole
+open Nitpick_Kodkod
 
 (* theory -> typ -> unit *)
 fun check_type ctxt (Type ("fun", Ts)) = List.app (check_type ctxt) Ts
--- a/src/HOL/Tools/Nitpick/nitpick.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -62,15 +62,15 @@
 structure Nitpick : NITPICK =
 struct
 
-open NitpickUtil
-open NitpickHOL
-open NitpickMono
-open NitpickScope
-open NitpickPeephole
-open NitpickRep
-open NitpickNut
-open NitpickKodkod
-open NitpickModel
+open Nitpick_Util
+open Nitpick_HOL
+open Nitpick_Mono
+open Nitpick_Scope
+open Nitpick_Peephole
+open Nitpick_Rep
+open Nitpick_Nut
+open Nitpick_Kodkod
+open Nitpick_Model
 
 type params = {
   cards_assigns: (typ option * int list) list,
@@ -355,21 +355,21 @@
     val effective_sat_solver =
       if sat_solver <> "smart" then
         if need_incremental andalso
-           not (sat_solver mem KodkodSAT.configured_sat_solvers true) then
+           not (sat_solver mem Kodkod_SAT.configured_sat_solvers true) then
           (print_m (K ("An incremental SAT solver is required: \"SAT4J\" will \
                        \be used instead of " ^ quote sat_solver ^ "."));
            "SAT4J")
         else
           sat_solver
       else
-        KodkodSAT.smart_sat_solver_name need_incremental
+        Kodkod_SAT.smart_sat_solver_name need_incremental
     val _ =
       if sat_solver = "smart" then
         print_v (fn () => "Using SAT solver " ^ quote effective_sat_solver ^
                           ". The following" ^
                           (if need_incremental then " incremental " else " ") ^
                           "solvers are configured: " ^
-                          commas (map quote (KodkodSAT.configured_sat_solvers
+                          commas (map quote (Kodkod_SAT.configured_sat_solvers
                                                        need_incremental)) ^ ".")
       else
         ()
@@ -439,7 +439,7 @@
         val formula = fold (fold s_and) [def_fs, nondef_fs] core_f
         val comment = (if liberal then "liberal" else "conservative") ^ "\n" ^
                       PrintMode.setmp [] multiline_string_for_scope scope
-        val kodkod_sat_solver = KodkodSAT.sat_solver_spec effective_sat_solver
+        val kodkod_sat_solver = Kodkod_SAT.sat_solver_spec effective_sat_solver
                                 |> snd
         val delay = if liberal then
                       Option.map (fn time => Time.- (time, Time.now ()))
@@ -483,7 +483,7 @@
                defs = nondef_fs @ def_fs @ declarative_axioms})
       end
       handle LIMIT (loc, msg) =>
-             if loc = "NitpickKodkod.check_arity"
+             if loc = "Nitpick_Kodkod.check_arity"
                 andalso not (Typtab.is_empty ofs) then
                problem_for_scope liberal
                    {ext_ctxt = ext_ctxt, card_assigns = card_assigns,
--- a/src/HOL/Tools/Nitpick/nitpick_hol.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_hol.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -139,10 +139,10 @@
     extended_context -> term -> ((term list * term list) * (bool * bool)) * term
 end;
 
-structure NitpickHOL : NITPICK_HOL =
+structure Nitpick_HOL : NITPICK_HOL =
 struct
 
-open NitpickUtil
+open Nitpick_Util
 
 type const_table = term list Symtab.table
 type special_fun = (styp * int list * term list) * styp
@@ -263,7 +263,7 @@
 val after_name_sep = snd o strip_first_name_sep
 
 (* When you add constants to these lists, make sure to handle them in
-   "NitpickNut.nut_from_term", and perhaps in "NitpickMono.consider_term" as
+   "Nitpick_Nut.nut_from_term", and perhaps in "Nitpick_Mono.consider_term" as
    well. *)
 val built_in_consts =
   [(@{const_name all}, 1),
@@ -405,7 +405,7 @@
 (* typ -> styp *)
 fun const_for_iterator_type (Type (s, Ts)) = (after_name_sep s, Ts ---> bool_T)
   | const_for_iterator_type T =
-    raise TYPE ("NitpickHOL.const_for_iterator_type", [T], [])
+    raise TYPE ("Nitpick_HOL.const_for_iterator_type", [T], [])
 
 (* int -> typ -> typ * typ *)
 fun strip_n_binders 0 T = ([], T)
@@ -413,7 +413,7 @@
     strip_n_binders (n - 1) T2 |>> cons T1
   | strip_n_binders n (Type (@{type_name fun_box}, Ts)) =
     strip_n_binders n (Type ("fun", Ts))
-  | strip_n_binders _ T = raise TYPE ("NitpickHOL.strip_n_binders", [T], [])
+  | strip_n_binders _ T = raise TYPE ("Nitpick_HOL.strip_n_binders", [T], [])
 (* typ -> typ *)
 val nth_range_type = snd oo strip_n_binders
 
@@ -432,7 +432,7 @@
 fun mk_flat_tuple _ [t] = t
   | mk_flat_tuple (Type ("*", [T1, T2])) (t :: ts) =
     HOLogic.pair_const T1 T2 $ t $ (mk_flat_tuple T2 ts)
-  | mk_flat_tuple T ts = raise TYPE ("NitpickHOL.mk_flat_tuple", [T], ts)
+  | mk_flat_tuple T ts = raise TYPE ("Nitpick_HOL.mk_flat_tuple", [T], ts)
 (* int -> term -> term list *)
 fun dest_n_tuple 1 t = [t]
   | dest_n_tuple n t = HOLogic.dest_prod t ||> dest_n_tuple (n - 1) |> op ::
@@ -441,7 +441,8 @@
 fun dest_n_tuple_type 1 T = [T]
   | dest_n_tuple_type n (Type (_, [T1, T2])) =
     T1 :: dest_n_tuple_type (n - 1) T2
-  | dest_n_tuple_type _ T = raise TYPE ("NitpickHOL.dest_n_tuple_type", [T], [])
+  | dest_n_tuple_type _ T =
+    raise TYPE ("Nitpick_HOL.dest_n_tuple_type", [T], [])
 
 (* (typ * typ) list -> typ -> typ *)
 fun typ_subst [] T = T
@@ -460,7 +461,7 @@
                    (Sign.typ_match thy (Logic.varifyT T1, T1') Vartab.empty))
               (Logic.varifyT T2)
   handle Type.TYPE_MATCH =>
-         raise TYPE ("NitpickHOL.instantiate_type", [T1, T1'], [])
+         raise TYPE ("Nitpick_HOL.instantiate_type", [T1, T1'], [])
 
 (* theory -> typ -> typ -> styp *)
 fun repair_constr_type thy body_T' T =
@@ -483,7 +484,7 @@
     val (co_s, co_Ts) = dest_Type co_T
     val _ =
       if forall is_TFree co_Ts andalso not (has_duplicates (op =) co_Ts) then ()
-      else raise TYPE ("NitpickHOL.register_codatatype", [co_T], [])
+      else raise TYPE ("Nitpick_HOL.register_codatatype", [co_T], [])
     val codatatypes = AList.update (op =) (co_s, (case_name, constr_xs))
                                    codatatypes
   in TheoryData.put {frac_types = frac_types, codatatypes = codatatypes} thy end
@@ -586,8 +587,8 @@
 fun mate_of_rep_fun thy (x as (_, Type ("fun", [T1 as Type (s', _), T2]))) =
     (case typedef_info thy s' of
        SOME {Abs_name, ...} => (Abs_name, Type ("fun", [T2, T1]))
-     | NONE => raise TERM ("NitpickHOL.mate_of_rep_fun", [Const x]))
-  | mate_of_rep_fun _ x = raise TERM ("NitpickHOL.mate_of_rep_fun", [Const x])
+     | NONE => raise TERM ("Nitpick_HOL.mate_of_rep_fun", [Const x]))
+  | mate_of_rep_fun _ x = raise TERM ("Nitpick_HOL.mate_of_rep_fun", [Const x])
 
 (* theory -> styp -> bool *)
 fun is_coconstr thy (s, T) =
@@ -874,7 +875,7 @@
     case AList.lookup (op =) asgns T of
       SOME k => k
     | NONE => if T = @{typ bisim_iterator} then 0
-              else raise TYPE ("NitpickHOL.card_of_type", [T], [])
+              else raise TYPE ("Nitpick_HOL.card_of_type", [T], [])
 (* int -> (typ * int) list -> typ -> int *)
 fun bounded_card_of_type max default_card asgns (Type ("fun", [T1, T2])) =
     let
@@ -894,7 +895,7 @@
                     card_of_type asgns T
                   else
                     card_of_type asgns T
-                    handle TYPE ("NitpickHOL.card_of_type", _, _) =>
+                    handle TYPE ("Nitpick_HOL.card_of_type", _, _) =>
                            default_card)
 (* theory -> int -> (typ * int) list -> typ -> int *)
 fun bounded_precise_card_of_type thy max default_card asgns T =
@@ -1110,13 +1111,13 @@
     (* term -> term *)
     fun aux (v as Var _) t = lambda v t
       | aux (c as Const (@{const_name TYPE}, T)) t = lambda c t
-      | aux _ _ = raise TERM ("NitpickHOL.normalized_rhs_of", [t])
+      | aux _ _ = raise TERM ("Nitpick_HOL.normalized_rhs_of", [t])
     val (lhs, rhs) =
       case t of
         Const (@{const_name "=="}, _) $ t1 $ t2 => (t1, t2)
       | @{const Trueprop} $ (Const (@{const_name "op ="}, _) $ t1 $ t2) =>
         (t1, t2)
-      | _ => raise TERM ("NitpickHOL.normalized_rhs_of", [t])
+      | _ => raise TERM ("Nitpick_HOL.normalized_rhs_of", [t])
     val args = strip_comb lhs |> snd
   in fold_rev aux args rhs end
 
@@ -1170,7 +1171,7 @@
   case term_under_def t of
     Const (s, _) => (s, t)
   | Free _ => raise NOT_SUPPORTED "local definitions"
-  | t' => raise TERM ("NitpickHOL.pair_for_prop", [t, t'])
+  | t' => raise TERM ("Nitpick_HOL.pair_for_prop", [t, t'])
 
 (* (Proof.context -> term list) -> Proof.context -> const_table *)
 fun table_for get ctxt =
@@ -1308,7 +1309,7 @@
     |> fold_rev (curry absdummy) (func_Ts @ [dataT])
   end
 
-val redefined_in_NitpickDefs_thy =
+val redefined_in_Nitpick_thy =
   [@{const_name option_case}, @{const_name nat_case}, @{const_name list_case},
    @{const_name list_size}]
 
@@ -1325,7 +1326,8 @@
                  select_nth_constr_arg thy constr_x t j res_T
                  |> optimized_record_get thy s rec_T' res_T
                end
-             | _ => raise TYPE ("NitpickHOL.optimized_record_get", [rec_T], []))
+             | _ => raise TYPE ("Nitpick_HOL.optimized_record_get", [rec_T],
+                                []))
     | j => select_nth_constr_arg thy constr_x t j res_T
   end
 (* theory -> string -> typ -> term -> term -> term *)
@@ -1380,7 +1382,7 @@
   (is_real_equational_fun ext_ctxt orf is_real_inductive_pred ext_ctxt
    orf (String.isPrefix ubfp_prefix orf String.isPrefix lbfp_prefix) o fst)
   andf (not o has_trivial_definition thy def_table)
-  andf (not o member (op =) redefined_in_NitpickDefs_thy o fst)
+  andf (not o member (op =) redefined_in_Nitpick_thy o fst)
 
 (* term * term -> term *)
 fun s_betapply (Const (@{const_name If}, _) $ @{const True} $ t, _) = t
@@ -1532,7 +1534,7 @@
               else case def_of_const thy def_table x of
                 SOME def =>
                 if depth > unfold_max_depth then
-                  raise LIMIT ("NitpickHOL.unfold_defs_in_term",
+                  raise LIMIT ("Nitpick_HOL.unfold_defs_in_term",
                                "too many nested definitions (" ^
                                string_of_int depth ^ ") while expanding " ^
                                quote s)
@@ -1640,7 +1642,8 @@
         ({thy, ctxt, debug, fast_descrs, tac_timeout, intro_table, ...}
          : extended_context) (x as (_, T)) =
   case def_props_for_const thy fast_descrs intro_table x of
-    [] => raise TERM ("NitpickHOL.is_is_well_founded_inductive_pred", [Const x])
+    [] => raise TERM ("Nitpick_HOL.is_is_well_founded_inductive_pred",
+                      [Const x])
   | intro_ts =>
     (case map (triple_for_intro_rule thy x) intro_ts
           |> filter_out (null o #2) of
@@ -1772,7 +1775,7 @@
                               |> ap_split tuple_T bool_T))
         end
       | aux t =
-        raise TERM ("NitpickHOL.linear_pred_base_and_step_rhss.aux", [t])
+        raise TERM ("Nitpick_HOL.linear_pred_base_and_step_rhss.aux", [t])
   in aux end
 
 (* extended_context -> styp -> term -> term *)
@@ -1834,8 +1837,8 @@
         val rhs = case fp_app of
                     Const _ $ t =>
                     betapply (t, list_comb (Const x', next :: outer_bounds))
-                  | _ => raise TERM ("NitpickHOL.unrolled_inductive_pred_const",
-                                     [fp_app])
+                  | _ => raise TERM ("Nitpick_HOL.unrolled_inductive_pred_\
+                                     \const", [fp_app])
         val (inner, naked_rhs) = strip_abs rhs
         val all = outer @ inner
         val bounds = map Bound (length all - 1 downto 0)
@@ -1854,7 +1857,7 @@
     val outer_bounds = map Bound (length outer - 1 downto 0)
     val rhs = case fp_app of
                 Const _ $ t => betapply (t, list_comb (Const x, outer_bounds))
-              | _ => raise TERM ("NitpickHOL.raw_inductive_pred_axiom",
+              | _ => raise TERM ("Nitpick_HOL.raw_inductive_pred_axiom",
                                  [fp_app])
     val (inner, naked_rhs) = strip_abs rhs
     val all = outer @ inner
@@ -1876,7 +1879,7 @@
 (* extended_context -> styp -> term list *)
 fun raw_equational_fun_axioms (ext_ctxt as {thy, fast_descrs, simp_table,
                                             psimp_table, ...}) (x as (s, _)) =
-  if s mem redefined_in_NitpickDefs_thy then
+  if s mem redefined_in_Nitpick_thy then
     []
   else case def_props_for_const thy fast_descrs (!simp_table) x of
     [] => (case def_props_for_const thy fast_descrs psimp_table x of
@@ -2329,7 +2332,7 @@
                                 ts
                    (* (term * int list) list -> term *)
                    fun mk_connection [] =
-                       raise ARG ("NitpickHOL.push_quantifiers_inward.aux.\
+                       raise ARG ("Nitpick_HOL.push_quantifiers_inward.aux.\
                                   \mk_connection", "")
                      | mk_connection ts_cum_bounds =
                        ts_cum_bounds |> map fst
@@ -2720,7 +2723,7 @@
              |> new_s <> "fun"
                 ? construct_value thy (@{const_name FunBox},
                                        Type ("fun", new_Ts) --> new_T) o single
-           | t' => raise TERM ("NitpickHOL.box_fun_and_pair_in_term.\
+           | t' => raise TERM ("Nitpick_HOL.box_fun_and_pair_in_term.\
                                \coerce_term", [t']))
         | (Type (new_s, new_Ts as [new_T1, new_T2]),
            Type (old_s, old_Ts as [old_T1, old_T2])) =>
@@ -2740,7 +2743,7 @@
                    else @{const_name PairBox}, new_Ts ---> new_T)
                   [coerce_term Ts new_T1 old_T1 t1,
                    coerce_term Ts new_T2 old_T2 t2]
-            | t' => raise TERM ("NitpickHOL.box_fun_and_pair_in_term.\
+            | t' => raise TERM ("Nitpick_HOL.box_fun_and_pair_in_term.\
                                 \coerce_term", [t'])
           else
             raise TYPE ("coerce_term", [new_T, old_T], [t])
@@ -2753,7 +2756,7 @@
         (case T' of
            Type (_, [T1, T2]) =>
            fold (add_boxed_types_for_var z) [(T1, t1), (T2, t2)]
-         | _ => raise TYPE ("NitpickHOL.box_fun_and_pair_in_term.\
+         | _ => raise TYPE ("Nitpick_HOL.box_fun_and_pair_in_term.\
                             \add_boxed_types_for_var", [T'], []))
       | _ => exists_subterm (equal (Var z)) t' ? insert (op =) T
     (* typ list -> typ list -> term -> indexname * typ -> typ *)
@@ -3008,7 +3011,7 @@
          else
            let val accum as (xs, _) = (x :: xs, axs) in
              if depth > axioms_max_depth then
-               raise LIMIT ("NitpickHOL.axioms_for_term.add_axioms_for_term",
+               raise LIMIT ("Nitpick_HOL.axioms_for_term.add_axioms_for_term",
                             "too many nested axioms (" ^ string_of_int depth ^
                             ")")
              else if Refute.is_const_of_class thy x then
@@ -3081,7 +3084,7 @@
                          [] => t
                        | [(x, S)] =>
                          Refute.monomorphic_term (Vartab.make [(x, (S, T))]) t
-                       | _ => raise TERM ("NitpickHOL.axioms_for_term.\
+                       | _ => raise TERM ("Nitpick_HOL.axioms_for_term.\
                                           \add_axioms_for_sort", [t]))
               class_axioms
       in fold (add_nondef_axiom depth) monomorphic_class_axioms end
--- a/src/HOL/Tools/Nitpick/nitpick_isar.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_isar.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -13,13 +13,13 @@
   val default_params : theory -> (string * string) list -> params
 end
 
-structure NitpickIsar : NITPICK_ISAR =
+structure Nitpick_Isar : NITPICK_ISAR =
 struct
 
-open NitpickUtil
-open NitpickHOL
-open NitpickRep
-open NitpickNut
+open Nitpick_Util
+open Nitpick_HOL
+open Nitpick_Rep
+open Nitpick_Nut
 open Nitpick
 
 type raw_param = string * string list
--- a/src/HOL/Tools/Nitpick/nitpick_kodkod.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_kodkod.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -7,10 +7,10 @@
 
 signature NITPICK_KODKOD =
 sig
-  type extended_context = NitpickHOL.extended_context
-  type dtype_spec = NitpickScope.dtype_spec
-  type kodkod_constrs = NitpickPeephole.kodkod_constrs
-  type nut = NitpickNut.nut
+  type extended_context = Nitpick_HOL.extended_context
+  type dtype_spec = Nitpick_Scope.dtype_spec
+  type kodkod_constrs = Nitpick_Peephole.kodkod_constrs
+  type nut = Nitpick_Nut.nut
   type nfa_transition = Kodkod.rel_expr * typ
   type nfa_entry = typ * nfa_transition list
   type nfa_table = nfa_entry list
@@ -37,15 +37,15 @@
     int Typtab.table -> bool -> kodkod_constrs -> nut -> Kodkod.formula
 end;
 
-structure NitpickKodkod : NITPICK_KODKOD =
+structure Nitpick_Kodkod : NITPICK_KODKOD =
 struct
 
-open NitpickUtil
-open NitpickHOL
-open NitpickScope
-open NitpickPeephole
-open NitpickRep
-open NitpickNut
+open Nitpick_Util
+open Nitpick_HOL
+open Nitpick_Scope
+open Nitpick_Peephole
+open Nitpick_Rep
+open Nitpick_Nut
 
 type nfa_transition = Kodkod.rel_expr * typ
 type nfa_entry = typ * nfa_transition list
@@ -89,7 +89,7 @@
 (* int -> int -> unit *)
 fun check_arity univ_card n =
   if n > Kodkod.max_arity univ_card then
-    raise LIMIT ("NitpickKodkod.check_arity",
+    raise LIMIT ("Nitpick_Kodkod.check_arity",
                  "arity " ^ string_of_int n ^ " too large for universe of \
                  \cardinality " ^ string_of_int univ_card)
   else
@@ -132,7 +132,7 @@
 (* int -> unit *)
 fun check_table_size k =
   if k > max_table_size then
-    raise LIMIT ("NitpickKodkod.check_table_size",
+    raise LIMIT ("Nitpick_Kodkod.check_table_size",
                  "precomputed table too large (" ^ string_of_int k ^ ")")
   else
     ()
@@ -245,7 +245,7 @@
      ("norm_frac", tabulate_int_op2_2 debug univ_card (int_card, j0)
                                       isa_norm_frac)
    else
-     raise ARG ("NitpickKodkod.tabulate_built_in_rel", "unknown relation"))
+     raise ARG ("Nitpick_Kodkod.tabulate_built_in_rel", "unknown relation"))
 
 (* bool -> int -> int -> int -> int -> int * int -> Kodkod.rel_expr
    -> Kodkod.bound *)
@@ -266,11 +266,11 @@
      if nick = @{const_name bisim_iterator_max} then
        case R of
          Atom (k, j0) => [Kodkod.TupleSet [Kodkod.Tuple [k - 1 + j0]]]
-       | _ => raise NUT ("NitpickKodkod.bound_for_plain_rel", [u])
+       | _ => raise NUT ("Nitpick_Kodkod.bound_for_plain_rel", [u])
      else
        [Kodkod.TupleSet [], upper_bound_for_rep R])
   | bound_for_plain_rel _ _ u =
-    raise NUT ("NitpickKodkod.bound_for_plain_rel", [u])
+    raise NUT ("Nitpick_Kodkod.bound_for_plain_rel", [u])
 
 (* Proof.context -> bool -> dtype_spec list -> nut -> Kodkod.bound *)
 fun bound_for_sel_rel ctxt debug dtypes
@@ -293,7 +293,7 @@
          end)
     end
   | bound_for_sel_rel _ _ _ u =
-    raise NUT ("NitpickKodkod.bound_for_sel_rel", [u])
+    raise NUT ("Nitpick_Kodkod.bound_for_sel_rel", [u])
 
 (* Kodkod.bound list -> Kodkod.bound list *)
 fun merge_bounds bs =
@@ -320,7 +320,7 @@
   if is_lone_rep R then
     all_combinations_for_rep R |> map singleton_from_combination
   else
-    raise REP ("NitpickKodkod.all_singletons_for_rep", [R])
+    raise REP ("Nitpick_Kodkod.all_singletons_for_rep", [R])
 
 (* Kodkod.rel_expr -> Kodkod.rel_expr list *)
 fun unpack_products (Kodkod.Product (r1, r2)) =
@@ -333,7 +333,7 @@
 val empty_rel_for_rep = empty_n_ary_rel o arity_of_rep
 fun full_rel_for_rep R =
   case atom_schema_of_rep R of
-    [] => raise REP ("NitpickKodkod.full_rel_for_rep", [R])
+    [] => raise REP ("Nitpick_Kodkod.full_rel_for_rep", [R])
   | schema => foldl1 Kodkod.Product (map Kodkod.AtomSeq schema)
 
 (* int -> int list -> Kodkod.decl list *)
@@ -424,7 +424,7 @@
 fun rel_expr_from_formula kk R f =
   case unopt_rep R of
     Atom (2, j0) => atom_from_formula kk j0 f
-  | _ => raise REP ("NitpickKodkod.rel_expr_from_formula", [R])
+  | _ => raise REP ("Nitpick_Kodkod.rel_expr_from_formula", [R])
 
 (* kodkod_cotrs -> int -> int -> Kodkod.rel_expr -> Kodkod.rel_expr list *)
 fun unpack_vect_in_chunks ({kk_project_seq, ...} : kodkod_constrs) chunk_arity
@@ -471,13 +471,13 @@
       if is_lone_rep old_R andalso is_lone_rep new_R
          andalso card = card_of_rep new_R then
         if card >= lone_rep_fallback_max_card then
-          raise LIMIT ("NitpickKodkod.lone_rep_fallback",
+          raise LIMIT ("Nitpick_Kodkod.lone_rep_fallback",
                        "too high cardinality (" ^ string_of_int card ^ ")")
         else
           kk_case_switch kk old_R new_R r (all_singletons_for_rep old_R)
                          (all_singletons_for_rep new_R)
       else
-        raise REP ("NitpickKodkod.lone_rep_fallback", [old_R, new_R])
+        raise REP ("Nitpick_Kodkod.lone_rep_fallback", [old_R, new_R])
     end
 (* kodkod_constrs -> int * int -> rep -> Kodkod.rel_expr -> Kodkod.rel_expr *)
 and atom_from_rel_expr kk (x as (k, j0)) old_R r =
@@ -490,7 +490,7 @@
       atom_from_rel_expr kk x (Vect (dom_card, R2'))
                          (vect_from_rel_expr kk dom_card R2' old_R r)
     end
-  | Opt _ => raise REP ("NitpickKodkod.atom_from_rel_expr", [old_R])
+  | Opt _ => raise REP ("Nitpick_Kodkod.atom_from_rel_expr", [old_R])
   | _ => lone_rep_fallback kk (Atom x) old_R r
 (* kodkod_constrs -> rep list -> rep -> Kodkod.rel_expr -> Kodkod.rel_expr *)
 and struct_from_rel_expr kk Rs old_R r =
@@ -515,7 +515,7 @@
       else
         lone_rep_fallback kk (Struct Rs) old_R r
     end
-  | _ => raise REP ("NitpickKodkod.struct_from_rel_expr", [old_R])
+  | _ => raise REP ("Nitpick_Kodkod.struct_from_rel_expr", [old_R])
 (* kodkod_constrs -> int -> rep -> rep -> Kodkod.rel_expr -> Kodkod.rel_expr *)
 and vect_from_rel_expr kk k R old_R r =
   case old_R of
@@ -530,7 +530,7 @@
                      rel_expr_from_formula kk R (#kk_subset kk arg_r r))
                  (all_singletons_for_rep R1))
     else
-      raise REP ("NitpickKodkod.vect_from_rel_expr", [old_R])
+      raise REP ("Nitpick_Kodkod.vect_from_rel_expr", [old_R])
   | Func (Unit, R2) => rel_expr_from_rel_expr kk R R2 r
   | Func (R1, R2) =>
     fold1 (#kk_product kk)
@@ -538,7 +538,7 @@
                    rel_expr_from_rel_expr kk R R2
                                          (kk_n_fold_join kk true R1 R2 arg_r r))
                (all_singletons_for_rep R1))
-  | _ => raise REP ("NitpickKodkod.vect_from_rel_expr", [old_R])
+  | _ => raise REP ("Nitpick_Kodkod.vect_from_rel_expr", [old_R])
 (* kodkod_constrs -> rep -> rep -> rep -> Kodkod.rel_expr -> Kodkod.rel_expr *)
 and func_from_no_opt_rel_expr kk R1 R2 (Atom x) r =
     let
@@ -555,12 +555,12 @@
      | Func (Atom (1, _), Formula Neut) =>
        (case unopt_rep R2 of
           Atom (2, j0) => atom_from_formula kk j0 (#kk_some kk r)
-        | _ => raise REP ("NitpickKodkod.func_from_no_opt_rel_expr",
+        | _ => raise REP ("Nitpick_Kodkod.func_from_no_opt_rel_expr",
                           [old_R, Func (Unit, R2)]))
      | Func (R1', R2') =>
        rel_expr_from_rel_expr kk R2 R2' (#kk_project_seq kk r (arity_of_rep R1')
                               (arity_of_rep R2'))
-     | _ => raise REP ("NitpickKodkod.func_from_no_opt_rel_expr",
+     | _ => raise REP ("Nitpick_Kodkod.func_from_no_opt_rel_expr",
                        [old_R, Func (Unit, R2)]))
   | func_from_no_opt_rel_expr kk R1 (Formula Neut) old_R r =
     (case old_R of
@@ -592,7 +592,7 @@
      | Func (R1', Atom (2, j0)) =>
        func_from_no_opt_rel_expr kk R1 (Formula Neut)
            (Func (R1', Formula Neut)) (#kk_join kk r (Kodkod.Atom (j0 + 1)))
-     | _ => raise REP ("NitpickKodkod.func_from_no_opt_rel_expr",
+     | _ => raise REP ("Nitpick_Kodkod.func_from_no_opt_rel_expr",
                        [old_R, Func (R1, Formula Neut)]))
   | func_from_no_opt_rel_expr kk R1 R2 old_R r =
     case old_R of
@@ -621,7 +621,7 @@
                                  (#kk_rel_eq kk r2 r3)
              end
            end
-         | _ => raise REP ("NitpickKodkod.func_from_no_opt_rel_expr",
+         | _ => raise REP ("Nitpick_Kodkod.func_from_no_opt_rel_expr",
                            [old_R, Func (R1, R2)]))
     | Func (Unit, R2') =>
       let val j0 = some_j0 in
@@ -648,7 +648,7 @@
                                                       (dom_schema @ ran_schema))
                                (#kk_subset kk ran_prod app)
         end
-    | _ => raise REP ("NitpickKodkod.func_from_no_opt_rel_expr",
+    | _ => raise REP ("Nitpick_Kodkod.func_from_no_opt_rel_expr",
                       [old_R, Func (R1, R2)])
 (* kodkod_constrs -> rep -> rep -> Kodkod.rel_expr -> Kodkod.rel_expr *)
 and rel_expr_from_rel_expr kk new_R old_R r =
@@ -657,7 +657,7 @@
     val unopt_new_R = unopt_rep new_R
   in
     if unopt_old_R <> old_R andalso unopt_new_R = new_R then
-      raise REP ("NitpickKodkod.rel_expr_from_rel_expr", [old_R, new_R])
+      raise REP ("Nitpick_Kodkod.rel_expr_from_rel_expr", [old_R, new_R])
     else if unopt_new_R = unopt_old_R then
       r
     else
@@ -666,7 +666,7 @@
        | Struct Rs => struct_from_rel_expr kk Rs
        | Vect (k, R') => vect_from_rel_expr kk k R'
        | Func (R1, R2) => func_from_no_opt_rel_expr kk R1 R2
-       | _ => raise REP ("NitpickKodkod.rel_expr_from_rel_expr",
+       | _ => raise REP ("Nitpick_Kodkod.rel_expr_from_rel_expr",
                          [old_R, new_R]))
           unopt_old_R r
   end
@@ -683,13 +683,13 @@
     else if is_lone_rep R andalso card_of_rep R > 1 then kk_lone (Kodkod.Rel x)
     else Kodkod.True
   | declarative_axiom_for_plain_rel _ u =
-    raise NUT ("NitpickKodkod.declarative_axiom_for_plain_rel", [u])
+    raise NUT ("Nitpick_Kodkod.declarative_axiom_for_plain_rel", [u])
 
 (* nut NameTable.table -> styp -> Kodkod.rel_expr * rep * int *)
 fun const_triple rel_table (x as (s, T)) =
   case the_name rel_table (ConstName (s, T, Any)) of
     FreeRel ((n, j), _, R, _) => (Kodkod.Rel (n, j), R, n)
-  | _ => raise TERM ("NitpickKodkod.const_triple", [Const x])
+  | _ => raise TERM ("Nitpick_Kodkod.const_triple", [Const x])
 
 (* nut NameTable.table -> styp -> Kodkod.rel_expr *)
 fun discr_rel_expr rel_table = #1 o const_triple rel_table o discr_for_constr
@@ -849,7 +849,8 @@
                       (~1 upto num_sels - 1)
     val j0 = case triples |> hd |> #2 of
                Func (Atom (_, j0), _) => j0
-             | R => raise REP ("NitpickKodkod.uniqueness_axiom_for_constr", [R])
+             | R => raise REP ("Nitpick_Kodkod.uniqueness_axiom_for_constr",
+                               [R])
     val set_r = triples |> hd |> #1
   in
     if num_sels = 0 then
@@ -960,7 +961,7 @@
            let val opt1 = is_opt_rep (rep_of u1) in
              case polar of
                Neut => if opt1 then
-                         raise NUT ("NitpickKodkod.to_f (Finite)", [u])
+                         raise NUT ("Nitpick_Kodkod.to_f (Finite)", [u])
                        else
                          Kodkod.True
              | Pos => formula_for_bool (not opt1)
@@ -992,7 +993,7 @@
              if not (is_opt_rep ran_R) then
                to_set_bool_op kk_implies kk_subset u1 u2
              else if polar = Neut then
-               raise NUT ("NitpickKodkod.to_f (Subset)", [u])
+               raise NUT ("Nitpick_Kodkod.to_f (Subset)", [u])
              else
                let
                  (* bool -> nut -> Kodkod.rel_expr *)
@@ -1102,16 +1103,16 @@
          | Op3 (If, _, _, u1, u2, u3) =>
            kk_formula_if (to_f u1) (to_f u2) (to_f u3)
          | FormulaReg (j, _, _) => Kodkod.FormulaReg j
-         | _ => raise NUT ("NitpickKodkod.to_f", [u]))
+         | _ => raise NUT ("Nitpick_Kodkod.to_f", [u]))
       | Atom (2, j0) => formula_from_atom j0 (to_r u)
-      | _ => raise NUT ("NitpickKodkod.to_f", [u])
+      | _ => raise NUT ("Nitpick_Kodkod.to_f", [u])
     (* polarity -> nut -> Kodkod.formula *)
     and to_f_with_polarity polar u =
       case rep_of u of
         Formula _ => to_f u
       | Atom (2, j0) => formula_from_atom j0 (to_r u)
       | Opt (Atom (2, j0)) => formula_from_opt_atom polar j0 (to_r u)
-      | _ => raise NUT ("NitpickKodkod.to_f_with_polarity", [u])
+      | _ => raise NUT ("Nitpick_Kodkod.to_f_with_polarity", [u])
     (* nut -> Kodkod.rel_expr *)
     and to_r u =
       case u of
@@ -1142,12 +1143,12 @@
       | Cst (Num j, @{typ int}, R) =>
          (case atom_for_int (card_of_rep R, offset_of_type ofs int_T) j of
             ~1 => if is_opt_rep R then Kodkod.None
-                  else raise NUT ("NitpickKodkod.to_r (Num)", [u])
+                  else raise NUT ("Nitpick_Kodkod.to_r (Num)", [u])
           | j' => Kodkod.Atom j')
       | Cst (Num j, T, R) =>
         if j < card_of_rep R then Kodkod.Atom (j + offset_of_type ofs T)
         else if is_opt_rep R then Kodkod.None
-        else raise NUT ("NitpickKodkod.to_r", [u])
+        else raise NUT ("Nitpick_Kodkod.to_r", [u])
       | Cst (Unknown, _, R) => empty_rel_for_rep R
       | Cst (Unrep, _, R) => empty_rel_for_rep R
       | Cst (Suc, T, Func (Atom x, _)) =>
@@ -1177,7 +1178,7 @@
               (kk_product (Kodkod.AtomSeq (max_int_for_card int_k + 1, nat_j0))
                           Kodkod.Univ)
         else
-          raise BAD ("NitpickKodkod.to_r (NatToInt)", "\"nat_j0 <> int_j0\"")
+          raise BAD ("Nitpick_Kodkod.to_r (NatToInt)", "\"nat_j0 <> int_j0\"")
       | Cst (IntToNat, _, Func (Atom (int_k, int_j0), nat_R)) =>
         let
           val abs_card = max_int_for_card int_k + 1
@@ -1192,7 +1193,7 @@
                           (kk_product (Kodkod.AtomSeq (overlap, int_j0))
                                       Kodkod.Univ))
           else
-            raise BAD ("NitpickKodkod.to_r (IntToNat)", "\"nat_j0 <> int_j0\"")
+            raise BAD ("Nitpick_Kodkod.to_r (IntToNat)", "\"nat_j0 <> int_j0\"")
         end
       | Op1 (Not, _, R, u1) => kk_not3 (to_rep R u1)
       | Op1 (Finite, _, Opt (Atom _), _) => Kodkod.None
@@ -1204,10 +1205,10 @@
               Func (Struct [R1, R2], _) => (R1, R2)
             | Func (R1, _) =>
               if card_of_rep R1 <> 1 then
-                raise REP ("NitpickKodkod.to_r (Converse)", [R])
+                raise REP ("Nitpick_Kodkod.to_r (Converse)", [R])
               else
                 pairself (Atom o pair 1 o offset_of_type ofs) (b_T, a_T)
-            | _ => raise REP ("NitpickKodkod.to_r (Converse)", [R])
+            | _ => raise REP ("Nitpick_Kodkod.to_r (Converse)", [R])
           val body_R = body_rep R
           val a_arity = arity_of_rep a_R
           val b_arity = arity_of_rep b_R
@@ -1257,7 +1258,7 @@
                             (rel_expr_to_func kk R1 bool_atom_R
                                               (Func (R1, Formula Neut)) r))
                (to_opt R1 u1)
-         | _ => raise NUT ("NitpickKodkod.to_r (SingletonSet)", [u]))
+         | _ => raise NUT ("Nitpick_Kodkod.to_r (SingletonSet)", [u]))
       | Op1 (Tha, T, R, u1) =>
         if is_opt_rep R then
           kk_join (to_rep (Func (unopt_rep R, Opt bool_atom_R)) u1) true_atom
@@ -1384,7 +1385,7 @@
                  kk_product (kk_join (do_nut r a_R b_R u2)
                                      (do_nut r b_R c_R u1)) r
              in kk_union (do_term true_atom) (do_term false_atom) end
-           | _ => raise NUT ("NitpickKodkod.to_r (Composition)", [u]))
+           | _ => raise NUT ("Nitpick_Kodkod.to_r (Composition)", [u]))
           |> rel_expr_from_rel_expr kk R (Func (Struct [a_R, c_R], body_R))
         end
       | Op2 (Product, T, R, u1, u2) =>
@@ -1408,7 +1409,7 @@
                fun do_term r =
                  kk_product (kk_product (do_nut r a_R u1) (do_nut r b_R u2)) r
              in kk_union (do_term true_atom) (do_term false_atom) end
-           | _ => raise NUT ("NitpickKodkod.to_r (Product)", [u]))
+           | _ => raise NUT ("Nitpick_Kodkod.to_r (Product)", [u]))
           |> rel_expr_from_rel_expr kk R (Func (Struct [a_R, b_R], body_R))
         end
       | Op2 (Image, T, R, u1, u2) =>
@@ -1437,8 +1438,8 @@
                  rel_expr_from_rel_expr kk R core_R core_r
              end
            else
-             raise NUT ("NitpickKodkod.to_r (Image)", [u1, u2])
-         | _ => raise NUT ("NitpickKodkod.to_r (Image)", [u1, u2]))
+             raise NUT ("Nitpick_Kodkod.to_r (Image)", [u1, u2])
+         | _ => raise NUT ("Nitpick_Kodkod.to_r (Image)", [u1, u2]))
       | Op2 (Apply, @{typ nat}, _,
              Op2 (Apply, _, _, Cst (Subtract, _, _), u1), u2) =>
         if is_Cst Unrep u2 andalso not (is_opt_rep (rep_of u1)) then
@@ -1492,7 +1493,7 @@
             | us' =>
               kk_rel_if (kk_some (fold1 kk_product (map to_r us')))
                         (Kodkod.Atom j0) Kodkod.None)
-         | _ => raise NUT ("NitpickKodkod.to_r (Tuple)", [u]))
+         | _ => raise NUT ("Nitpick_Kodkod.to_r (Tuple)", [u]))
       | Construct ([u'], _, _, []) => to_r u'
       | Construct (_ :: sel_us, T, R, arg_us) =>
         let
@@ -1516,23 +1517,23 @@
       | BoundRel (x, _, _, _) => Kodkod.Var x
       | FreeRel (x, _, _, _) => Kodkod.Rel x
       | RelReg (j, _, R) => Kodkod.RelReg (arity_of_rep R, j)
-      | u => raise NUT ("NitpickKodkod.to_r", [u])
+      | u => raise NUT ("Nitpick_Kodkod.to_r", [u])
     (* nut -> Kodkod.decl *)
     and to_decl (BoundRel (x, _, R, _)) =
         Kodkod.DeclOne (x, Kodkod.AtomSeq (the_single (atom_schema_of_rep R)))
-      | to_decl u = raise NUT ("NitpickKodkod.to_decl", [u])
+      | to_decl u = raise NUT ("Nitpick_Kodkod.to_decl", [u])
     (* nut -> Kodkod.expr_assign *)
     and to_expr_assign (FormulaReg (j, _, R)) u =
         Kodkod.AssignFormulaReg (j, to_f u)
       | to_expr_assign (RelReg (j, _, R)) u =
         Kodkod.AssignRelReg ((arity_of_rep R, j), to_r u)
-      | to_expr_assign u1 _ = raise NUT ("NitpickKodkod.to_expr_assign", [u1])
+      | to_expr_assign u1 _ = raise NUT ("Nitpick_Kodkod.to_expr_assign", [u1])
     (* int * int -> nut -> Kodkod.rel_expr *)
     and to_atom (x as (k, j0)) u =
       case rep_of u of
         Formula _ => atom_from_formula kk j0 (to_f u)
       | Unit => if k = 1 then Kodkod.Atom j0
-                else raise NUT ("NitpickKodkod.to_atom", [u])
+                else raise NUT ("Nitpick_Kodkod.to_atom", [u])
       | R => atom_from_rel_expr kk x R (to_r u)
     (* rep list -> nut -> Kodkod.rel_expr *)
     and to_struct Rs u =
@@ -1563,7 +1564,7 @@
       | to_rep (Vect (k, R)) u = to_vect k R u
       | to_rep (Func (R1, R2)) u = to_func R1 R2 u
       | to_rep (Opt R) u = to_opt R u
-      | to_rep R _ = raise REP ("NitpickKodkod.to_rep", [R])
+      | to_rep R _ = raise REP ("Nitpick_Kodkod.to_rep", [R])
     (* nut -> Kodkod.rel_expr *)
     and to_integer u = to_opt (one_rep ofs (type_of u) (rep_of u)) u
     (* nut list -> rep -> Kodkod.rel_expr -> Kodkod.rel_expr *)
@@ -1593,7 +1594,7 @@
     (* rep list -> nut list -> Kodkod.rel_expr *)
     and to_product Rs us =
       case map (uncurry to_opt) (filter (not_equal Unit o fst) (Rs ~~ us)) of
-        [] => raise REP ("NitpickKodkod.to_product", Rs)
+        [] => raise REP ("Nitpick_Kodkod.to_product", Rs)
       | rs => fold1 kk_product rs
     (* int -> typ -> rep -> nut -> Kodkod.rel_expr *)
     and to_nth_pair_sel n res_T res_R u =
@@ -1639,7 +1640,7 @@
           connective (formula_from_atom j0 r1) (formula_from_atom j0 r2)
         | Func (R1, Atom _) => set_oper (kk_join r1 true_atom)
                                         (kk_join r2 true_atom)
-        | _ => raise REP ("NitpickKodkod.to_set_bool_op", [min_R])
+        | _ => raise REP ("Nitpick_Kodkod.to_set_bool_op", [min_R])
       end
     (* (Kodkod.formula -> Kodkod.formula -> Kodkod.formula)
        -> (Kodkod.rel_expr -> Kodkod.rel_expr -> Kodkod.rel_expr)
@@ -1676,7 +1677,7 @@
                                                                 neg_second)))
                                 false_atom))
                    r1 r2
-             | _ => raise REP ("NitpickKodkod.to_set_op", [min_R]))
+             | _ => raise REP ("Nitpick_Kodkod.to_set_op", [min_R]))
       end
     (* rep -> rep -> Kodkod.rel_expr -> nut -> Kodkod.rel_expr *)
     and to_apply res_R func_u arg_u =
@@ -1713,7 +1714,7 @@
         rel_expr_from_rel_expr kk res_R R2
             (kk_n_fold_join kk true R1 R2 (to_opt R1 arg_u) (to_r func_u))
         |> body_rep R2 = Formula Neut ? to_guard [arg_u] res_R
-      | _ => raise NUT ("NitpickKodkod.to_apply", [func_u])
+      | _ => raise NUT ("Nitpick_Kodkod.to_apply", [func_u])
     (* int -> rep -> rep -> Kodkod.rel_expr -> nut *)
     and to_apply_vect k R' res_R func_r arg_u =
       let
--- a/src/HOL/Tools/Nitpick/nitpick_model.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_model.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -7,9 +7,9 @@
 
 signature NITPICK_MODEL =
 sig
-  type scope = NitpickScope.scope
-  type rep = NitpickRep.rep
-  type nut = NitpickNut.nut
+  type scope = Nitpick_Scope.scope
+  type rep = Nitpick_Rep.rep
+  type nut = Nitpick_Nut.nut
 
   type params = {
     show_skolems: bool,
@@ -29,15 +29,15 @@
     -> Kodkod.raw_bound list -> term -> bool option
 end;
 
-structure NitpickModel : NITPICK_MODEL =
+structure Nitpick_Model : NITPICK_MODEL =
 struct
 
-open NitpickUtil
-open NitpickHOL
-open NitpickScope
-open NitpickPeephole
-open NitpickRep
-open NitpickNut
+open Nitpick_Util
+open Nitpick_HOL
+open Nitpick_Scope
+open Nitpick_Peephole
+open Nitpick_Rep
+open Nitpick_Nut
 
 type params = {
   show_skolems: bool,
@@ -57,7 +57,7 @@
     prefix ^ substring (short_name s, 0, 1) ^ nat_subscript (j + 1)
   | atom_name prefix (T as TFree (s, _)) j =
     prefix ^ perhaps (try (unprefix "'")) s ^ nat_subscript (j + 1)
-  | atom_name _ T _ = raise TYPE ("NitpickModel.atom_name", [T], [])
+  | atom_name _ T _ = raise TYPE ("Nitpick_Model.atom_name", [T], [])
 (* bool -> typ -> int -> term *)
 fun atom for_auto T j =
   if for_auto then
@@ -130,7 +130,7 @@
     fun aux (Const (s, _)) = (s <> non_opt_name, ([], []))
       | aux (Const (@{const_name fun_upd}, _) $ t0 $ t1 $ t2) =
         let val (s, (ts1, ts2)) = aux t0 in (s, (t1 :: ts1, t2 :: ts2)) end
-      | aux t = raise TERM ("NitpickModel.dest_plain_fun", [t])
+      | aux t = raise TERM ("Nitpick_Model.dest_plain_fun", [t])
   in apsnd (pairself rev) o aux end
 
 (* typ -> term -> term list * term *)
@@ -138,7 +138,7 @@
                  (Const (@{const_name Pair}, _) $ t1 $ t2) =
     break_in_two T2 t2 |>> cons t1
   | break_in_two _ (Const (@{const_name Pair}, _) $ t1 $ t2) = ([t1], t2)
-  | break_in_two _ t = raise TERM ("NitpickModel.break_in_two", [t])
+  | break_in_two _ t = raise TERM ("Nitpick_Model.break_in_two", [t])
 (* typ -> term -> term -> term *)
 fun pair_up (Type ("*", [T1', T2']))
             (t1 as Const (@{const_name Pair},
@@ -180,7 +180,7 @@
                  [T1' --> T2', T1', T2'] ---> T1' --> T2')
           $ do_arrow T1' T2' T1 T2 t0 $ do_term T1' T1 t1 $ do_term T2' T2 t2
         | do_arrow _ _ _ _ t =
-          raise TERM ("NitpickModel.typecast_fun.do_arrow", [t])
+          raise TERM ("Nitpick_Model.typecast_fun.do_arrow", [t])
       and do_fun T1' T2' T1 T2 t =
         case factor_out_types T1' T1 of
           ((_, NONE), (_, NONE)) => t |> do_arrow T1' T2' T1 T2
@@ -188,7 +188,7 @@
           t |> do_curry T1a T1b T2 |> do_arrow T1' T2' T1a (T1b --> T2)
         | ((T1a', SOME T1b'), (_, NONE)) =>
           t |> do_arrow T1a' (T1b' --> T2') T1 T2 |> do_uncurry T1' T2'
-        | _ => raise TYPE ("NitpickModel.typecast_fun.do_fun", [T1, T1'], [])
+        | _ => raise TYPE ("Nitpick_Model.typecast_fun.do_fun", [T1, T1'], [])
       (* typ -> typ -> term -> term *)
       and do_term (Type ("fun", [T1', T2'])) (Type ("fun", [T1, T2])) t =
           do_fun T1' T2' T1 T2 t
@@ -198,9 +198,9 @@
           $ do_term T1' T1 t1 $ do_term T2' T2 t2
         | do_term T' T t =
           if T = T' then t
-          else raise TYPE ("NitpickModel.typecast_fun.do_term", [T, T'], [])
+          else raise TYPE ("Nitpick_Model.typecast_fun.do_term", [T, T'], [])
     in if T1' = T1 andalso T2' = T2 then t else do_fun T1' T2' T1 T2 t end
-  | typecast_fun T' _ _ _ = raise TYPE ("NitpickModel.typecast_fun", [T'], [])
+  | typecast_fun T' _ _ _ = raise TYPE ("Nitpick_Model.typecast_fun", [T'], [])
 
 (* term -> string *)
 fun truth_const_sort_key @{const True} = "0"
@@ -302,7 +302,7 @@
           term_for_rep seen T T' (Vect (k1, Atom (k2, 0)))
                        [nth_combination (replicate k1 (k2, 0)) j]
           handle General.Subscript =>
-                 raise ARG ("NitpickModel.reconstruct_term.term_for_atom",
+                 raise ARG ("Nitpick_Model.reconstruct_term.term_for_atom",
                             signed_string_of_int j ^ " for " ^
                             string_for_rep (Vect (k1, Atom (k2, 0))))
         end
@@ -350,7 +350,7 @@
               map (fn x => get_first
                                (fn ConstName (s', T', R) =>
                                    if (s', T') = x then SOME R else NONE
-                                 | u => raise NUT ("NitpickModel.reconstruct_\
+                                 | u => raise NUT ("Nitpick_Model.reconstruct_\
                                                    \term.term_for_atom", [u]))
                                sel_names |> the) sel_xs
             val arg_Rs = map (snd o dest_Func) sel_Rs
@@ -389,7 +389,7 @@
                                  | n2 => Const (@{const_name HOL.divide},
                                                 [num_T, num_T] ---> num_T)
                                          $ mk_num n1 $ mk_num n2)
-                      | _ => raise TERM ("NitpickModel.reconstruct_term.term_\
+                      | _ => raise TERM ("Nitpick_Model.reconstruct_term.term_\
                                          \for_atom (Abs_Frac)", ts)
                     end
                   else if not for_auto andalso is_abs_fun thy constr_x then
@@ -421,7 +421,7 @@
     and term_for_rep seen T T' Unit [[]] = term_for_atom seen T T' 0
       | term_for_rep seen T T' (R as Atom (k, j0)) [[j]] =
         if j >= j0 andalso j < j0 + k then term_for_atom seen T T' (j - j0)
-        else raise REP ("NitpickModel.reconstruct_term.term_for_rep", [R])
+        else raise REP ("Nitpick_Model.reconstruct_term.term_for_rep", [R])
       | term_for_rep seen (Type ("*", [T1, T2])) _ (Struct [R1, R2]) [js] =
         let
           val arity1 = arity_of_rep R1
@@ -454,7 +454,7 @@
       | term_for_rep seen T T' (Opt R) jss =
         if null jss then Const (unknown, T) else term_for_rep seen T T' R jss
       | term_for_rep seen T _ R jss =
-        raise ARG ("NitpickModel.reconstruct_term.term_for_rep",
+        raise ARG ("Nitpick_Model.reconstruct_term.term_for_rep",
                    Refute.string_of_typ T ^ " " ^ string_for_rep R ^ " " ^
                    string_of_int (length jss))
   in
@@ -576,7 +576,7 @@
             (assign_operator_for_const (s, T),
              user_friendly_const ext_ctxt (base_name, step_name) formats (s, T),
              T)
-          | _ => raise NUT ("NitpickModel.reconstruct_hol_model.\
+          | _ => raise NUT ("Nitpick_Model.reconstruct_hol_model.\
                             \pretty_for_assign", [name])
         val t2 = if rep_of name = Any then
                    Const (@{const_name undefined}, T')
@@ -601,7 +601,7 @@
     fun integer_datatype T =
       [{typ = T, card = card_of_type card_assigns T, co = false,
         precise = false, constrs = []}]
-      handle TYPE ("NitpickHOL.card_of_type", _, _) => []
+      handle TYPE ("Nitpick_HOL.card_of_type", _, _) => []
     val (codatatypes, datatypes) =
       List.partition #co datatypes
       ||> append (integer_datatype nat_T @ integer_datatype int_T)
@@ -637,7 +637,7 @@
                           free_names of
                 [name] => name
               | [] => FreeName (s, T, Any)
-              | _ => raise TERM ("NitpickModel.reconstruct_hol_model",
+              | _ => raise TERM ("Nitpick_Model.reconstruct_hol_model",
                                  [Const x])) all_frees
     val chunks = block_of_names true "Free variable" free_names @
                  block_of_names show_skolems "Skolem constant" skolem_names @
--- a/src/HOL/Tools/Nitpick/nitpick_mono.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_mono.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -7,17 +7,17 @@
 
 signature NITPICK_MONO =
 sig
-  type extended_context = NitpickHOL.extended_context
+  type extended_context = Nitpick_HOL.extended_context
 
   val formulas_monotonic :
     extended_context -> typ -> term list -> term list -> term -> bool
 end;
 
-structure NitpickMono : NITPICK_MONO =
+structure Nitpick_Mono : NITPICK_MONO =
 struct
 
-open NitpickUtil
-open NitpickHOL
+open Nitpick_Util
+open Nitpick_HOL
 
 type var = int
 
@@ -363,11 +363,11 @@
                   accum =
     (accum |> fold (uncurry (do_ctype_comp cmp xs)) [(C11, C21), (C12, C22)]
      handle Library.UnequalLengths =>
-            raise CTYPE ("NitpickMono.do_ctype_comp", [C1, C2]))
+            raise CTYPE ("Nitpick_Mono.do_ctype_comp", [C1, C2]))
   | do_ctype_comp cmp xs (CType _) (CType _) accum =
     accum (* no need to compare them thanks to the cache *)
   | do_ctype_comp _ _ C1 C2 _ =
-    raise CTYPE ("NitpickMono.do_ctype_comp", [C1, C2])
+    raise CTYPE ("Nitpick_Mono.do_ctype_comp", [C1, C2])
 
 (* comp_op -> ctype -> ctype -> constraint_set -> constraint_set *)
 fun add_ctype_comp _ _ _ UnsolvableCSet = UnsolvableCSet
@@ -413,7 +413,7 @@
   | do_notin_ctype_fv sn sexp (CType (_, Cs)) accum =
     accum |> fold (do_notin_ctype_fv sn sexp) Cs
   | do_notin_ctype_fv _ _ C _ =
-    raise CTYPE ("NitpickMono.do_notin_ctype_fv", [C])
+    raise CTYPE ("Nitpick_Mono.do_notin_ctype_fv", [C])
 
 (* sign -> ctype -> constraint_set -> constraint_set *)
 fun add_notin_ctype_fv _ _ UnsolvableCSet = UnsolvableCSet
@@ -584,13 +584,13 @@
       case ctype_for (nth_range_type 2 T) of
         C as CPair (a_C, b_C) =>
         (CFun (a_C, S Neg, CFun (b_C, S Neg, C)), accum)
-      | C => raise CTYPE ("NitpickMono.consider_term.do_pair_constr", [C])
+      | C => raise CTYPE ("Nitpick_Mono.consider_term.do_pair_constr", [C])
     (* int -> typ -> accumulator -> ctype * accumulator *)
     fun do_nth_pair_sel n T =
       case ctype_for (domain_type T) of
         C as CPair (a_C, b_C) =>
         pair (CFun (C, S Neg, if n = 0 then a_C else b_C))
-      | C => raise CTYPE ("NitpickMono.consider_term.do_nth_pair_sel", [C])
+      | C => raise CTYPE ("Nitpick_Mono.consider_term.do_nth_pair_sel", [C])
     val unsolvable = (CType ("unsolvable", []), unsolvable_accum)
     (* typ -> term -> accumulator -> ctype * accumulator *)
     fun do_bounded_quantifier abs_T bound_t body_t accum =
@@ -770,7 +770,7 @@
              | _ => case C1 of
                       CFun (C11, _, C12) =>
                       (C12, accum ||> add_is_sub_ctype C2 C11)
-                    | _ => raise CTYPE ("NitpickMono.consider_term.do_term \
+                    | _ => raise CTYPE ("Nitpick_Mono.consider_term.do_term \
                                         \(op $)", [C1])
            end)
         |> tap (fn (C, _) =>
@@ -906,7 +906,7 @@
           | Const (@{const_name "op ="}, _) $ t1 $ t2 => do_equals t1 t2 accum
           | @{const "op &"} $ t1 $ t2 => accum |> do_formula t1 |> do_formula t2
           | @{const "op -->"} $ t1 $ t2 => do_implies t1 t2 accum
-          | _ => raise TERM ("NitpickMono.consider_definitional_axiom.\
+          | _ => raise TERM ("Nitpick_Mono.consider_definitional_axiom.\
                              \do_formula", [t])
     in do_formula t end
 
--- a/src/HOL/Tools/Nitpick/nitpick_nut.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_nut.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -7,11 +7,11 @@
 
 signature NITPICK_NUT =
 sig
-  type special_fun = NitpickHOL.special_fun
-  type extended_context = NitpickHOL.extended_context
-  type scope = NitpickScope.scope
-  type name_pool = NitpickPeephole.name_pool
-  type rep = NitpickRep.rep
+  type special_fun = Nitpick_HOL.special_fun
+  type extended_context = Nitpick_HOL.extended_context
+  type scope = Nitpick_Scope.scope
+  type name_pool = Nitpick_Peephole.name_pool
+  type rep = Nitpick_Rep.rep
 
   datatype cst =
     Unity |
@@ -121,14 +121,14 @@
   val rename_vars_in_nut : name_pool -> nut NameTable.table -> nut -> nut
 end;
 
-structure NitpickNut : NITPICK_NUT =
+structure Nitpick_Nut : NITPICK_NUT =
 struct
 
-open NitpickUtil
-open NitpickHOL
-open NitpickScope
-open NitpickPeephole
-open NitpickRep
+open Nitpick_Util
+open Nitpick_HOL
+open Nitpick_Scope
+open Nitpick_Peephole
+open Nitpick_Rep
 
 datatype cst =
   Unity |
@@ -357,16 +357,16 @@
   | nickname_of (ConstName (s, _, _)) = s
   | nickname_of (BoundRel (_, _, _, nick)) = nick
   | nickname_of (FreeRel (_, _, _, nick)) = nick
-  | nickname_of u = raise NUT ("NitpickNut.nickname_of", [u])
+  | nickname_of u = raise NUT ("Nitpick_Nut.nickname_of", [u])
 
 (* nut -> bool *)
 fun is_skolem_name u =
   space_explode name_sep (nickname_of u)
   |> exists (String.isPrefix skolem_prefix)
-  handle NUT ("NitpickNut.nickname_of", _) => false
+  handle NUT ("Nitpick_Nut.nickname_of", _) => false
 fun is_eval_name u =
   String.isPrefix eval_prefix (nickname_of u)
-  handle NUT ("NitpickNut.nickname_of", _) => false
+  handle NUT ("Nitpick_Nut.nickname_of", _) => false
 (* cst -> nut -> bool *)
 fun is_Cst cst (Cst (cst', _, _)) = (cst = cst')
   | is_Cst _ _ = false
@@ -407,7 +407,7 @@
     (case fast_string_ord (s1, s2) of
        EQUAL => TermOrd.typ_ord (T1, T2)
      | ord => ord)
-  | name_ord (u1, u2) = raise NUT ("NitpickNut.name_ord", [u1, u2])
+  | name_ord (u1, u2) = raise NUT ("Nitpick_Nut.name_ord", [u1, u2])
 
 (* nut -> nut -> int *)
 fun num_occs_in_nut needle_u stack_u =
@@ -430,7 +430,7 @@
 fun modify_name_rep (BoundName (j, T, _, nick)) R = BoundName (j, T, R, nick)
   | modify_name_rep (FreeName (s, T, _)) R = FreeName (s, T, R)
   | modify_name_rep (ConstName (s, T, _)) R = ConstName (s, T, R)
-  | modify_name_rep u _ = raise NUT ("NitpickNut.modify_name_rep", [u])
+  | modify_name_rep u _ = raise NUT ("Nitpick_Nut.modify_name_rep", [u])
 
 structure NameTable = Table(type key = nut val ord = name_ord)
 
@@ -438,12 +438,12 @@
 fun the_name table name =
   case NameTable.lookup table name of
     SOME u => u
-  | NONE => raise NUT ("NitpickNut.the_name", [name])
+  | NONE => raise NUT ("Nitpick_Nut.the_name", [name])
 (* nut NameTable.table -> nut -> Kodkod.n_ary_index *)
 fun the_rel table name =
   case the_name table name of
     FreeRel (x, _, _, _) => x
-  | u => raise NUT ("NitpickNut.the_rel", [u])
+  | u => raise NUT ("Nitpick_Nut.the_rel", [u])
 
 (* typ * term -> typ * term *)
 fun mk_fst (_, Const (@{const_name Pair}, T) $ t1 $ _) = (domain_type T, t1)
@@ -669,13 +669,13 @@
             (case arity_of_built_in_const fast_descrs x of
                SOME n =>
                (case n - length ts of
-                  0 => raise TERM ("NitpickNut.nut_from_term.aux", [t])
+                  0 => raise TERM ("Nitpick_Nut.nut_from_term.aux", [t])
                 | k => if k > 0 then sub (eta_expand Ts t k)
                        else do_apply t0 ts)
              | NONE => if null ts then ConstName (s, T, Any)
                        else do_apply t0 ts)
         | (Free (s, T), []) => FreeName (s, T, Any)
-        | (Var _, []) => raise TERM ("NitpickNut.nut_from_term", [t])
+        | (Var _, []) => raise TERM ("Nitpick_Nut.nut_from_term", [t])
         | (Bound j, []) =>
           BoundName (length Ts - j - 1, nth Ts j, Any, nth ss j)
         | (Abs (s, T, t1), []) =>
@@ -1106,7 +1106,7 @@
                  else
                    unopt_rep R
              in s_op2 Lambda T R u1' u2' end
-           | R => raise NUT ("NitpickNut.aux.choose_reps_in_nut", [u]))
+           | R => raise NUT ("Nitpick_Nut.aux.choose_reps_in_nut", [u]))
         | Op2 (oper, T, _, u1, u2) =>
           if oper mem [All, Exist] then
             let
@@ -1274,9 +1274,9 @@
   | shape_tuple (T as Type ("fun", [_, T2])) (R as Vect (k, R')) us =
     Tuple (T, R, map (shape_tuple T2 R') (batch_list (length us div k) us))
   | shape_tuple T R [u] =
-    if type_of u = T then u else raise NUT ("NitpickNut.shape_tuple", [u])
+    if type_of u = T then u else raise NUT ("Nitpick_Nut.shape_tuple", [u])
   | shape_tuple T Unit [] = Cst (Unity, T, Unit)
-  | shape_tuple _ _ us = raise NUT ("NitpickNut.shape_tuple", us)
+  | shape_tuple _ _ us = raise NUT ("Nitpick_Nut.shape_tuple", us)
 
 (* bool -> nut -> nut list * name_pool * nut NameTable.table
    -> nut list * name_pool * nut NameTable.table *)
--- a/src/HOL/Tools/Nitpick/nitpick_peephole.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_peephole.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -86,11 +86,11 @@
   val kodkod_constrs : bool -> int -> int -> int -> kodkod_constrs
 end;
 
-structure NitpickPeephole : NITPICK_PEEPHOLE =
+structure Nitpick_Peephole : NITPICK_PEEPHOLE =
 struct
 
 open Kodkod
-open NitpickUtil
+open Nitpick_Util
 
 type name_pool = {
   rels: n_ary_index list,
@@ -188,20 +188,20 @@
     if is_none_product r1 orelse is_none_product r2 then SOME false else NONE
 
 (* int -> rel_expr *)
-fun empty_n_ary_rel 0 = raise ARG ("NitpickPeephole.empty_n_ary_rel", "0")
+fun empty_n_ary_rel 0 = raise ARG ("Nitpick_Peephole.empty_n_ary_rel", "0")
   | empty_n_ary_rel n = funpow (n - 1) (curry Product None) None
 
 (* decl -> rel_expr *)
 fun decl_one_set (DeclOne (_, r)) = r
   | decl_one_set _ =
-    raise ARG ("NitpickPeephole.decl_one_set", "not \"DeclOne\"")
+    raise ARG ("Nitpick_Peephole.decl_one_set", "not \"DeclOne\"")
 
 (* int_expr -> bool *)
 fun is_Num (Num _) = true
   | is_Num _ = false
 (* int_expr -> int *)
 fun dest_Num (Num k) = k
-  | dest_Num _ = raise ARG ("NitpickPeephole.dest_Num", "not \"Num\"")
+  | dest_Num _ = raise ARG ("Nitpick_Peephole.dest_Num", "not \"Num\"")
 (* int -> int -> int_expr list *)
 fun num_seq j0 n = map Num (index_seq j0 n)
 
--- a/src/HOL/Tools/Nitpick/nitpick_rep.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_rep.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -7,8 +7,8 @@
 
 signature NITPICK_REP =
 sig
-  type polarity = NitpickUtil.polarity
-  type scope = NitpickScope.scope
+  type polarity = Nitpick_Util.polarity
+  type scope = Nitpick_Scope.scope
 
   datatype rep =
     Any |
@@ -58,12 +58,12 @@
   val all_combinations_for_reps : rep list -> int list list
 end;
 
-structure NitpickRep : NITPICK_REP =
+structure Nitpick_Rep : NITPICK_REP =
 struct
 
-open NitpickUtil
-open NitpickHOL
-open NitpickScope
+open Nitpick_Util
+open Nitpick_HOL
+open Nitpick_Scope
 
 datatype rep =
   Any |
@@ -111,7 +111,7 @@
   | is_opt_rep _ = false
 
 (* rep -> int *)
-fun card_of_rep Any = raise REP ("NitpickRep.card_of_rep", [Any])
+fun card_of_rep Any = raise REP ("Nitpick_Rep.card_of_rep", [Any])
   | card_of_rep (Formula _) = 2
   | card_of_rep Unit = 1
   | card_of_rep (Atom (k, _)) = k
@@ -120,7 +120,7 @@
   | card_of_rep (Func (R1, R2)) =
     reasonable_power (card_of_rep R2) (card_of_rep R1)
   | card_of_rep (Opt R) = card_of_rep R
-fun arity_of_rep Any = raise REP ("NitpickRep.arity_of_rep", [Any])
+fun arity_of_rep Any = raise REP ("Nitpick_Rep.arity_of_rep", [Any])
   | arity_of_rep (Formula _) = 0
   | arity_of_rep Unit = 0
   | arity_of_rep (Atom _) = 1
@@ -129,7 +129,7 @@
   | arity_of_rep (Func (R1, R2)) = arity_of_rep R1 + arity_of_rep R2
   | arity_of_rep (Opt R) = arity_of_rep R
 fun min_univ_card_of_rep Any =
-    raise REP ("NitpickRep.min_univ_card_of_rep", [Any])
+    raise REP ("Nitpick_Rep.min_univ_card_of_rep", [Any])
   | min_univ_card_of_rep (Formula _) = 0
   | min_univ_card_of_rep Unit = 0
   | min_univ_card_of_rep (Atom (k, j0)) = k + j0 + 1
@@ -151,7 +151,7 @@
 
 (* rep -> rep * rep *)
 fun dest_Func (Func z) = z
-  | dest_Func R = raise REP ("NitpickRep.dest_Func", [R])
+  | dest_Func R = raise REP ("Nitpick_Rep.dest_Func", [R])
 (* int Typtab.table -> typ -> (unit -> int) -> rep -> rep *)
 fun smart_range_rep _ _ _ Unit = Unit
   | smart_range_rep _ _ _ (Vect (_, R)) = R
@@ -162,7 +162,7 @@
     Atom (1, offset_of_type ofs T2)
   | smart_range_rep ofs (Type ("fun", [_, T2])) ran_card (Atom _) =
     Atom (ran_card (), offset_of_type ofs T2)
-  | smart_range_rep _ _ _ R = raise REP ("NitpickRep.smart_range_rep", [R])
+  | smart_range_rep _ _ _ R = raise REP ("Nitpick_Rep.smart_range_rep", [R])
 
 (* rep -> rep list *)
 fun binder_reps (Func (R1, R2)) = R1 :: binder_reps R2
@@ -177,7 +177,7 @@
   | flip_rep_polarity R = R
 
 (* int Typtab.table -> rep -> rep *)
-fun one_rep _ _ Any = raise REP ("NitpickRep.one_rep", [Any])
+fun one_rep _ _ Any = raise REP ("Nitpick_Rep.one_rep", [Any])
   | one_rep _ _ (Atom x) = Atom x
   | one_rep _ _ (Struct Rs) = Struct Rs
   | one_rep _ _ (Vect z) = Vect z
@@ -203,7 +203,7 @@
   else if polar2 = Neut then
     polar1
   else
-    raise ARG ("NitpickRep.min_polarity",
+    raise ARG ("Nitpick_Rep.min_polarity",
                commas (map (quote o string_for_polarity) [polar1, polar2]))
 
 (* It's important that Func is before Vect, because if the range is Opt we
@@ -236,7 +236,7 @@
     if k1 < k2 then Vect (k1, R1)
     else if k1 > k2 then Vect (k2, R2)
     else Vect (k1, min_rep R1 R2)
-  | min_rep R1 R2 = raise REP ("NitpickRep.min_rep", [R1, R2])
+  | min_rep R1 R2 = raise REP ("Nitpick_Rep.min_rep", [R1, R2])
 (* rep list -> rep list -> rep list *)
 and min_reps [] _ = []
   | min_reps _ [] = []
@@ -253,7 +253,7 @@
   | Vect (k, _) => k
   | Func (R1, _) => card_of_rep R1
   | Opt R => card_of_domain_from_rep ran_card R
-  | _ => raise REP ("NitpickRep.card_of_domain_from_rep", [R])
+  | _ => raise REP ("Nitpick_Rep.card_of_domain_from_rep", [R])
 
 (* int Typtab.table -> typ -> rep -> rep *)
 fun rep_to_binary_rel_rep ofs T R =
@@ -306,10 +306,10 @@
     (optable_rep ofs T1 (best_one_rep_for_type scope T1),
      optable_rep ofs T2 (best_one_rep_for_type scope T2))
   | best_non_opt_symmetric_reps_for_fun_type _ T =
-    raise TYPE ("NitpickRep.best_non_opt_symmetric_reps_for_fun_type", [T], [])
+    raise TYPE ("Nitpick_Rep.best_non_opt_symmetric_reps_for_fun_type", [T], [])
 
 (* rep -> (int * int) list *)
-fun atom_schema_of_rep Any = raise REP ("NitpickRep.atom_schema_of_rep", [Any])
+fun atom_schema_of_rep Any = raise REP ("Nitpick_Rep.atom_schema_of_rep", [Any])
   | atom_schema_of_rep (Formula _) = []
   | atom_schema_of_rep Unit = []
   | atom_schema_of_rep (Atom x) = [x]
@@ -332,7 +332,7 @@
   | type_schema_of_rep (Type ("fun", [T1, T2])) (Func (R1, R2)) =
     type_schema_of_rep T1 R1 @ type_schema_of_rep T2 R2
   | type_schema_of_rep T (Opt R) = type_schema_of_rep T R
-  | type_schema_of_rep T R = raise REP ("NitpickRep.type_schema_of_rep", [R])
+  | type_schema_of_rep T R = raise REP ("Nitpick_Rep.type_schema_of_rep", [R])
 (* typ list -> rep list -> typ list *)
 and type_schema_of_reps Ts Rs = flat (map2 type_schema_of_rep Ts Rs)
 
--- a/src/HOL/Tools/Nitpick/nitpick_scope.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_scope.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -7,7 +7,7 @@
 
 signature NITPICK_SCOPE =
 sig
-  type extended_context = NitpickHOL.extended_context
+  type extended_context = Nitpick_HOL.extended_context
 
   type constr_spec = {
     const: styp,
@@ -47,11 +47,11 @@
     -> int list -> typ list -> typ list -> scope list
 end;
 
-structure NitpickScope : NITPICK_SCOPE =
+structure Nitpick_Scope : NITPICK_SCOPE =
 struct
 
-open NitpickUtil
-open NitpickHOL
+open Nitpick_Util
+open Nitpick_HOL
 
 type constr_spec = {
   const: styp,
@@ -85,7 +85,7 @@
   List.find (equal T o #typ) dtypes
 
 (* dtype_spec list -> styp -> constr_spec *)
-fun constr_spec [] x = raise TERM ("NitpickScope.constr_spec", [Const x])
+fun constr_spec [] x = raise TERM ("Nitpick_Scope.constr_spec", [Const x])
   | constr_spec ({constrs, ...} :: dtypes : dtype_spec list) (x as (s, T)) =
     case List.find (equal (s, body_type T) o (apsnd body_type o #const))
                    constrs of
@@ -115,7 +115,7 @@
 (* scope -> typ -> int * int *)
 fun spec_of_type ({card_assigns, ofs, ...} : scope) T =
   (card_of_type card_assigns T
-   handle TYPE ("NitpickHOL.card_of_type", _, _) => ~1, offset_of_type ofs T)
+   handle TYPE ("Nitpick_HOL.card_of_type", _, _) => ~1, offset_of_type ofs T)
 
 (* (string -> string) -> scope
    -> string list * string list * string list * string list * string list *)
@@ -205,17 +205,17 @@
 fun lookup_ints_assign eq asgns key =
   case triple_lookup eq asgns key of
     SOME ks => ks
-  | NONE => raise ARG ("NitpickScope.lookup_ints_assign", "")
+  | NONE => raise ARG ("Nitpick_Scope.lookup_ints_assign", "")
 (* theory -> (typ option * int list) list -> typ -> int list *)
 fun lookup_type_ints_assign thy asgns T =
   map (curry Int.max 1) (lookup_ints_assign (type_match thy) asgns T)
-  handle ARG ("NitpickScope.lookup_ints_assign", _) =>
-         raise TYPE ("NitpickScope.lookup_type_ints_assign", [T], [])
+  handle ARG ("Nitpick_Scope.lookup_ints_assign", _) =>
+         raise TYPE ("Nitpick_Scope.lookup_type_ints_assign", [T], [])
 (* theory -> (styp option * int list) list -> styp -> int list *)
 fun lookup_const_ints_assign thy asgns x =
   lookup_ints_assign (const_match thy) asgns x
-  handle ARG ("NitpickScope.lookup_ints_assign", _) =>
-         raise TERM ("NitpickScope.lookup_const_ints_assign", [Const x])
+  handle ARG ("Nitpick_Scope.lookup_ints_assign", _) =>
+         raise TERM ("Nitpick_Scope.lookup_const_ints_assign", [Const x])
 
 (* theory -> (styp option * int list) list -> styp -> row option *)
 fun row_for_constr thy maxes_asgns constr =
@@ -315,7 +315,7 @@
       max < k
       orelse (forall (not_equal 0) precise_cards andalso doms_card () < k)
     end
-    handle TYPE ("NitpickHOL.card_of_type", _, _) => false
+    handle TYPE ("Nitpick_HOL.card_of_type", _, _) => false
 
 (* theory -> scope_desc -> bool *)
 fun is_surely_inconsistent_scope_description thy (desc as (card_asgns, _)) =
--- a/src/HOL/Tools/Nitpick/nitpick_tests.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_tests.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -10,15 +10,14 @@
   val run_all_tests : unit -> unit
 end
 
-structure NitpickTests =
+structure Nitpick_Tests =
 struct
 
-open NitpickUtil
-open NitpickPeephole
-open NitpickRep
-open NitpickNut
-open NitpickKodkod
-open Nitpick
+open Nitpick_Util
+open Nitpick_Peephole
+open Nitpick_Rep
+open Nitpick_Nut
+open Nitpick_Kodkod
 
 val settings =
   [("solver", "\"zChaff\""),
--- a/src/HOL/Tools/Nitpick/nitpick_util.ML	Tue Oct 27 13:51:22 2009 +0100
+++ b/src/HOL/Tools/Nitpick/nitpick_util.ML	Tue Oct 27 16:01:38 2009 +0100
@@ -72,7 +72,7 @@
   val maybe_quote : string -> string
 end
 
-structure NitpickUtil : NITPICK_UTIL =
+structure Nitpick_Util : NITPICK_UTIL =
 struct
 
 type styp = string * typ
@@ -107,7 +107,7 @@
   | reasonable_power 1 _ = 1
   | reasonable_power a b =
     if b < 0 orelse b > max_exponent then
-      raise LIMIT ("NitpickUtil.reasonable_power",
+      raise LIMIT ("Nitpick_Util.reasonable_power",
                    "too large exponent (" ^ signed_string_of_int b ^ ")")
     else
       let
@@ -123,7 +123,7 @@
     if reasonable_power m r = n then
       r
     else
-      raise ARG ("NitpickUtil.exact_log",
+      raise ARG ("Nitpick_Util.exact_log",
                  commas (map signed_string_of_int [m, n]))
   end
 
@@ -133,7 +133,7 @@
     if reasonable_power r m = n then
       r
     else
-      raise ARG ("NitpickUtil.exact_root",
+      raise ARG ("Nitpick_Util.exact_root",
                  commas (map signed_string_of_int [m, n]))
   end
 
@@ -156,7 +156,7 @@
     fun aux _ [] _ = []
       | aux i (j :: js) (x :: xs) =
         if i = j then x :: aux (i + 1) js xs else aux (i + 1) (j :: js) xs
-      | aux _ _ _ = raise ARG ("NitpickUtil.filter_indices",
+      | aux _ _ _ = raise ARG ("Nitpick_Util.filter_indices",
                                "indices unordered or out of range")
   in aux 0 js xs end
 fun filter_out_indices js xs =
@@ -165,7 +165,7 @@
     fun aux _ [] xs = xs
       | aux i (j :: js) (x :: xs) =
         if i = j then aux (i + 1) js xs else x :: aux (i + 1) (j :: js) xs
-      | aux _ _ _ = raise ARG ("NitpickUtil.filter_out_indices",
+      | aux _ _ _ = raise ARG ("Nitpick_Util.filter_out_indices",
                                "indices unordered or out of range")
   in aux 0 js xs end
 
@@ -303,5 +303,5 @@
 
 end;
 
-structure BasicNitpickUtil : BASIC_NITPICK_UTIL = NitpickUtil;
-open BasicNitpickUtil;
+structure Basic_Nitpick_Util : BASIC_NITPICK_UTIL = Nitpick_Util;
+open Basic_Nitpick_Util;