aboutsummaryrefslogtreecommitdiffhomepage
path: root/doc
diff options
context:
space:
mode:
authorGravatar herbelin <herbelin@85f007b7-540e-0410-9357-904b9bb8a0f7>2003-01-22 22:41:11 +0000
committerGravatar herbelin <herbelin@85f007b7-540e-0410-9357-904b9bb8a0f7>2003-01-22 22:41:11 +0000
commit5564edf454bc65d027dab7834088adc752b42fd1 (patch)
tree22962de76521fe4712490258935527abed03c0f7 /doc
parent2e1cf3b0fc53197dbeb40e57b5dcbf6165419c9b (diff)
Changement s�mantique Match term
git-svn-id: svn+ssh://scm.gforge.inria.fr/svn/coq/trunk@8310 85f007b7-540e-0410-9357-904b9bb8a0f7
Diffstat (limited to 'doc')
-rw-r--r--doc/RefMan-ltac.tex30
1 files changed, 19 insertions, 11 deletions
diff --git a/doc/RefMan-ltac.tex b/doc/RefMan-ltac.tex
index d96ff4dda..4011e975d 100644
--- a/doc/RefMan-ltac.tex
+++ b/doc/RefMan-ltac.tex
@@ -142,10 +142,10 @@ evaluation yields either a term, an integer or a tactic. Intermediary
results can be terms or integers but the final result must be a tactic
which is then applied to the current goal.
-There is a special case for Match expressions of which the clauses
-evaluate to tactics. Such expressions can only be used as end result
-of a tactic expression (never as argument of a local definition or of an
-application).
+There is a special case for {\tt Match Context} expressions of which
+the clauses evaluate to tactics. Such expressions can only be used as
+end result of a tactic expression (never as argument of a local
+definition or of an application).
%% \subsection{Values}
@@ -223,11 +223,16 @@ We can carry out pattern matching on terms with:
~{\tt |} {\tt \_} {\tt ->} {\tacexpr}$_{n+1}$
\end{tabular}
-if {\term} is matched (non-linear first order unification) by {\pattern}$_1$ then
-{\tacexpr}$_1$ is evaluated into some $v_1$ by substituting the pattern matching instantiations to
-the metavariables. If $v_1$ is a tactic value, then it is applied to the current goal. If this application fails, then, as if the matching with {\pattern}$_1$ had failed, the clause {\pattern}$_2$ {\tt ->} {\tacexpr}$_2$ is tried and so on.
-The pattern {\_} matches any term, but if the corresponding action is a tactic which fails, then the whole clause fails.
-If all clauses fail then a no-matching error is raised. \\
+the {\term} is matched (non-linear first order unification) against
+{\pattern}$_1$ then {\tacexpr}$_1$ is evaluated into some value by
+substituting the pattern matching instantiations to the
+metavariables. If the matching with {\pattern}$_1$ fails,
+{\pattern}$_2$ is used and so on. The pattern {\_} matches any term
+and shunts all remaining patterns if any. If {\tacexpr}$_1$ evaluates
+to a tactic, this tactic is not immediately applied to the current
+goal (in contrast with {\tt Match Context}). If all clauses fail (in
+particular, there is no pattern {\_}) then a no-matching error is
+raised. \\
{\tt Error message:}\\
@@ -358,8 +363,11 @@ We have the failing tactic:\\
{\tt Fail} and {\tt Fail $n$} \\
It always fails and leaves the goal unchanged. It does not appear in
-the proof script and can be catched by {\tt Try}. If no number is
-specified, it defaults to $0$.
+the proof script and can be catched by {\tt Try}. The number $n$ is
+the failure level. If no level is specified, it defaults to $0$. The
+level is used in {\tt Match Context}. If $0$, it makes {\tt Match
+Context} considering the next clause. If non zero, the current {\tt
+Match Context} block is aborted and the level is decremented.
{\tt Error message:}\\