2014-11-30 20:34:12 -08:00
|
|
|
/-
|
|
|
|
Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
|
2014-12-15 16:43:42 -05:00
|
|
|
Module: init.tactic
|
2014-11-30 20:34:12 -08:00
|
|
|
Author: Leonardo de Moura
|
|
|
|
|
|
|
|
This is just a trick to embed the 'tactic language' as a Lean
|
|
|
|
expression. We should view 'tactic' as automation that when execute
|
|
|
|
produces a term. tactic.builtin is just a "dummy" for creating the
|
|
|
|
definitions that are actually implemented in C++
|
|
|
|
-/
|
|
|
|
prelude
|
2015-03-03 16:37:38 -05:00
|
|
|
import init.datatypes init.reserved_notation init.num
|
2014-11-30 20:34:12 -08:00
|
|
|
|
|
|
|
inductive tactic :
|
|
|
|
Type := builtin : tactic
|
2014-09-04 16:36:06 -07:00
|
|
|
|
|
|
|
namespace tactic
|
2014-07-01 19:05:22 -07:00
|
|
|
-- Remark the following names are not arbitrary, the tactic module
|
|
|
|
-- uses them when converting Lean expressions into actual tactic objects.
|
|
|
|
-- The bultin 'by' construct triggers the process of converting a
|
2014-07-02 07:08:20 -07:00
|
|
|
-- a term of type 'tactic' into a tactic that sythesizes a term
|
2014-09-19 13:44:44 -07:00
|
|
|
opaque definition and_then (t1 t2 : tactic) : tactic := builtin
|
|
|
|
opaque definition or_else (t1 t2 : tactic) : tactic := builtin
|
|
|
|
opaque definition append (t1 t2 : tactic) : tactic := builtin
|
|
|
|
opaque definition interleave (t1 t2 : tactic) : tactic := builtin
|
|
|
|
opaque definition par (t1 t2 : tactic) : tactic := builtin
|
|
|
|
opaque definition fixpoint (f : tactic → tactic) : tactic := builtin
|
|
|
|
opaque definition repeat (t : tactic) : tactic := builtin
|
|
|
|
opaque definition at_most (t : tactic) (k : num) : tactic := builtin
|
|
|
|
opaque definition discard (t : tactic) (k : num) : tactic := builtin
|
|
|
|
opaque definition focus_at (t : tactic) (i : num) : tactic := builtin
|
|
|
|
opaque definition try_for (t : tactic) (ms : num) : tactic := builtin
|
2015-03-25 17:42:34 -07:00
|
|
|
opaque definition all_goals (t : tactic) : tactic := builtin
|
2014-09-19 13:44:44 -07:00
|
|
|
opaque definition now : tactic := builtin
|
|
|
|
opaque definition assumption : tactic := builtin
|
|
|
|
opaque definition eassumption : tactic := builtin
|
|
|
|
opaque definition state : tactic := builtin
|
|
|
|
opaque definition fail : tactic := builtin
|
|
|
|
opaque definition id : tactic := builtin
|
|
|
|
opaque definition beta : tactic := builtin
|
2014-10-23 13:18:30 -07:00
|
|
|
opaque definition info : tactic := builtin
|
2014-10-28 23:18:49 -07:00
|
|
|
opaque definition whnf : tactic := builtin
|
2015-04-30 13:36:43 -07:00
|
|
|
opaque definition contradiction : tactic := builtin
|
2015-04-30 17:52:29 -07:00
|
|
|
opaque definition exfalso : tactic := builtin
|
2015-05-02 12:58:46 -07:00
|
|
|
opaque definition congruence : tactic := builtin
|
2014-10-29 19:13:55 -07:00
|
|
|
opaque definition rotate_left (k : num) := builtin
|
|
|
|
opaque definition rotate_right (k : num) := builtin
|
|
|
|
definition rotate (k : num) := rotate_left k
|
2014-10-22 15:18:43 -07:00
|
|
|
|
|
|
|
-- This is just a trick to embed expressions into tactics.
|
|
|
|
-- The nested expressions are "raw". They tactic should
|
|
|
|
-- elaborate them when it is executed.
|
|
|
|
inductive expr : Type :=
|
|
|
|
builtin : expr
|
|
|
|
|
2014-10-22 16:15:00 -07:00
|
|
|
inductive expr_list : Type :=
|
2015-02-25 17:00:10 -08:00
|
|
|
| nil : expr_list
|
|
|
|
| cons : expr → expr_list → expr_list
|
2014-10-22 16:15:00 -07:00
|
|
|
|
2015-03-05 18:07:06 -08:00
|
|
|
-- auxiliary type used to mark optional list of arguments
|
|
|
|
definition opt_expr_list := expr_list
|
|
|
|
|
2015-04-22 16:03:22 -07:00
|
|
|
-- auxiliary types used to mark that the expression (list) is an identifier (list)
|
|
|
|
definition identifier := expr
|
|
|
|
definition identifier_list := expr_list
|
|
|
|
definition opt_identifier_list := expr_list
|
|
|
|
|
|
|
|
opaque definition apply (e : expr) : tactic := builtin
|
2015-05-01 15:07:28 -07:00
|
|
|
opaque definition eapply (e : expr) : tactic := builtin
|
2015-04-22 16:03:22 -07:00
|
|
|
opaque definition fapply (e : expr) : tactic := builtin
|
|
|
|
opaque definition rename (a b : identifier) : tactic := builtin
|
2015-04-30 11:00:39 -07:00
|
|
|
opaque definition intro (e : identifier_list) : tactic := builtin
|
2015-04-30 11:57:40 -07:00
|
|
|
opaque definition generalize_tac (e : expr) (id : identifier) : tactic := builtin
|
2015-04-30 11:00:39 -07:00
|
|
|
opaque definition clear (e : identifier_list) : tactic := builtin
|
|
|
|
opaque definition revert (e : identifier_list) : tactic := builtin
|
2015-04-22 16:03:22 -07:00
|
|
|
opaque definition refine (e : expr) : tactic := builtin
|
|
|
|
opaque definition exact (e : expr) : tactic := builtin
|
|
|
|
-- Relaxed version of exact that does not enforce goal type
|
|
|
|
opaque definition rexact (e : expr) : tactic := builtin
|
|
|
|
opaque definition check_expr (e : expr) : tactic := builtin
|
|
|
|
opaque definition trace (s : string) : tactic := builtin
|
|
|
|
|
2015-02-02 19:20:24 -08:00
|
|
|
-- rewrite_tac is just a marker for the builtin 'rewrite' notation
|
|
|
|
-- used to create instances of this tactic.
|
|
|
|
opaque definition rewrite_tac (e : expr_list) : tactic := builtin
|
|
|
|
|
2015-04-22 16:03:22 -07:00
|
|
|
opaque definition cases (id : identifier) (ids : opt_identifier_list) : tactic := builtin
|
2014-11-28 22:25:37 -08:00
|
|
|
|
2015-04-22 16:03:22 -07:00
|
|
|
opaque definition intros (ids : opt_identifier_list) : tactic := builtin
|
2014-10-22 15:18:43 -07:00
|
|
|
|
2015-03-05 18:07:06 -08:00
|
|
|
opaque definition generalizes (es : expr_list) : tactic := builtin
|
2014-11-23 14:39:35 -08:00
|
|
|
|
2015-04-22 16:03:22 -07:00
|
|
|
opaque definition clears (ids : identifier_list) : tactic := builtin
|
2014-11-26 14:49:48 -08:00
|
|
|
|
2015-04-22 16:03:22 -07:00
|
|
|
opaque definition reverts (ids : identifier_list) : tactic := builtin
|
2014-11-23 14:39:35 -08:00
|
|
|
|
2015-03-05 18:07:06 -08:00
|
|
|
opaque definition change (e : expr) : tactic := builtin
|
2015-03-01 14:15:23 -08:00
|
|
|
|
2015-04-22 16:03:22 -07:00
|
|
|
opaque definition assert_hypothesis (id : identifier) (e : expr) : tactic := builtin
|
2014-11-29 21:34:26 -08:00
|
|
|
|
2015-04-28 17:20:39 -07:00
|
|
|
opaque definition lettac (id : identifier) (e : expr) : tactic := builtin
|
|
|
|
|
2015-04-30 21:13:27 -07:00
|
|
|
opaque definition constructor (k : option num) : tactic := builtin
|
|
|
|
opaque definition existsi (e : expr) : tactic := builtin
|
|
|
|
opaque definition split : tactic := builtin
|
|
|
|
opaque definition left : tactic := builtin
|
|
|
|
opaque definition right : tactic := builtin
|
2015-04-30 17:52:29 -07:00
|
|
|
|
2015-05-01 12:45:21 -07:00
|
|
|
opaque definition injection (e : expr) (ids : opt_identifier_list) : tactic := builtin
|
|
|
|
|
2015-05-01 19:31:24 -07:00
|
|
|
opaque definition subst (ids : identifier_list) : tactic := builtin
|
|
|
|
|
2015-05-02 15:48:25 -07:00
|
|
|
opaque definition reflexivity : tactic := builtin
|
|
|
|
opaque definition symmetry : tactic := builtin
|
|
|
|
opaque definition transitivity (e : expr) : tactic := builtin
|
|
|
|
|
2015-04-27 17:46:13 -07:00
|
|
|
definition try (t : tactic) : tactic := or_else t id
|
|
|
|
definition repeat1 (t : tactic) : tactic := and_then t (repeat t)
|
2014-07-03 12:59:48 -07:00
|
|
|
definition focus (t : tactic) : tactic := focus_at t 0
|
|
|
|
definition determ (t : tactic) : tactic := at_most t 1
|
2015-04-27 17:46:13 -07:00
|
|
|
definition trivial : tactic := or_else (or_else (apply eq.refl) (apply true.intro)) assumption
|
2015-03-03 16:37:38 -05:00
|
|
|
definition do (n : num) (t : tactic) : tactic :=
|
2015-04-27 17:46:13 -07:00
|
|
|
nat.rec id (λn t', and_then t t') (nat.of_num n)
|
2014-08-07 16:59:08 -07:00
|
|
|
end tactic
|
2015-04-27 17:46:13 -07:00
|
|
|
tactic_infixl `;`:15 := tactic.and_then
|
|
|
|
tactic_notation `(` h `|` r:(foldl `|` (e r, tactic.or_else r e) h) `)` := r
|