fix(frontends/lean/notation_cmd): fix default, add 'prev' action
Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
parent
9ec4f23522
commit
fa1857e6a9
2 changed files with 25 additions and 9 deletions
|
@ -12,6 +12,7 @@ Author: Leonardo de Moura
|
||||||
|
|
||||||
namespace lean {
|
namespace lean {
|
||||||
static name g_max("max");
|
static name g_max("max");
|
||||||
|
static name g_prev("prev");
|
||||||
static name g_colon(":");
|
static name g_colon(":");
|
||||||
static name g_comma(",");
|
static name g_comma(",");
|
||||||
static name g_assign(":=");
|
static name g_assign(":=");
|
||||||
|
@ -184,12 +185,28 @@ static void parse_notation_local(parser & p, buffer<expr> & locals) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
unsigned get_precedence(environment const & env, buffer<token_entry> const & new_tokens, name const & token) {
|
||||||
|
std::string token_str = token.to_string();
|
||||||
|
for (auto const & e : new_tokens) {
|
||||||
|
if (e.m_token == token_str)
|
||||||
|
return e.m_prec;
|
||||||
|
}
|
||||||
|
auto prec = get_precedence(get_token_table(env), token_str.c_str());
|
||||||
|
if (prec)
|
||||||
|
return *prec;
|
||||||
|
else
|
||||||
|
return 0;
|
||||||
|
}
|
||||||
|
|
||||||
static action parse_action(parser & p, name const & prev_token, buffer<expr> & locals, buffer<token_entry> & new_tokens) {
|
static action parse_action(parser & p, name const & prev_token, buffer<expr> & locals, buffer<token_entry> & new_tokens) {
|
||||||
if (p.curr_is_token(g_colon)) {
|
if (p.curr_is_token(g_colon)) {
|
||||||
p.next();
|
p.next();
|
||||||
if (p.curr_is_numeral() || p.curr_is_token_or_id(g_max)) {
|
if (p.curr_is_numeral() || p.curr_is_token_or_id(g_max)) {
|
||||||
unsigned prec = parse_precedence(p, "invalid notation declaration, small numeral expected");
|
unsigned prec = parse_precedence(p, "invalid notation declaration, small numeral expected");
|
||||||
return mk_expr_action(prec);
|
return mk_expr_action(prec);
|
||||||
|
} else if (p.curr_is_token_or_id(g_prev)) {
|
||||||
|
p.next();
|
||||||
|
return mk_expr_action(get_precedence(p.env(), new_tokens, prev_token));
|
||||||
} else if (p.curr_is_string()) {
|
} else if (p.curr_is_string()) {
|
||||||
std::string fn = p.get_str_val();
|
std::string fn = p.get_str_val();
|
||||||
p.next();
|
p.next();
|
||||||
|
@ -242,10 +259,6 @@ static action parse_action(parser & p, name const & prev_token, buffer<expr> & l
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
} else {
|
} else {
|
||||||
auto prec = get_precedence(get_token_table(p.env()), prev_token.to_string().c_str());
|
|
||||||
if (prec)
|
|
||||||
return mk_expr_action(*prec);
|
|
||||||
else
|
|
||||||
return mk_expr_action();
|
return mk_expr_action();
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -4,15 +4,18 @@ variable and : Bool → Bool → Bool
|
||||||
infixr `∧`:35 := and
|
infixr `∧`:35 := and
|
||||||
variable le : N → N → Bool
|
variable le : N → N → Bool
|
||||||
variable lt : N → N → Bool
|
variable lt : N → N → Bool
|
||||||
|
variable f : N → N
|
||||||
|
variable add : N → N → N
|
||||||
|
infixl `+`:65 := add
|
||||||
precedence `≤`:50
|
precedence `≤`:50
|
||||||
precedence `<`:50
|
precedence `<`:50
|
||||||
infixl ≤ := le
|
infixl ≤ := le
|
||||||
infixl < := lt
|
infixl < := lt
|
||||||
notation A ≤ B ≤ C := A ≤ B ∧ B ≤ C
|
notation A ≤ B:prev ≤ C:prev := A ≤ B ∧ B ≤ C
|
||||||
notation A ≤ B < C := A ≤ B ∧ B < C
|
notation A ≤ B:prev < C:prev := A ≤ B ∧ B < C
|
||||||
notation A < B ≤ C := A < B ∧ B ≤ C
|
notation A < B:prev ≤ C:prev := A < B ∧ B ≤ C
|
||||||
variables a b c d e : N
|
variables a b c d e : N
|
||||||
check a ≤ b ≤ c
|
check a ≤ b ≤ f c + b ∧ a < b
|
||||||
check a ≤ d
|
check a ≤ d
|
||||||
check a < b ≤ c
|
check a < b ≤ c
|
||||||
check a ≤ b < c
|
check a ≤ b < c
|
||||||
|
|
Loading…
Reference in a new issue