From ec7f90cb1614e5bd5c14776a347415f16d1f0424 Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Sat, 6 Dec 2014 09:43:42 -0800 Subject: [PATCH] feat(hott/init): make sure eq is universe polymorphic Jakob and Floris needed path equality to be universe polymorphic when proving univalence. --- hott/init/datatypes.hlean | 2 +- src/frontends/lean/structure_cmd.cpp | 3 ++- 2 files changed, 3 insertions(+), 2 deletions(-) diff --git a/hott/init/datatypes.hlean b/hott/init/datatypes.hlean index fec97587d..b3c0e81dc 100644 --- a/hott/init/datatypes.hlean +++ b/hott/init/datatypes.hlean @@ -19,7 +19,7 @@ star : unit inductive empty : Type -inductive eq {A : Type} (a : A) : A → Type := +inductive eq.{l} {A : Type.{l}} (a : A) : A → Type.{l} := refl : eq a a structure prod (A B : Type) := diff --git a/src/frontends/lean/structure_cmd.cpp b/src/frontends/lean/structure_cmd.cpp index 896053136..0fab1111c 100644 --- a/src/frontends/lean/structure_cmd.cpp +++ b/src/frontends/lean/structure_cmd.cpp @@ -762,7 +762,8 @@ struct structure_cmd_fn { lhs = mk_app(lhs, proj); } expr eq = mk_app(mk_constant("eq", to_list(sort_level(m_type))), st_type, lhs, st); - levels rec_ls = levels(mk_level_zero(), st_ls); + level eq_lvl = sort_level(m_tc->ensure_type(eq).first); + levels rec_ls = levels(eq_lvl, st_ls); expr rec = mk_app(mk_constant(inductive::get_elim_name(m_name), rec_ls), m_params); expr type_former = Fun(st, eq); expr mk = mk_app(mk_app(mk_constant(m_mk, st_ls), m_params), m_fields);