src/Pure/Isar/object_logic.ML
author wenzelm
Thu, 21 Apr 2005 22:02:06 +0200
changeset 15801 d2f5ca3c048d
parent 15570 8d8c70b41bab
child 15973 5fd94d84470f
permissions -rw-r--r--
superceded by Pure.thy and CPure.thy;
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/Isar/object_logic.ML
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     2
    ID:         $Id$
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     3
    Author:     Markus Wenzel, TU Muenchen
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     4
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     5
Specifics about common object-logics.
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     6
*)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     7
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     8
signature OBJECT_LOGIC =
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
     9
sig
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    10
  val add_judgment: bstring * string * mixfix -> theory -> theory
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    11
  val add_judgment_i: bstring * typ * mixfix -> theory -> theory
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    12
  val judgment_name: Sign.sg -> string
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    13
  val is_judgment: Sign.sg -> term -> bool
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    14
  val drop_judgment: Sign.sg -> term -> term
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    15
  val fixed_judgment: Sign.sg -> string -> term
13376
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
    16
  val assert_propT: Sign.sg -> term -> term
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    17
  val declare_atomize: theory attribute
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    18
  val declare_rulify: theory attribute
12807
4f2983e39a59 atomize_term replaces atomize_cterm;
wenzelm
parents: 12729
diff changeset
    19
  val atomize_term: Sign.sg -> term -> term
14743
81001d6cb8c0 conversion of theorems to atomic form
paulson
parents: 14226
diff changeset
    20
  val atomize_thm: thm -> thm
13376
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
    21
  val atomize_rule: Sign.sg -> cterm -> thm
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    22
  val atomize_tac: int -> tactic
12829
c92128238f85 full_atomize;
wenzelm
parents: 12807
diff changeset
    23
  val full_atomize_tac: int -> tactic
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    24
  val atomize_goal: int -> thm -> thm
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    25
  val rulify: thm -> thm
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    26
  val rulify_no_asm: thm -> thm
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    27
  val rule_format: 'a attribute
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    28
  val rule_format_no_asm: 'a attribute
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    29
end;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    30
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    31
structure ObjectLogic: OBJECT_LOGIC =
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    32
struct
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    33
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    34
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    35
(** object-logic theory data **)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    36
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    37
(* data kind 'Pure/object-logic' *)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    38
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    39
structure ObjectLogicDataArgs =
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    40
struct
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    41
  val name = "Pure/object-logic";
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    42
  type T = string option * (thm list * thm list);
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    43
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
    44
  val empty = (NONE, ([], [Drule.norm_hhf_eq]));
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    45
  val copy = I;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    46
  val prep_ext = I;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    47
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
    48
  fun merge_judgment (SOME x, SOME y) =
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
    49
        if x = y then SOME x else error "Attempt to merge different object-logics"
15570
8d8c70b41bab Move towards standard functions.
skalberg
parents: 15531
diff changeset
    50
    | merge_judgment (j1, j2) = if isSome j1 then j1 else j2;
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    51
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    52
  fun merge ((judgment1, (atomize1, rulify1)), (judgment2, (atomize2, rulify2))) =
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    53
    (merge_judgment (judgment1, judgment2),
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    54
      (Drule.merge_rules (atomize1, atomize2), Drule.merge_rules (rulify1, rulify2)));
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    55
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    56
  fun print _ _ = ();
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    57
end;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    58
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    59
structure ObjectLogicData = TheoryDataFun(ObjectLogicDataArgs);
15801
d2f5ca3c048d superceded by Pure.thy and CPure.thy;
wenzelm
parents: 15570
diff changeset
    60
val _ = Context.add_setup [ObjectLogicData.init];
d2f5ca3c048d superceded by Pure.thy and CPure.thy;
wenzelm
parents: 15570
diff changeset
    61
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    62
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    63
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    64
(** generic treatment of judgments -- with a single argument only **)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    65
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    66
(* add_judgment(_i) *)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    67
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    68
local
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    69
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
    70
