fix(frontends/lean/notation_cmd): fix default, add 'prev' action

Signed-off-by: Leonardo de Moura <leonardo@microsoft.com>
This commit is contained in:
Leonardo de Moura 2014-07-03 16:38:49 -07:00
parent 9ec4f23522
commit fa1857e6a9
2 changed files with 25 additions and 9 deletions

View file

@ -12,6 +12,7 @@ Author: Leonardo de Moura
namespace lean {
static name g_max("max");
static name g_prev("prev");
static name g_colon(":");
static name g_comma(",");
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) {
if (p.curr_is_token(g_colon)) {
p.next();
if (p.curr_is_numeral() || p.curr_is_token_or_id(g_max)) {
unsigned prec = parse_precedence(p, "invalid notation declaration, small numeral expected");
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()) {
std::string fn = p.get_str_val();
p.next();
@ -242,10 +259,6 @@ static action parse_action(parser & p, name const & prev_token, buffer<expr> & l
}
}
} 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();
}
}

View file

@ -4,15 +4,18 @@ variable and : Bool → Bool → Bool
infixr `∧`:35 := and
variable le : N → N → Bool
variable lt : N → N → Bool
variable f : N → N
variable add : N → N → N
infixl `+`:65 := add
precedence `≤`:50
precedence `<`:50
infixl ≤ := le
infixl < := lt
notation A ≤ B ≤ C := A ≤ B ∧ B ≤ C
notation A ≤ B < C := 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:prev < C:prev := A ≤ B ∧ B < C
notation A < B:prev ≤ C:prev := A < B ∧ B ≤ C
variables a b c d e : N
check a ≤ b ≤ c
check a ≤ b ≤ f c + b ∧ a < b
check a ≤ d
check a < b ≤ c
check a ≤ b < c