diff --git a/src/frontends/lean/pp.cpp b/src/frontends/lean/pp.cpp index 05c9ae5e9..1641e109c 100644 --- a/src/frontends/lean/pp.cpp +++ b/src/frontends/lean/pp.cpp @@ -709,7 +709,7 @@ auto pretty_fn::pp_pi(expr const & e) -> result { result lhs = pp_child(binding_domain(e), get_arrow_prec()); result rhs = pp_child(lift_free_vars(binding_body(e), 1), get_arrow_prec()-1); format r = group(lhs.fmt() + space() + (m_unicode ? *g_arrow_n_fmt : *g_arrow_fmt) + line() + rhs.fmt()); - return result(get_arrow_prec()-1, r); + return result(get_arrow_prec(), get_arrow_prec()-1, r); } else { expr b = e; buffer locals; diff --git a/tests/lean/pp_bug.lean b/tests/lean/pp_bug.lean new file mode 100644 index 000000000..203568647 --- /dev/null +++ b/tests/lean/pp_bug.lean @@ -0,0 +1,11 @@ +variables p q : Prop +check ¬(p → q) +check ¬p → q +check (¬p) → q +check ¬(p → q) +check p ↔ q +check ¬(p ↔ q) +check ¬p ↔ q +check (¬p) ↔ q +check (p → q) ↔ q +check p → (q ↔ q) diff --git a/tests/lean/pp_bug.lean.expected.out b/tests/lean/pp_bug.lean.expected.out new file mode 100644 index 000000000..d927da623 --- /dev/null +++ b/tests/lean/pp_bug.lean.expected.out @@ -0,0 +1,10 @@ +¬(p → q) : Prop +¬p → q : Prop +¬p → q : Prop +¬(p → q) : Prop +p ↔ q : Prop +¬(p ↔ q) : Prop +¬p ↔ q : Prop +¬p ↔ q : Prop +p → q ↔ q : Prop +p → (q ↔ q) : Prop