lean4-htt/src/library/tactic/cases_tactic.h

40 lines
1.8 KiB
C++

/*
Copyright (c) 2016 Microsoft Corporation. All rights reserved.
Released under Apache 2.0 license as described in the file LICENSE.
Author: Leonardo de Moura
*/
#pragma once
#include "library/tactic/induction_tactic.h"
namespace lean {
/** \brief Similar to induction, but applies 'cases_on' and has bettern support for dependent types. Failures are reported using exceptions.
\c ids (if available) provides the names for new hypotheses.
If ilist and slist are not nullptr, then
1- Store in ilist the new "hypotheses" introduced for each new goal.
We have a new "hypothesis" for each constructor field.
We say "hypothesis" because it may be an arbitrary term.
This may happen because of dependent pattern matching.
2- Store in slist the hypotheses that have been replaced in each goal.
\pre (ilist == nullptr) iff (slist == nullptr)
\post ilist != nullptr -> slist != nullptr -> length(*ilist) == length(*slist)
The result is a new list of goals and a list of constructor names.
The two lists have the same size. Let (m, c) be the i-th elements of each list.
Then we have that m is the goal associated with the constructor c.
\remark The resulting set of goals may be smaller than the number of constructors
since some of the goals are discarded.
\remark If unfold_ginductive is true, then we perform cases_on on the basic inductive datatype produced
by the kernel. That is, we use relaxed_whnf to expand generalized inductive datatypes.
*/
pair<list<expr>, list<name>>
cases(environment const & env, options const & opts, transparency_mode const & m, metavar_context & mctx,
expr const & mvar, expr const & H, list<name> & ids, intros_list * ilist, hsubstitution_list * slist,
bool unfold_ginductive);
void initialize_cases_tactic();
void finalize_cases_tactic();
}