# HG changeset patch # User blanchet # Date 1402527649 -7200 # Node ID 4c2156fdfe717ee132dd605fa77784c944450a23 # Parent c22ad39c3b4bada99c6bb0595c84ed81a58b79a2 made lookup more robust in the face of missing (dummy) case constant diff -r c22ad39c3b4b -r 4c2156fdfe71 src/HOL/Tools/Nitpick/nitpick_hol.ML --- a/src/HOL/Tools/Nitpick/nitpick_hol.ML Thu Jun 12 01:00:49 2014 +0200 +++ b/src/HOL/Tools/Nitpick/nitpick_hol.ML Thu Jun 12 01:00:49 2014 +0200 @@ -1493,21 +1493,19 @@ fun unfold_mutually_inductive_preds thy table = map_aterms (fn t as Const x => - (case def_of_const thy table x of - SOME t' => - let val t' = Envir.eta_contract t' in - if is_mutually_inductive_pred_def thy table t' then t' - else t - end - | NONE => t) - | t => t) + (case def_of_const thy table x of + SOME t' => + let val t' = Envir.eta_contract t' in + if is_mutually_inductive_pred_def thy table t' then t' else t + end + | NONE => t) + | t => t) fun case_const_names ctxt = map_filter (fn {casex = Const (s, T), ...} => - let val Ts = binder_types T in - if is_data_type ctxt (List.last Ts) then SOME (s, length Ts - 1) - else NONE - end) + (case rev (binder_types T) of + [] => NONE + | T :: Ts => if is_data_type ctxt T then SOME (s, length Ts) else NONE)) (Ctr_Sugar.ctr_sugars_of ctxt) @ map (apsnd length o snd) (#codatatypes (Data.get (Context.Proof ctxt))) @@ -1516,8 +1514,7 @@ else fixpoint_kind_of_rhs (the (def_of_const thy table x)) handle Option.Option => NoFp -fun is_raw_inductive_pred ({thy, def_tables, intro_table, ...} : hol_context) - x = +fun is_raw_inductive_pred ({thy, def_tables, intro_table, ...} : hol_context) x = fixpoint_kind_of_const thy def_tables x <> NoFp andalso not (null (def_props_for_const thy intro_table x)) @@ -1673,8 +1670,7 @@ select_nth_constr_arg ctxt constr_x t j res_T |> optimized_record_get hol_ctxt s rec_T' res_T end - | _ => raise TYPE ("Nitpick_HOL.optimized_record_get", [rec_T], - [])) + | _ => raise TYPE ("Nitpick_HOL.optimized_record_get", [rec_T], [])) | j => select_nth_constr_arg ctxt constr_x t j res_T end