fun new_judgment name (NONE, rules) = (SOME name, rules)
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
    71
  | new_judgment _ (SOME _, _) = error "Attempt to redeclare object-logic judgment";
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    72
14226
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    73
fun add_final name thy =
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    74
  let
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    75
    val typ = case Sign.const_type (sign_of thy) name of
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
    76
		SOME T => T
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
    77
	      | NONE => error "Internal error in ObjectLogic.gen_add_judgment";
14226
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    78
  in
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    79
    Theory.add_finals_i false [Const(name,typ)] thy
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    80
  end;
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    81
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    82
fun gen_add_judgment add_consts (name, T, syn) thy =
14226
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    83
  let
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    84
    val fullname = Sign.full_name (Theory.sign_of thy) name;
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    85
  in
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    86
    thy
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    87
    |> add_consts [(name, T, syn)]
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    88
    |> add_final fullname
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    89
    |> ObjectLogicData.map (new_judgment fullname)
7afe0e5bcc83 Made judgments automatically declared final.
skalberg
parents: 13376
diff changeset
    90
  end;
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    91
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    92
in
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    93
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    94
val add_judgment = gen_add_judgment Theory.add_consts;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    95
val add_judgment_i = gen_add_judgment Theory.add_consts_i;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    96
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    97
end;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    98
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
    99
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   100
(* term operations *)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   101
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   102
fun judgment_name sg =
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   103
  (case ObjectLogicData.get_sg sg of
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
   104
    (SOME name, _) => name
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   105
  | _ => raise TERM ("Unknown object-logic judgment", []));
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   106
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   107
fun is_judgment sg (Const (c, _) $ _) = c = judgment_name sg
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   108
  | is_judgment _ _ = false;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   109
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   110
fun drop_judgment sg (Abs (x, T, t)) = Abs (x, T, drop_judgment sg t)
12479
ed46612ad7ec drop_judgment: be graceful about undeclared judgment;
wenzelm
parents: 12371
diff changeset
   111
  | drop_judgment sg (tm as (Const (c, _) $ t)) =
ed46612ad7ec drop_judgment: be graceful about undeclared judgment;
wenzelm
parents: 12371
diff changeset
   112
      if (c = judgment_name sg handle TERM _ => false) then t else tm
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   113
  | drop_judgment _ tm = tm;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   114
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   115
fun fixed_judgment sg x =
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   116
  let  (*be robust wrt. low-level errors*)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   117
    val c = judgment_name sg;
14854
61bdf2ae4dc5 removed obsolete sort 'logic';
wenzelm
parents: 14743
diff changeset
   118
    val aT = TFree ("'a", []);
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   119
    val T =
15570
8d8c70b41bab Move towards standard functions.
skalberg
parents: 15531
diff changeset
   120
      getOpt (Sign.const_type sg c, aT --> propT)
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   121
      |> Term.map_type_tvar (fn ((x, _), S) => TFree (x, S));
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   122
    val U = Term.domain_type T handle Match => aT;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   123
  in Const (c, T) $ Free (x, U) end;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   124
13376
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
   125
fun assert_propT sg t =
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
   126
  let val T = Term.fastype_of t
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
   127
  in if T = propT then t else Const (judgment_name sg, T --> propT) $ t end;
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
   128
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   129
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   130
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   131
(** treatment of meta-level connectives **)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   132
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   133
(* maintain rules *)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   134
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   135
val get_atomize = #1 o #2 o ObjectLogicData.get_sg;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   136
val get_rulify = #2 o #2 o ObjectLogicData.get_sg;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   137
12371
wenzelm
parents: 12311
diff changeset
   138
val add_atomize = ObjectLogicData.map o Library.apsnd o Library.apfst o Drule.add_rule;
wenzelm
parents: 12311
diff changeset
   139
val add_rulify = ObjectLogicData.map o Library.apsnd o Library.apsnd o Drule.add_rule;
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   140
12371
wenzelm
parents: 12311
diff changeset
   141
fun declare_atomize (thy, th) = (add_atomize th thy, th);
wenzelm
parents: 12311
diff changeset
   142
