src/Pure/Isar/auto_bind.ML
author wenzelm
Thu, 18 Aug 2005 12:07:33 +0200
changeset 17118 1ff59b7b35b7
parent 15531 08c8dad8e399
child 17349 03fafcdfdfa7
permissions -rw-r--r--
fixed command prompt (was broken due to P.tags);
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
6783
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     1
(*  Title:      Pure/Isar/auto_bind.ML
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     2
    ID:         $Id$
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     3
    Author:     Markus Wenzel, TU Muenchen
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     4
10359
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
     5
Logic specific patterns and automatic term bindings.
6783
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     6
*)
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     7
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     8
signature AUTO_BIND =
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
     9
sig
12140
a987beab002d facts: multiple args;
wenzelm
parents: 11764
diff changeset
    10
  val goal: Sign.sg -> term list -> (indexname * term option) list
a987beab002d facts: multiple args;
wenzelm
parents: 11764
diff changeset
    11
  val facts: Sign.sg -> term list -> (indexname * term option) list
9296
0d2b31e1ea1b export thesisN separately;
wenzelm
parents: 8807
diff changeset
    12
  val thesisN: string
6783
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
    13
end;
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
    14
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
    15
structure AutoBind: AUTO_BIND =
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
    16
struct
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
    17
10359
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    18
(** bindings **)
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    19
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    20
val thesisN = "thesis";
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    21
val thisN = "this";
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    22
11764
fd780dd6e0b4 use ObjectLogic;
wenzelm
parents: 10808
diff changeset
    23
fun strip_judgment sg = ObjectLogic.drop_judgment sg o Logic.strip_assums_concl;
fd780dd6e0b4 use ObjectLogic;
wenzelm
parents: 10808
diff changeset
    24
fd780dd6e0b4 use ObjectLogic;
wenzelm
parents: 10808
diff changeset
    25
fun statement_binds sg name prop =
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 14981
diff changeset
    26
  [((name, 0), SOME (Term.list_abs (Logic.strip_params prop, strip_judgment sg prop)))];
10359
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    27
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    28
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    29
(* goal *)
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    30
12241
c4a2a0686238 fixed comment;
wenzelm
parents: 12140
diff changeset
    31
fun goal sg [prop] = statement_binds sg thesisN prop
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 14981
diff changeset
    32
  | goal _ _ = [((thesisN, 0), NONE)];
10359
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    33
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    34
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    35
(* facts *)
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    36
11764
fd780dd6e0b4 use ObjectLogic;
wenzelm
parents: 10808
diff changeset
    37
fun get_arg sg prop =
fd780dd6e0b4 use ObjectLogic;
wenzelm
parents: 10808
diff changeset
    38
  (case strip_judgment sg prop of
15531
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 14981
diff changeset
    39
    _ $ t => SOME (Term.list_abs (Logic.strip_params prop, t))
08c8dad8e399 Deleted Library.option type.
skalberg
parents: 14981
diff changeset
    40
  | _ => NONE);
10359
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    41
12140
a987beab002d facts: multiple args;
wenzelm
parents: 11764
diff changeset
    42
fun facts _ [] = []
a987beab002d facts: multiple args;
wenzelm
parents: 11764
diff changeset
    43
  | facts sg props =
10359
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    44
      let val prop = Library.last_elem props
11764
fd780dd6e0b4 use ObjectLogic;
wenzelm
parents: 10808
diff changeset
    45
      in [(Syntax.dddot_indexname, get_arg sg prop)] @ statement_binds sg thisN prop end;
10359
445e3b87f28b improved statement bindings for props;
wenzelm
parents: 9464
diff changeset
    46
10808
cc4a3ed7e70b added drop_judgment;
wenzelm
parents: 10377
diff changeset
    47
6783
9cf9c17d9e35 renamed object_logic.ML to Isar/auto_bind.ML and tuned this module;
wenzelm
parents:
diff changeset
    48
end;