feat(frontends/lean/pp): support scopedexpr notation in the pretty printer
This commit is contained in:
parent
f63d47fef3
commit
ed1afe26bd
4 changed files with 61 additions and 5 deletions
|
@ -697,6 +697,7 @@ auto pretty_fn::pp_notation(notation_entry const & entry, buffer<optional<expr>>
|
||||||
} else {
|
} else {
|
||||||
using notation::transition;
|
using notation::transition;
|
||||||
buffer<transition> ts;
|
buffer<transition> ts;
|
||||||
|
buffer<expr> locals; // from scoped_expr
|
||||||
to_buffer(entry.get_transitions(), ts);
|
to_buffer(entry.get_transitions(), ts);
|
||||||
format fmt;
|
format fmt;
|
||||||
unsigned i = ts.size();
|
unsigned i = ts.size();
|
||||||
|
@ -725,8 +726,8 @@ auto pretty_fn::pp_notation(notation_entry const & entry, buffer<optional<expr>>
|
||||||
curr = format(tk) + space() + e_fmt;
|
curr = format(tk) + space() + e_fmt;
|
||||||
if (last)
|
if (last)
|
||||||
last_rbp = a.rbp();
|
last_rbp = a.rbp();
|
||||||
}
|
|
||||||
break;
|
break;
|
||||||
|
}
|
||||||
case notation::action_kind::Exprs:
|
case notation::action_kind::Exprs:
|
||||||
if (args.empty() || !args.back()) {
|
if (args.empty() || !args.back()) {
|
||||||
return optional<result>();
|
return optional<result>();
|
||||||
|
@ -779,10 +780,53 @@ auto pretty_fn::pp_notation(notation_entry const & entry, buffer<optional<expr>>
|
||||||
break;
|
break;
|
||||||
}
|
}
|
||||||
case notation::action_kind::Binder:
|
case notation::action_kind::Binder:
|
||||||
case notation::action_kind::Binders:
|
if (locals.size() != 1)
|
||||||
case notation::action_kind::ScopedExpr:
|
|
||||||
// TODO(Leo)
|
|
||||||
return optional<result>();
|
return optional<result>();
|
||||||
|
curr = format(tk) + pp_binders(locals);
|
||||||
|
break;
|
||||||
|
case notation::action_kind::Binders:
|
||||||
|
curr = format(tk) + pp_binders(locals);
|
||||||
|
break;
|
||||||
|
case notation::action_kind::ScopedExpr:
|
||||||
|
if (args.empty() || !args.back()) {
|
||||||
|
return optional<result>();
|
||||||
|
} else {
|
||||||
|
expr e = *args.back();
|
||||||
|
bool first_scoped = locals.empty();
|
||||||
|
unsigned i = 0;
|
||||||
|
args.pop_back();
|
||||||
|
expr const & rec = a.get_rec();
|
||||||
|
while (true) {
|
||||||
|
args.resize(args.size() + 1);
|
||||||
|
if (!match(rec, e, args) || !args.back()) {
|
||||||
|
args.pop_back();
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
expr b = *args.back();
|
||||||
|
args.pop_back();
|
||||||
|
if (!((is_lambda(b) && a.use_lambda_abstraction()) ||
|
||||||
|
(is_pi(b) && !a.use_lambda_abstraction()))) {
|
||||||
|
break;
|
||||||
|
}
|
||||||
|
auto p = binding_body_fresh(b, true);
|
||||||
|
if (first_scoped) {
|
||||||
|
locals.push_back(p.second);
|
||||||
|
} else {
|
||||||
|
if (i >= locals.size() || locals[i] != p.second)
|
||||||
|
return optional<result>();
|
||||||
|
}
|
||||||
|
e = p.first;
|
||||||
|
i++;
|
||||||
|
}
|
||||||
|
if (locals.empty())
|
||||||
|
return optional<result>();
|
||||||
|
result e_r = pp_notation_child(e, token_lbp, a.rbp());
|
||||||
|
format e_fmt = e_r.fmt();
|
||||||
|
curr = format(tk) + space() + e_fmt;
|
||||||
|
if (last)
|
||||||
|
last_rbp = a.rbp();
|
||||||
|
break;
|
||||||
|
}
|
||||||
case notation::action_kind::Ext:
|
case notation::action_kind::Ext:
|
||||||
case notation::action_kind::LuaExt:
|
case notation::action_kind::LuaExt:
|
||||||
return optional<result>();
|
return optional<result>();
|
||||||
|
|
7
tests/lean/notation4.lean
Normal file
7
tests/lean/notation4.lean
Normal file
|
@ -0,0 +1,7 @@
|
||||||
|
import logic data.sigma data.list
|
||||||
|
open sigma
|
||||||
|
|
||||||
|
check ∃ (A : Type₁) (x y : A), x = y
|
||||||
|
check ∃ (x : num), x = 0
|
||||||
|
check Σ (x : num), x = 10
|
||||||
|
check Σ (A : Type₁), list A
|
5
tests/lean/notation4.lean.expected.out
Normal file
5
tests/lean/notation4.lean.expected.out
Normal file
|
@ -0,0 +1,5 @@
|
||||||
|
notation4.lean:2:0: warning: imported file uses 'sorry'
|
||||||
|
∃ (A : Type₁) (x y : A) , x = y : Prop
|
||||||
|
∃ (x : num) , x = 0 : Prop
|
||||||
|
Σ (x : num) , x = 10 : Type₁
|
||||||
|
Σ (A : Type₁) , list A : Type₂
|
|
@ -1,3 +1,3 @@
|
||||||
Exists (λ (x : A), p x) : bool
|
∃ (x : A) , p x : bool
|
||||||
Exists (λ (x : A), Exists (λ (y : A), q x y)) : bool
|
∃ (x y : A) , q x y : bool
|
||||||
λ (x : A), x : A → A
|
λ (x : A), x : A → A
|
||||||
|
|
Loading…
Reference in a new issue