fun declare_rulify (thy, th) = (add_rulify th thy, th);
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   143
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   144
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   145
(* atomize *)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   146
15001
fb2141a9f8c0 Moved conversion rules from MetaSimplifier to Drule. refl_implies removed
skalberg
parents: 14981
diff changeset
   147
fun rewrite_prems_tac rews i = PRIMITIVE (Drule.fconv_rule
fb2141a9f8c0 Moved conversion rules from MetaSimplifier to Drule. refl_implies removed
skalberg
parents: 14981
diff changeset
   148
  (Drule.goals_conv (Library.equal i)
fb2141a9f8c0 Moved conversion rules from MetaSimplifier to Drule. refl_implies removed
skalberg
parents: 14981
diff changeset
   149
    (Drule.forall_conv
fb2141a9f8c0 Moved conversion rules from MetaSimplifier to Drule. refl_implies removed
skalberg
parents: 14981
diff changeset
   150
      (Drule.goals_conv (K true) (Tactic.rewrite true rews)))));
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   151
12807
4f2983e39a59 atomize_term replaces atomize_cterm;
wenzelm
parents: 12729
diff changeset
   152
fun atomize_term sg =
13197
0567f4fd1415 Changed interface of MetaSimplifier.rewrite_term.
berghofe
parents: 12829
diff changeset
   153
  drop_judgment sg o MetaSimplifier.rewrite_term sg (get_atomize sg) [];
12729
46808b5ec985 added atomize_cterm;
wenzelm
parents: 12725
diff changeset
   154
13376
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
   155
fun atomize_rule sg = Tactic.rewrite true (get_atomize sg);
59975b8417e2 assert_propT;
wenzelm
parents: 13334
diff changeset
   156
14743
81001d6cb8c0 conversion of theorems to atomic form
paulson
parents: 14226
diff changeset
   157
(*Convert a natural-deduction rule into a formula (probably in FOL)*)
81001d6cb8c0 conversion of theorems to atomic form
paulson
parents: 14226
diff changeset
   158
fun atomize_thm th =
81001d6cb8c0 conversion of theorems to atomic form
paulson
parents: 14226
diff changeset
   159
  rewrite_rule  (get_atomize (Thm.sign_of_thm th)) th;
81001d6cb8c0 conversion of theorems to atomic form
paulson
parents: 14226
diff changeset
   160
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   161
fun atomize_tac i st =
12807
4f2983e39a59 atomize_term replaces atomize_cterm;
wenzelm
parents: 12729
diff changeset
   162
  if Logic.has_meta_prems (Thm.prop_of st) i then
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   163
    (rewrite_prems_tac (get_atomize (Thm.sign_of_thm st)) i) st
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   164
  else all_tac st;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   165
12829
c92128238f85 full_atomize;
wenzelm
parents: 12807
diff changeset
   166
fun full_atomize_tac i st =
c92128238f85 full_atomize;
wenzelm
parents: 12807
diff changeset
   167
  rewrite_goal_tac (get_atomize (Thm.sign_of_thm st)) i st;
c92128238f85 full_atomize;
wenzelm
parents: 12807
diff changeset
   168
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   169
fun atomize_goal i st =
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 15001
diff changeset
   170
  (case Seq.pull (atomize_tac i st) of NONE => st | SOME (st', _) => st');
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   171
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   172
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   173
(* rulify *)
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   174
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   175
fun gen_rulify full thm =
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   176
  Tactic.simplify full (get_rulify (Thm.sign_of_thm thm)) thm
12725
7ede865e1fe5 renamed forall_elim_vars_safe to gen_all;
wenzelm
parents: 12479
diff changeset
   177
  |> Drule.gen_all |> Drule.strip_shyps_warning |> Drule.zero_var_indexes;
11897
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   178
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   179
val rulify = gen_rulify true;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   180
val rulify_no_asm = gen_rulify false;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   181
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   182
fun rule_format x = Drule.rule_attribute (fn _ => rulify) x;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   183
fun rule_format_no_asm x = Drule.rule_attribute (fn _ => rulify_no_asm) x;
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   184
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   185
b9f2028f53bd moved object_logic.ML to Isar/object_logic.ML;
wenzelm
parents:
diff changeset
   186
end;