feat(frontends/lean/pp): support scopedexpr notation in the pretty printer

This commit is contained in:
Leonardo de Moura 2014-10-19 12:48:34 -07:00
parent f63d47fef3
commit ed1afe26bd
4 changed files with 61 additions and 5 deletions

View file

@ -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>();

View 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

View 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₂

View file

@ -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