2014-08-01 00:48:51 +00:00
|
|
|
----------------------------------------------------------------------------------------------------
|
2014-07-02 14:08:20 +00:00
|
|
|
-- Copyright (c) 2014 Microsoft Corporation. All rights reserved.
|
|
|
|
-- Released under Apache 2.0 license as described in the file LICENSE.
|
|
|
|
-- Author: Leonardo de Moura
|
2014-08-01 00:48:51 +00:00
|
|
|
----------------------------------------------------------------------------------------------------
|
2014-11-07 16:53:14 +00:00
|
|
|
import data.string.decl data.num.decl
|
2014-07-02 02:05:22 +00:00
|
|
|
-- This is just a trick to embed the 'tactic language' as a
|
2014-07-02 14:08:20 +00:00
|
|
|
-- Lean expression. We should view 'tactic' as automation
|
|
|
|
-- that when execute produces a term.
|
2014-09-04 23:36:06 +00:00
|
|
|
-- tactic.builtin is just a "dummy" for creating the
|
2014-07-03 15:06:28 +00:00
|
|
|
-- definitions that are actually implemented in C++
|
2014-07-02 14:08:20 +00:00
|
|
|
inductive tactic : Type :=
|
2014-09-04 23:36:06 +00:00
|
|
|
builtin : tactic
|
|
|
|
|
|
|
|
namespace tactic
|
2014-07-02 02:05:22 +00: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 14:08:20 +00:00
|
|
|
-- a term of type 'tactic' into a tactic that sythesizes a term
|
2014-09-19 20:44:44 +00: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
|
|
|
|
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 20:18:30 +00:00
|
|
|
opaque definition info : tactic := builtin
|
2014-10-29 06:18:49 +00:00
|
|
|
opaque definition whnf : tactic := builtin
|
2014-10-30 02:13:55 +00: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 22:18:43 +00: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-23 01:11:09 +00:00
|
|
|
opaque definition apply (e : expr) : tactic := builtin
|
|
|
|
opaque definition rapply (e : expr) : tactic := builtin
|
|
|
|
opaque definition rename (a b : expr) : tactic := builtin
|
|
|
|
opaque definition intro (e : expr) : tactic := builtin
|
2014-10-24 05:40:15 +00:00
|
|
|
opaque definition generalize (e : expr) : tactic := builtin
|
2014-10-22 23:15:00 +00:00
|
|
|
|
|
|
|
inductive expr_list : Type :=
|
|
|
|
nil : expr_list,
|
|
|
|
cons : expr → expr_list → expr_list
|
|
|
|
|
|
|
|
opaque definition intro_list (es : expr_list) : tactic := builtin
|
|
|
|
notation `intros` := intro_list expr_list.nil
|
|
|
|
notation `intros` `(` l:(foldr `,` (h t, expr_list.cons h t) expr_list.nil) `)` := intro_list l
|
2014-10-22 22:18:43 +00:00
|
|
|
|
2014-11-23 22:39:35 +00:00
|
|
|
opaque definition generalize_list (es : expr_list) : tactic := builtin
|
|
|
|
notation `generalizes` `(` l:(foldr `,` (h t, expr_list.cons h t) expr_list.nil) `)` := generalize_list l
|
|
|
|
|
|
|
|
opaque definition clear (e : expr) : tactic := builtin
|
|
|
|
|
2014-10-23 16:48:53 +00:00
|
|
|
opaque definition unfold (e : expr) : tactic := builtin
|
2014-10-23 01:34:45 +00:00
|
|
|
opaque definition exact (e : expr) : tactic := builtin
|
2014-09-19 20:44:44 +00:00
|
|
|
opaque definition trace (s : string) : tactic := builtin
|
2014-10-21 00:10:16 +00:00
|
|
|
infixl `;`:15 := and_then
|
|
|
|
notation `[` h:10 `|`:10 r:(foldl 10 `|` (e r, or_else r e) h) `]` := r
|
|
|
|
definition try (t : tactic) : tactic := [t | id]
|
|
|
|
definition repeat1 (t : tactic) : tactic := t ; repeat t
|
2014-07-03 19:59:48 +00:00
|
|
|
definition focus (t : tactic) : tactic := focus_at t 0
|
|
|
|
definition determ (t : tactic) : tactic := at_most t 1
|
2014-08-20 02:32:44 +00:00
|
|
|
|
2014-08-07 23:59:08 +00:00
|
|
|
end tactic
|