From 8fc02ed741bb2dd91ac2739df00ff8242bcf60a3 Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Wed, 20 Nov 2019 16:10:40 -0800 Subject: [PATCH] chore: update stage0 --- stage0/library/Init/Lean/Expr.c | 121 +- stage0/library/Init/Lean/Meta.c | 31876 +------------- stage0/library/Init/Lean/Meta/Basic.c | 9954 ++++- stage0/library/Init/Lean/Meta/Check.c | 5279 ++- stage0/library/Init/Lean/Meta/Exception.c | 30 +- stage0/library/Init/Lean/Meta/ExprDefEq.c | 42142 ++++++++++++------- stage0/library/Init/Lean/Meta/FunInfo.c | 2810 +- stage0/library/Init/Lean/Meta/InferType.c | 19059 ++------- stage0/library/Init/Lean/Meta/LevelDefEq.c | 4871 ++- stage0/library/Init/Lean/Meta/Offset.c | 791 +- stage0/library/Init/Lean/Meta/WHNF.c | 12149 +++++- stage0/src/shell/CMakeLists.txt | 14 +- 12 files changed, 61761 insertions(+), 67335 deletions(-) diff --git a/stage0/library/Init/Lean/Expr.c b/stage0/library/Init/Lean/Expr.c index 97a91f3a90..c3bcdf3326 100644 --- a/stage0/library/Init/Lean/Expr.c +++ b/stage0/library/Init/Lean/Expr.c @@ -155,6 +155,7 @@ lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); lean_object* l_Lean_Expr_isMVar___boxed(lean_object*); uint8_t l_Lean_Expr_Data_hasExprMVar(uint64_t); lean_object* l_Lean_Literal_type(lean_object*); +lean_object* l_Lean_Literal_beq___boxed(lean_object*, lean_object*); lean_object* l_Lean_Expr_isConstOf___boxed(lean_object*, lean_object*); lean_object* lean_expr_mk_mdata(lean_object*, lean_object*); uint64_t l_Lean_BinderInfo_toUInt64(uint8_t); @@ -182,6 +183,7 @@ lean_object* l_Lean_Expr_constLevels_x21(lean_object*); lean_object* l_Lean_Expr_hasLevelParam___boxed(lean_object*); lean_object* l_Lean_Expr_updateFn___main___boxed(lean_object*, lean_object*); uint8_t lean_expr_has_mvar(lean_object*); +uint8_t l_Lean_Literal_beq(lean_object*, lean_object*); lean_object* l_Lean_BinderInfo_hasBeq___closed__1; uint8_t lean_expr_binder_info(lean_object*); uint64_t l_Lean_Expr_mkData___closed__2; @@ -254,6 +256,7 @@ uint8_t l_Lean_BinderInfo_isAuxDecl(uint8_t); lean_object* l_Lean_Expr_bindingName_x21___closed__1; lean_object* l_Lean_Expr_Data_hasLevelMVar___boxed(lean_object*); uint8_t l_Lean_Expr_Data_nonDepLet(uint64_t); +lean_object* l_Lean_Literal_hasBeq___closed__1; uint64_t l_UInt64_land(uint64_t, uint64_t); lean_object* l___private_Init_Lean_Expr_3__getAppArgsAux___main(lean_object*, lean_object*, lean_object*); lean_object* lean_expr_mk_app(lean_object*, lean_object*); @@ -280,6 +283,7 @@ lean_object* l_Lean_ExprStructEq_Inhabited; lean_object* l_Lean_Expr_bvarIdx_x21(lean_object*); lean_object* l_Lean_Expr_updateProj_x21___closed__2; lean_object* l_Lean_mkLocal(lean_object*, lean_object*, lean_object*, uint8_t); +lean_object* l_Lean_Literal_hasBeq; lean_object* l_Lean_Expr_getAppNumArgsAux___main___boxed(lean_object*, lean_object*); lean_object* l_Lean_Expr_instantiateRevRange___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_updateLambda_x21___closed__1; @@ -456,6 +460,7 @@ uint8_t l_Lean_Expr_isLet(lean_object*); lean_object* l_Lean_Expr_isLet___boxed(lean_object*); lean_object* l_Lean_ExprStructEq_hash___boxed(lean_object*); lean_object* l___private_Init_Lean_Expr_7__betaRevAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t lean_string_dec_eq(lean_object*, lean_object*); uint32_t l_Lean_Expr_Data_looseBVarRange(uint64_t); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); uint64_t l_Lean_Expr_mkData(size_t, lean_object*, uint8_t, uint8_t, uint8_t, uint8_t); @@ -528,6 +533,72 @@ x_1 = l_Lean_Literal_hashable___closed__1; return x_1; } } +uint8_t l_Lean_Literal_beq(lean_object* x_1, lean_object* x_2) { +_start: +{ +if (lean_obj_tag(x_1) == 0) +{ +if (lean_obj_tag(x_2) == 0) +{ +lean_object* x_3; lean_object* x_4; uint8_t x_5; +x_3 = lean_ctor_get(x_1, 0); +x_4 = lean_ctor_get(x_2, 0); +x_5 = lean_nat_dec_eq(x_3, x_4); +return x_5; +} +else +{ +uint8_t x_6; +x_6 = 0; +return x_6; +} +} +else +{ +if (lean_obj_tag(x_2) == 0) +{ +uint8_t x_7; +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_8 = lean_ctor_get(x_1, 0); +x_9 = lean_ctor_get(x_2, 0); +x_10 = lean_string_dec_eq(x_8, x_9); +return x_10; +} +} +} +} +lean_object* l_Lean_Literal_beq___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +uint8_t x_3; lean_object* x_4; +x_3 = l_Lean_Literal_beq(x_1, x_2); +lean_dec(x_2); +lean_dec(x_1); +x_4 = lean_box(x_3); +return x_4; +} +} +lean_object* _init_l_Lean_Literal_hasBeq___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Literal_beq___boxed), 2, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Literal_hasBeq() { +_start: +{ +lean_object* x_1; +x_1 = l_Lean_Literal_hasBeq___closed__1; +return x_1; +} +} size_t l_Lean_BinderInfo_hash(uint8_t x_1) { _start: { @@ -1024,7 +1095,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(122u); +x_2 = lean_unsigned_to_nat(129u); x_3 = lean_unsigned_to_nat(42u); x_4 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__2; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5237,7 +5308,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(455u); +x_2 = lean_unsigned_to_nat(462u); x_3 = lean_unsigned_to_nat(20u); x_4 = l_List_get_x21___main___rarg___closed__2; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5491,7 +5562,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(475u); +x_2 = lean_unsigned_to_nat(482u); x_3 = lean_unsigned_to_nat(15u); x_4 = l_Lean_Expr_appFn_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5532,7 +5603,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(479u); +x_2 = lean_unsigned_to_nat(486u); x_3 = lean_unsigned_to_nat(15u); x_4 = l_Lean_Expr_appFn_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5581,7 +5652,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(483u); +x_2 = lean_unsigned_to_nat(490u); x_3 = lean_unsigned_to_nat(17u); x_4 = l_Lean_Expr_constName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5622,7 +5693,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(487u); +x_2 = lean_unsigned_to_nat(494u); x_3 = lean_unsigned_to_nat(18u); x_4 = l_Lean_Expr_constName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5671,7 +5742,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(491u); +x_2 = lean_unsigned_to_nat(498u); x_3 = lean_unsigned_to_nat(16u); x_4 = l_Lean_Expr_bvarIdx_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5720,7 +5791,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(495u); +x_2 = lean_unsigned_to_nat(502u); x_3 = lean_unsigned_to_nat(14u); x_4 = l_Lean_Expr_fvarId_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5769,7 +5840,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(499u); +x_2 = lean_unsigned_to_nat(506u); x_3 = lean_unsigned_to_nat(14u); x_4 = l_Lean_Expr_mvarId_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5818,7 +5889,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(504u); +x_2 = lean_unsigned_to_nat(511u); x_3 = lean_unsigned_to_nat(21u); x_4 = l_Lean_Expr_bindingName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5868,7 +5939,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(509u); +x_2 = lean_unsigned_to_nat(516u); x_3 = lean_unsigned_to_nat(21u); x_4 = l_Lean_Expr_bindingName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5918,7 +5989,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(514u); +x_2 = lean_unsigned_to_nat(521u); x_3 = lean_unsigned_to_nat(21u); x_4 = l_Lean_Expr_bindingName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -5976,7 +6047,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(518u); +x_2 = lean_unsigned_to_nat(525u); x_3 = lean_unsigned_to_nat(20u); x_4 = l_Lean_Expr_letName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -6782,7 +6853,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(684u); +x_2 = lean_unsigned_to_nat(691u); x_3 = lean_unsigned_to_nat(18u); x_4 = l_Lean_Expr_appFn_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -6824,7 +6895,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(693u); +x_2 = lean_unsigned_to_nat(700u); x_3 = lean_unsigned_to_nat(18u); x_4 = l_Lean_Expr_constName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -6873,7 +6944,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(702u); +x_2 = lean_unsigned_to_nat(709u); x_3 = lean_unsigned_to_nat(14u); x_4 = l_Lean_Expr_updateSort_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -6930,7 +7001,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(719u); +x_2 = lean_unsigned_to_nat(726u); x_3 = lean_unsigned_to_nat(17u); x_4 = l_Lean_Expr_updateMData_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -6971,7 +7042,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(724u); +x_2 = lean_unsigned_to_nat(731u); x_3 = lean_unsigned_to_nat(18u); x_4 = l_Lean_Expr_updateProj_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7022,7 +7093,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(733u); +x_2 = lean_unsigned_to_nat(740u); x_3 = lean_unsigned_to_nat(21u); x_4 = l_Lean_Expr_updateForall_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7066,7 +7137,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(738u); +x_2 = lean_unsigned_to_nat(745u); x_3 = lean_unsigned_to_nat(21u); x_4 = l_Lean_Expr_updateForall_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7120,7 +7191,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(747u); +x_2 = lean_unsigned_to_nat(754u); x_3 = lean_unsigned_to_nat(17u); x_4 = l_Lean_Expr_updateLambda_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7164,7 +7235,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(752u); +x_2 = lean_unsigned_to_nat(759u); x_3 = lean_unsigned_to_nat(17u); x_4 = l_Lean_Expr_updateLambda_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7208,7 +7279,7 @@ _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = l___private_Init_Lean_Expr_1__Expr_mkDataCore___closed__1; -x_2 = lean_unsigned_to_nat(761u); +x_2 = lean_unsigned_to_nat(768u); x_3 = lean_unsigned_to_nat(20u); x_4 = l_Lean_Expr_letName_x21___closed__1; x_5 = l___private_Init_Util_1__mkPanicMessage(x_1, x_2, x_3, x_4); @@ -7323,6 +7394,10 @@ l_Lean_Literal_hashable___closed__1 = _init_l_Lean_Literal_hashable___closed__1( lean_mark_persistent(l_Lean_Literal_hashable___closed__1); l_Lean_Literal_hashable = _init_l_Lean_Literal_hashable(); lean_mark_persistent(l_Lean_Literal_hashable); +l_Lean_Literal_hasBeq___closed__1 = _init_l_Lean_Literal_hasBeq___closed__1(); +lean_mark_persistent(l_Lean_Literal_hasBeq___closed__1); +l_Lean_Literal_hasBeq = _init_l_Lean_Literal_hasBeq(); +lean_mark_persistent(l_Lean_Literal_hasBeq); l_Lean_BinderInfo_hashable___closed__1 = _init_l_Lean_BinderInfo_hashable___closed__1(); lean_mark_persistent(l_Lean_BinderInfo_hashable___closed__1); l_Lean_BinderInfo_hashable = _init_l_Lean_BinderInfo_hashable(); diff --git a/stage0/library/Init/Lean/Meta.c b/stage0/library/Init/Lean/Meta.c index 9692f09467..751d935d21 100644 --- a/stage0/library/Init/Lean/Meta.c +++ b/stage0/library/Init/Lean/Meta.c @@ -1,6 +1,6 @@ // Lean compiler output // Module: Init.Lean.Meta -// Imports: Init.Lean.Meta.Basic Init.Lean.Meta.WHNF Init.Lean.Meta.InferType Init.Lean.Meta.FunInfo Init.Lean.Meta.LevelDefEq Init.Lean.Meta.ExprDefEq +// Imports: Init.Lean.Meta.Basic Init.Lean.Meta.LevelDefEq Init.Lean.Meta.WHNF Init.Lean.Meta.InferType Init.Lean.Meta.FunInfo Init.Lean.Meta.ExprDefEq #include "runtime/lean.h" #if defined(__clang__) #pragma clang diagnostic ignored "-Wunused-parameter" @@ -13,31869 +13,11 @@ #ifdef __cplusplus extern "C" { #endif -lean_object* l_Lean_Meta_getFunInfoAuxAux___at_Lean_Meta_getFunInfo___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__13___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_collectDeps(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__43(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Level_normalize___main(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___closed__1; -lean_object* l_Lean_Meta_forallBoundedTelescope___at_Lean_Meta_getFunInfo___spec__3(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_mk_empty_array_with_capacity(lean_object*); -lean_object* l_Lean_mkSort(lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_4__checkConstant(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_isProp___spec__14(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_unreachable_x21___rarg(lean_object*); -lean_object* l_Lean_Meta_lambdaTelescope___at_Lean_Meta_isProp___spec__4(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__23(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__19___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1; -lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__40___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getLevelAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__45(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__18(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_whnfAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_isProp___spec__6(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_mkForall(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_local_ctx_mk_let_decl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_5__checkApp___at_Lean_Meta_check___spec__3(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_4__getRecRuleFor(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__24(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__15___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getExprMVarAssignment___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__7(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassQuick___main(lean_object*, lean_object*, lean_object*); -extern lean_object* l_Array_empty___closed__1; -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__2(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l___private_Init_Lean_WHNF_6__isIdRhsApp(lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__25(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__44(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__38___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(lean_object*, lean_object*, lean_object*); -uint8_t l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(lean_object*); -lean_object* l_Lean_Meta_instantiateLevelMVars(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__47(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_expr_instantiate1(lean_object*, lean_object*); -lean_object* lean_array_push(lean_object*, lean_object*); -lean_object* lean_array_get_size(lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___at_Lean_Meta_isProp___spec__16(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isTypeCorrect(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfo(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_getAppFn___main(lean_object*); -extern lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -lean_object* lean_environment_find(lean_object*, lean_object*); -extern lean_object* l_Lean_Expr_getAppArgs___closed__1; -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__40(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_8__inferFVarType(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___at_Lean_Meta_check___spec__4(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12___rarg___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__22___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_1__getFirstCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__8(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__36(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_nat_add(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__51(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___lambda__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isTypeCorrectAux___at_Lean_Meta_isTypeCorrect___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint___main(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_7__inferMVarType(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Literal_type(lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_mkLevelIMax(lean_object*, lean_object*); -lean_object* l_Lean_RecursorVal_getMajorIdx(lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_array_fget(lean_object*, lean_object*); -lean_object* l_Lean_mkProj(lean_object*, lean_object*, lean_object*); -lean_object* lean_expr_instantiate_rev_range(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(lean_object*, lean_object*, lean_object*); -uint8_t lean_nat_dec_eq(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__16(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__10___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__20(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentHashMap_find___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__23___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_3__toCtorIfLit(lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isProp___spec__8(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_nat_sub(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_2__boolToExpr___boxed(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__17___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_check___spec__9(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_shrink___main___rarg(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__33(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__16___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__42(lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Lean_Expr_hasExprMVar(lean_object*); -lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Expr_2__mkAppRangeAux___main(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__50(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__6(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__16(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_fvarId_x21(lean_object*); -lean_object* l_List_lengthAux___main___rarg(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__23(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___at_Lean_Meta_isProp___spec__3(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__28(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(lean_object*, lean_object*, lean_object*); -lean_object* lean_instantiate_lparams(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_ConstantInfo_name(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__20___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__20___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__50___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Lean_LocalDecl_binderInfo(lean_object*); -lean_object* lean_name_mk_string(lean_object*, lean_object*); -lean_object* l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__19(lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__21___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_2__inferConstType(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__27(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Lean_ConstantInfo_hasValue(lean_object*); -uint8_t l___private_Init_Lean_Meta_1__exprToBool(lean_object*); -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_isProp___spec__17(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__43___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Lean_Expr_isConstOf(lean_object*, lean_object*); -lean_object* l_Lean_Meta_mkFreshId___rarg(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__12___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_check___spec__10(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Expr_3__getAppArgsAux___main(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__41___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Lean_Expr_isForall(lean_object*); -lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_1__exprToBool___boxed(lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_mkFVar(lean_object*); -uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); -lean_object* l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___lambda__1(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Lean_Expr_isLambda(lean_object*); -lean_object* l_Lean_mkLevelMVar(lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__19(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__34(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__10___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__17(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_RecursorVal_getInduct(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__14(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isDefEq(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_LocalDecl_type(lean_object*); -lean_object* l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_LocalDecl_value_x3f(lean_object*); -lean_object* l_Lean_ConstantInfo_lparams(lean_object*); -lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); -lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__21(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__41(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___at_Lean_Meta_isProp___spec__23(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* lean_instantiate_value_lparams(lean_object*, lean_object*); -uint8_t l_Lean_BinderInfo_beq(uint8_t, uint8_t); -lean_object* l___private_Init_Lean_WHNF_7__extractIdRhs(lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_mkLevelSucc(lean_object*); -lean_object* l_Lean_Meta_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__13(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); -uint8_t lean_expr_eqv(lean_object*, lean_object*); -lean_object* l_Lean_Meta_usingDefault(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(lean_object*, lean_object*); -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_check___spec__6(lean_object*, lean_object*, lean_object*); -uint8_t lean_nat_dec_le(lean_object*, lean_object*); -lean_object* l_Lean_mkApp(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___at_Lean_Meta_check___spec__18(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_betaRev(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__20___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getConstAux(lean_object*, uint8_t, lean_object*, lean_object*); -uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__9(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_2__boolToExpr(uint8_t); -lean_object* l_Lean_Expr_updateFn___main(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__12(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuick___main(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__9___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfoNArgs(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__14___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___lambda__1(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__32(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__22(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4___closed__1; -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__19(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__13(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Lean_Expr_hasLooseBVars(lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Expr_Inhabited; -lean_object* lean_mk_array(lean_object*, lean_object*); -lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__21___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12(lean_object*); -lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__15(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isDefEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__8(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__20(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__31(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__47___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__26(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_Meta_isClassQuick___main___closed__1; -lean_object* lean_metavar_ctx_get_expr_assignment(lean_object*, lean_object*); -extern lean_object* l_Lean_Meta_CheckAssignment_check___main___closed__1; -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__17(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1; -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_check___spec__12(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Expr_getRevArgD___main(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isProp(lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12___rarg(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_checkAux___at_Lean_Meta_check___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__48___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_mkConst(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isPropAux___at_Lean_Meta_isProp___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(lean_object*, lean_object*); -extern lean_object* l_Lean_smartUnfoldingSuffix; -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__22(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__20(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__14(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t lean_is_class(lean_object*, lean_object*); -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_isProp___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__19___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint___main___closed__1; -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__15(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_check(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__38(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t lean_nat_dec_lt(lean_object*, lean_object*); -lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__48(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_monadInhabited___rarg(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__21(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_lambdaTelescope___at_Lean_Meta_check___spec__8(lean_object*, lean_object*, lean_object*); -uint8_t l___private_Init_Lean_Meta_1__exprToBool(lean_object* x_1) { -_start: -{ -if (lean_obj_tag(x_1) == 3) -{ -uint8_t x_2; -x_2 = 0; -return x_2; -} -else -{ -uint8_t x_3; -x_3 = 1; -return x_3; -} -} -} -lean_object* l___private_Init_Lean_Meta_1__exprToBool___boxed(lean_object* x_1) { -_start: -{ -uint8_t x_2; lean_object* x_3; -x_2 = l___private_Init_Lean_Meta_1__exprToBool(x_1); -lean_dec(x_1); -x_3 = lean_box(x_2); -return x_3; -} -} -lean_object* l___private_Init_Lean_Meta_2__boolToExpr(uint8_t x_1) { -_start: -{ -if (x_1 == 0) -{ -lean_object* x_2; -x_2 = l_Lean_Expr_getAppArgs___closed__1; -return x_2; -} -else -{ -lean_object* x_3; -x_3 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1; -return x_3; -} -} -} -lean_object* l___private_Init_Lean_Meta_2__boolToExpr___boxed(lean_object* x_1) { -_start: -{ -uint8_t x_2; lean_object* x_3; -x_2 = lean_unbox(x_1); -lean_dec(x_1); -x_3 = l___private_Init_Lean_Meta_2__boolToExpr(x_2); -return x_3; -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; -x_9 = l_Lean_ConstantInfo_lparams(x_4); -x_10 = lean_unsigned_to_nat(0u); -x_11 = l_List_lengthAux___main___rarg(x_9, x_10); -lean_dec(x_9); -x_12 = l_List_lengthAux___main___rarg(x_5, x_10); -x_13 = lean_nat_dec_eq(x_11, x_12); -lean_dec(x_12); -lean_dec(x_11); -if (x_13 == 0) -{ -uint8_t x_14; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_14 = lean_expr_eqv(x_2, x_3); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; -x_15 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_8); -return x_16; -} -else -{ -lean_object* x_17; -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_1); -lean_ctor_set(x_17, 1, x_8); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -lean_dec(x_1); -x_18 = lean_instantiate_value_lparams(x_4, x_5); -x_19 = l_Lean_Expr_betaRev(x_18, x_6); -lean_dec(x_18); -x_20 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_19); -x_21 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_20, x_7, x_8); -return x_21; -} -} -} -lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; lean_object* x_10; uint8_t x_113; lean_object* x_114; -x_113 = lean_ctor_get_uint8(x_4, sizeof(void*)*1); -x_114 = lean_box(x_113); -switch (lean_obj_tag(x_114)) { -case 2: -{ -lean_object* x_115; lean_object* x_116; -x_115 = lean_unsigned_to_nat(5u); -x_116 = lean_unsigned_to_nat(3u); -x_9 = x_115; -x_10 = x_116; -goto block_112; -} -case 3: -{ -lean_object* x_117; lean_object* x_118; -x_117 = lean_unsigned_to_nat(4u); -x_118 = lean_unsigned_to_nat(3u); -x_9 = x_117; -x_10 = x_118; -goto block_112; -} -default: -{ -uint8_t x_119; -lean_dec(x_114); -lean_dec(x_7); -x_119 = lean_expr_eqv(x_2, x_3); -if (x_119 == 0) -{ -lean_object* x_120; lean_object* x_121; -x_120 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_121 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_121, 0, x_120); -lean_ctor_set(x_121, 1, x_8); -return x_121; -} -else -{ -lean_object* x_122; -x_122 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_122, 0, x_1); -lean_ctor_set(x_122, 1, x_8); -return x_122; -} -} -} -block_112: -{ -lean_object* x_11; uint8_t x_12; -x_11 = lean_array_get_size(x_6); -x_12 = lean_nat_dec_lt(x_9, x_11); -if (x_12 == 0) -{ -uint8_t x_13; -lean_dec(x_11); -lean_dec(x_7); -x_13 = lean_expr_eqv(x_2, x_3); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_8); -return x_15; -} -else -{ -lean_object* x_16; -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_1); -lean_ctor_set(x_16, 1, x_8); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_array_fget(x_6, x_9); -lean_inc(x_7); -x_18 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_17, x_7, x_8); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -if (lean_obj_tag(x_19) == 5) -{ -lean_object* x_20; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -if (lean_obj_tag(x_20) == 5) -{ -lean_object* x_21; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -lean_dec(x_20); -if (lean_obj_tag(x_21) == 5) -{ -lean_object* x_22; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -lean_dec(x_21); -if (lean_obj_tag(x_22) == 4) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_object* x_27; -x_23 = lean_ctor_get(x_18, 1); -lean_inc(x_23); -lean_dec(x_18); -x_24 = lean_ctor_get(x_19, 1); -lean_inc(x_24); -lean_dec(x_19); -x_25 = lean_ctor_get(x_22, 0); -lean_inc(x_25); -lean_dec(x_22); -x_26 = 0; -x_27 = l_Lean_Meta_getConstAux(x_25, x_26, x_7, x_23); -if (lean_obj_tag(x_27) == 0) -{ -lean_object* x_28; -x_28 = lean_ctor_get(x_27, 0); -lean_inc(x_28); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_7); -x_29 = !lean_is_exclusive(x_27); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_27, 0); -lean_dec(x_30); -x_31 = lean_expr_eqv(x_2, x_3); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = l_Lean_Expr_updateFn___main(x_1, x_3); -lean_ctor_set(x_27, 0, x_32); -return x_27; -} -else -{ -lean_ctor_set(x_27, 0, x_1); -return x_27; -} -} -else -{ -lean_object* x_33; uint8_t x_34; -x_33 = lean_ctor_get(x_27, 1); -lean_inc(x_33); -lean_dec(x_27); -x_34 = lean_expr_eqv(x_2, x_3); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; -x_35 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_35); -lean_ctor_set(x_36, 1, x_33); -return x_36; -} -else -{ -lean_object* x_37; -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_1); -lean_ctor_set(x_37, 1, x_33); -return x_37; -} -} -} -else -{ -lean_object* x_38; -x_38 = lean_ctor_get(x_28, 0); -lean_inc(x_38); -lean_dec(x_28); -if (lean_obj_tag(x_38) == 4) -{ -lean_object* x_39; uint8_t x_40; lean_object* x_41; -x_39 = lean_ctor_get(x_38, 0); -lean_inc(x_39); -lean_dec(x_38); -x_40 = lean_ctor_get_uint8(x_39, sizeof(void*)*1); -lean_dec(x_39); -x_41 = lean_box(x_40); -if (lean_obj_tag(x_41) == 1) -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -lean_dec(x_1); -x_42 = lean_ctor_get(x_27, 1); -lean_inc(x_42); -lean_dec(x_27); -x_43 = l_Lean_Expr_Inhabited; -x_44 = lean_array_get(x_43, x_6, x_10); -x_45 = l_Lean_mkApp(x_44, x_24); -x_46 = lean_unsigned_to_nat(1u); -x_47 = lean_nat_add(x_9, x_46); -x_48 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_11, x_6, x_47, x_45); -lean_dec(x_11); -x_49 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_48, x_7, x_42); -return x_49; -} -else -{ -uint8_t x_50; -lean_dec(x_41); -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_7); -x_50 = !lean_is_exclusive(x_27); -if (x_50 == 0) -{ -lean_object* x_51; uint8_t x_52; -x_51 = lean_ctor_get(x_27, 0); -lean_dec(x_51); -x_52 = lean_expr_eqv(x_2, x_3); -if (x_52 == 0) -{ -lean_object* x_53; -x_53 = l_Lean_Expr_updateFn___main(x_1, x_3); -lean_ctor_set(x_27, 0, x_53); -return x_27; -} -else -{ -lean_ctor_set(x_27, 0, x_1); -return x_27; -} -} -else -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_27, 1); -lean_inc(x_54); -lean_dec(x_27); -x_55 = lean_expr_eqv(x_2, x_3); -if (x_55 == 0) -{ -lean_object* x_56; lean_object* x_57; -x_56 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_56); -lean_ctor_set(x_57, 1, x_54); -return x_57; -} -else -{ -lean_object* x_58; -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_1); -lean_ctor_set(x_58, 1, x_54); -return x_58; -} -} -} -} -else -{ -uint8_t x_59; -lean_dec(x_38); -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_7); -x_59 = !lean_is_exclusive(x_27); -if (x_59 == 0) -{ -lean_object* x_60; uint8_t x_61; -x_60 = lean_ctor_get(x_27, 0); -lean_dec(x_60); -x_61 = lean_expr_eqv(x_2, x_3); -if (x_61 == 0) -{ -lean_object* x_62; -x_62 = l_Lean_Expr_updateFn___main(x_1, x_3); -lean_ctor_set(x_27, 0, x_62); -return x_27; -} -else -{ -lean_ctor_set(x_27, 0, x_1); -return x_27; -} -} -else -{ -lean_object* x_63; uint8_t x_64; -x_63 = lean_ctor_get(x_27, 1); -lean_inc(x_63); -lean_dec(x_27); -x_64 = lean_expr_eqv(x_2, x_3); -if (x_64 == 0) -{ -lean_object* x_65; lean_object* x_66; -x_65 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_66, 1, x_63); -return x_66; -} -else -{ -lean_object* x_67; -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_1); -lean_ctor_set(x_67, 1, x_63); -return x_67; -} -} -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_24); -lean_dec(x_11); -lean_dec(x_7); -lean_dec(x_1); -x_68 = !lean_is_exclusive(x_27); -if (x_68 == 0) -{ -return x_27; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_27, 0); -x_70 = lean_ctor_get(x_27, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_27); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_7); -x_72 = !lean_is_exclusive(x_18); -if (x_72 == 0) -{ -lean_object* x_73; uint8_t x_74; -x_73 = lean_ctor_get(x_18, 0); -lean_dec(x_73); -x_74 = lean_expr_eqv(x_2, x_3); -if (x_74 == 0) -{ -lean_object* x_75; -x_75 = l_Lean_Expr_updateFn___main(x_1, x_3); -lean_ctor_set(x_18, 0, x_75); -return x_18; -} -else -{ -lean_ctor_set(x_18, 0, x_1); -return x_18; -} -} -else -{ -lean_object* x_76; uint8_t x_77; -x_76 = lean_ctor_get(x_18, 1); -lean_inc(x_76); -lean_dec(x_18); -x_77 = lean_expr_eqv(x_2, x_3); -if (x_77 == 0) -{ -lean_object* x_78; lean_object* x_79; -x_78 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_76); -return x_79; -} -else -{ -lean_object* x_80; -x_80 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_80, 0, x_1); -lean_ctor_set(x_80, 1, x_76); -return x_80; -} -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_21); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_7); -x_81 = !lean_is_exclusive(x_18); -if (x_81 == 0) -{ -lean_object* x_82; uint8_t x_83; -x_82 = lean_ctor_get(x_18, 0); -lean_dec(x_82); -x_83 = lean_expr_eqv(x_2, x_3); -if (x_83 == 0) -{ -lean_object* x_84; -x_84 = l_Lean_Expr_updateFn___main(x_1, x_3); -lean_ctor_set(x_18, 0, x_84); -return x_18; -} -else -{ -lean_ctor_set(x_18, 0, x_1); -return x_18; -} -} -else -{ -lean_object* x_85; uint8_t x_86; -x_85 = lean_ctor_get(x_18, 1); -lean_inc(x_85); -lean_dec(x_18); -x_86 = lean_expr_eqv(x_2, x_3); -if (x_86 == 0) -{ -lean_object* x_87; lean_object* x_88; -x_87 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_88 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_85); -return x_88; -} -else -{ -lean_object* x_89; -x_89 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_89, 0, x_1); -lean_ctor_set(x_89, 1, x_85); -return x_89; -} -} -} -} -else -{ -uint8_t x_90; -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_7); -x_90 = !lean_is_exclusive(x_18); -if (x_90 == 0) -{ -lean_object* x_91; uint8_t x_92; -x_91 = lean_ctor_get(x_18, 0); -lean_dec(x_91); -x_92 = lean_expr_eqv(x_2, x_3); -if (x_92 == 0) -{ -lean_object* x_93; -x_93 = l_Lean_Expr_updateFn___main(x_1, x_3); -lean_ctor_set(x_18, 0, x_93); -return x_18; -} -else -{ -lean_ctor_set(x_18, 0, x_1); -return x_18; -} -} -else -{ -lean_object* x_94; uint8_t x_95; -x_94 = lean_ctor_get(x_18, 1); -lean_inc(x_94); -lean_dec(x_18); -x_95 = lean_expr_eqv(x_2, x_3); -if (x_95 == 0) -{ -lean_object* x_96; lean_object* x_97; -x_96 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_97 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_97, 0, x_96); -lean_ctor_set(x_97, 1, x_94); -return x_97; -} -else -{ -lean_object* x_98; -x_98 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_98, 0, x_1); -lean_ctor_set(x_98, 1, x_94); -return x_98; -} -} -} -} -else -{ -uint8_t x_99; -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_7); -x_99 = !lean_is_exclusive(x_18); -if (x_99 == 0) -{ -lean_object* x_100; uint8_t x_101; -x_100 = lean_ctor_get(x_18, 0); -lean_dec(x_100); -x_101 = lean_expr_eqv(x_2, x_3); -if (x_101 == 0) -{ -lean_object* x_102; -x_102 = l_Lean_Expr_updateFn___main(x_1, x_3); -lean_ctor_set(x_18, 0, x_102); -return x_18; -} -else -{ -lean_ctor_set(x_18, 0, x_1); -return x_18; -} -} -else -{ -lean_object* x_103; uint8_t x_104; -x_103 = lean_ctor_get(x_18, 1); -lean_inc(x_103); -lean_dec(x_18); -x_104 = lean_expr_eqv(x_2, x_3); -if (x_104 == 0) -{ -lean_object* x_105; lean_object* x_106; -x_105 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_106 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_106, 0, x_105); -lean_ctor_set(x_106, 1, x_103); -return x_106; -} -else -{ -lean_object* x_107; -x_107 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_107, 0, x_1); -lean_ctor_set(x_107, 1, x_103); -return x_107; -} -} -} -} -else -{ -uint8_t x_108; -lean_dec(x_11); -lean_dec(x_7); -lean_dec(x_1); -x_108 = !lean_is_exclusive(x_18); -if (x_108 == 0) -{ -return x_18; -} -else -{ -lean_object* x_109; lean_object* x_110; lean_object* x_111; -x_109 = lean_ctor_get(x_18, 0); -x_110 = lean_ctor_get(x_18, 1); -lean_inc(x_110); -lean_inc(x_109); -lean_dec(x_18); -x_111 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_111, 0, x_109); -lean_ctor_set(x_111, 1, x_110); -return x_111; -} -} -} -} -} -} -lean_object* l___private_Init_Lean_WHNF_1__getFirstCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = lean_apply_3(x_1, x_2, x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -lean_object* x_6; -x_6 = lean_ctor_get(x_5, 0); -lean_inc(x_6); -if (lean_obj_tag(x_6) == 0) -{ -uint8_t x_7; -x_7 = !lean_is_exclusive(x_5); -if (x_7 == 0) -{ -lean_object* x_8; lean_object* x_9; -x_8 = lean_ctor_get(x_5, 0); -lean_dec(x_8); -x_9 = lean_box(0); -lean_ctor_set(x_5, 0, x_9); -return x_5; -} -else -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_5, 1); -lean_inc(x_10); -lean_dec(x_5); -x_11 = lean_box(0); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_10); -return x_12; -} -} -else -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_6); -if (x_13 == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_6, 0); -if (lean_obj_tag(x_14) == 5) -{ -lean_object* x_15; lean_object* x_16; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -lean_dec(x_14); -x_16 = lean_ctor_get(x_15, 4); -lean_inc(x_16); -lean_dec(x_15); -if (lean_obj_tag(x_16) == 0) -{ -uint8_t x_17; -lean_free_object(x_6); -x_17 = !lean_is_exclusive(x_5); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_ctor_get(x_5, 0); -lean_dec(x_18); -x_19 = lean_box(0); -lean_ctor_set(x_5, 0, x_19); -return x_5; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_5, 1); -lean_inc(x_20); -lean_dec(x_5); -x_21 = lean_box(0); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_20); -return x_22; -} -} -else -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_5); -if (x_23 == 0) -{ -lean_object* x_24; lean_object* x_25; -x_24 = lean_ctor_get(x_5, 0); -lean_dec(x_24); -x_25 = lean_ctor_get(x_16, 0); -lean_inc(x_25); -lean_dec(x_16); -lean_ctor_set(x_6, 0, x_25); -return x_5; -} -else -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_5, 1); -lean_inc(x_26); -lean_dec(x_5); -x_27 = lean_ctor_get(x_16, 0); -lean_inc(x_27); -lean_dec(x_16); -lean_ctor_set(x_6, 0, x_27); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_6); -lean_ctor_set(x_28, 1, x_26); -return x_28; -} -} -} -else -{ -uint8_t x_29; -lean_free_object(x_6); -lean_dec(x_14); -x_29 = !lean_is_exclusive(x_5); -if (x_29 == 0) -{ -lean_object* x_30; lean_object* x_31; -x_30 = lean_ctor_get(x_5, 0); -lean_dec(x_30); -x_31 = lean_box(0); -lean_ctor_set(x_5, 0, x_31); -return x_5; -} -else -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_32 = lean_ctor_get(x_5, 1); -lean_inc(x_32); -lean_dec(x_5); -x_33 = lean_box(0); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_32); -return x_34; -} -} -} -else -{ -lean_object* x_35; -x_35 = lean_ctor_get(x_6, 0); -lean_inc(x_35); -lean_dec(x_6); -if (lean_obj_tag(x_35) == 5) -{ -lean_object* x_36; lean_object* x_37; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -lean_dec(x_35); -x_37 = lean_ctor_get(x_36, 4); -lean_inc(x_37); -lean_dec(x_36); -if (lean_obj_tag(x_37) == 0) -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_38 = lean_ctor_get(x_5, 1); -lean_inc(x_38); -if (lean_is_exclusive(x_5)) { - lean_ctor_release(x_5, 0); - lean_ctor_release(x_5, 1); - x_39 = x_5; -} else { - lean_dec_ref(x_5); - x_39 = lean_box(0); -} -x_40 = lean_box(0); -if (lean_is_scalar(x_39)) { - x_41 = lean_alloc_ctor(0, 2, 0); -} else { - x_41 = x_39; -} -lean_ctor_set(x_41, 0, x_40); -lean_ctor_set(x_41, 1, x_38); -return x_41; -} -else -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_42 = lean_ctor_get(x_5, 1); -lean_inc(x_42); -if (lean_is_exclusive(x_5)) { - lean_ctor_release(x_5, 0); - lean_ctor_release(x_5, 1); - x_43 = x_5; -} else { - lean_dec_ref(x_5); - x_43 = lean_box(0); -} -x_44 = lean_ctor_get(x_37, 0); -lean_inc(x_44); -lean_dec(x_37); -x_45 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_45, 0, x_44); -if (lean_is_scalar(x_43)) { - x_46 = lean_alloc_ctor(0, 2, 0); -} else { - x_46 = x_43; -} -lean_ctor_set(x_46, 0, x_45); -lean_ctor_set(x_46, 1, x_42); -return x_46; -} -} -else -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_35); -x_47 = lean_ctor_get(x_5, 1); -lean_inc(x_47); -if (lean_is_exclusive(x_5)) { - lean_ctor_release(x_5, 0); - lean_ctor_release(x_5, 1); - x_48 = x_5; -} else { - lean_dec_ref(x_5); - x_48 = lean_box(0); -} -x_49 = lean_box(0); -if (lean_is_scalar(x_48)) { - x_50 = lean_alloc_ctor(0, 2, 0); -} else { - x_50 = x_48; -} -lean_ctor_set(x_50, 0, x_49); -lean_ctor_set(x_50, 1, x_47); -return x_50; -} -} -} -} -else -{ -uint8_t x_51; -x_51 = !lean_is_exclusive(x_5); -if (x_51 == 0) -{ -return x_5; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_5, 0); -x_53 = lean_ctor_get(x_5, 1); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_5); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; -} -} -} -} -lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Expr_getAppFn___main(x_2); -if (lean_obj_tag(x_6) == 4) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); -lean_dec(x_6); -x_9 = l___private_Init_Lean_WHNF_1__getFirstCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__8(x_1, x_7, x_4, x_5); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -if (lean_obj_tag(x_10) == 0) -{ -uint8_t x_11; -lean_dec(x_8); -lean_dec(x_2); -x_11 = !lean_is_exclusive(x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -x_12 = lean_ctor_get(x_9, 0); -lean_dec(x_12); -x_13 = lean_box(0); -lean_ctor_set(x_9, 0, x_13); -return x_9; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_9, 1); -lean_inc(x_14); -lean_dec(x_9); -x_15 = lean_box(0); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_14); -return x_16; -} -} -else -{ -uint8_t x_17; -x_17 = !lean_is_exclusive(x_9); -if (x_17 == 0) -{ -lean_object* x_18; uint8_t x_19; -x_18 = lean_ctor_get(x_9, 0); -lean_dec(x_18); -x_19 = !lean_is_exclusive(x_10); -if (x_19 == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_20 = lean_ctor_get(x_10, 0); -x_21 = l_Lean_mkConst(x_20, x_8); -x_22 = lean_unsigned_to_nat(0u); -x_23 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_22); -x_24 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_23); -x_25 = lean_mk_array(x_23, x_24); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_sub(x_23, x_26); -lean_dec(x_23); -x_28 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_25, x_27); -x_29 = l_Array_shrink___main___rarg(x_28, x_3); -x_30 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_29, x_29, x_22, x_21); -lean_dec(x_29); -lean_ctor_set(x_10, 0, x_30); -return x_9; -} -else -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_31 = lean_ctor_get(x_10, 0); -lean_inc(x_31); -lean_dec(x_10); -x_32 = l_Lean_mkConst(x_31, x_8); -x_33 = lean_unsigned_to_nat(0u); -x_34 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_33); -x_35 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_34); -x_36 = lean_mk_array(x_34, x_35); -x_37 = lean_unsigned_to_nat(1u); -x_38 = lean_nat_sub(x_34, x_37); -lean_dec(x_34); -x_39 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_36, x_38); -x_40 = l_Array_shrink___main___rarg(x_39, x_3); -x_41 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_40, x_40, x_33, x_32); -lean_dec(x_40); -x_42 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_42, 0, x_41); -lean_ctor_set(x_9, 0, x_42); -return x_9; -} -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_43 = lean_ctor_get(x_9, 1); -lean_inc(x_43); -lean_dec(x_9); -x_44 = lean_ctor_get(x_10, 0); -lean_inc(x_44); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - x_45 = x_10; -} else { - lean_dec_ref(x_10); - x_45 = lean_box(0); -} -x_46 = l_Lean_mkConst(x_44, x_8); -x_47 = lean_unsigned_to_nat(0u); -x_48 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_47); -x_49 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_48); -x_50 = lean_mk_array(x_48, x_49); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_sub(x_48, x_51); -lean_dec(x_48); -x_53 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_50, x_52); -x_54 = l_Array_shrink___main___rarg(x_53, x_3); -x_55 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_54, x_54, x_47, x_46); -lean_dec(x_54); -if (lean_is_scalar(x_45)) { - x_56 = lean_alloc_ctor(1, 1, 0); -} else { - x_56 = x_45; -} -lean_ctor_set(x_56, 0, x_55); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_56); -lean_ctor_set(x_57, 1, x_43); -return x_57; -} -} -} -else -{ -uint8_t x_58; -lean_dec(x_8); -lean_dec(x_2); -x_58 = !lean_is_exclusive(x_9); -if (x_58 == 0) -{ -return x_9; -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_9, 0); -x_60 = lean_ctor_get(x_9, 1); -lean_inc(x_60); -lean_inc(x_59); -lean_dec(x_9); -x_61 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_61, 0, x_59); -lean_ctor_set(x_61, 1, x_60); -return x_61; -} -} -} -else -{ -lean_object* x_62; lean_object* x_63; -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_62 = lean_box(0); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_62); -lean_ctor_set(x_63, 1, x_5); -return x_63; -} -} -} -uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__9(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -uint8_t x_5; -x_5 = lean_nat_dec_lt(x_4, x_3); -if (x_5 == 0) -{ -uint8_t x_6; -lean_dec(x_4); -x_6 = 0; -return x_6; -} -else -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_fget(x_2, x_4); -x_8 = l_Lean_Expr_hasExprMVar(x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; -x_9 = lean_unsigned_to_nat(1u); -x_10 = lean_nat_add(x_4, x_9); -lean_dec(x_4); -x_4 = x_10; -goto _start; -} -else -{ -lean_dec(x_4); -return x_8; -} -} -} -} -uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__10(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -uint8_t x_6; -x_6 = lean_nat_dec_lt(x_5, x_4); -if (x_6 == 0) -{ -uint8_t x_7; -lean_dec(x_5); -x_7 = 0; -return x_7; -} -else -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_fget(x_3, x_5); -x_9 = l_Lean_Expr_hasExprMVar(x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_add(x_5, x_10); -lean_dec(x_5); -x_2 = lean_box(0); -x_5 = x_11; -goto _start; -} -else -{ -lean_dec(x_5); -return x_9; -} -} -} -} -lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -uint8_t x_5; lean_object* x_6; -x_5 = 1; -lean_inc(x_3); -lean_inc(x_2); -x_6 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_2, x_2, x_3, x_4); -lean_dec(x_2); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); -lean_dec(x_6); -lean_inc(x_3); -x_9 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_7, x_3, x_8); -if (lean_obj_tag(x_9) == 0) -{ -uint8_t x_10; -x_10 = !lean_is_exclusive(x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; -x_11 = lean_ctor_get(x_9, 0); -x_12 = lean_ctor_get(x_9, 1); -x_13 = l_Lean_Expr_getAppFn___main(x_11); -x_14 = l_Lean_RecursorVal_getInduct(x_1); -x_15 = l_Lean_Expr_isConstOf(x_13, x_14); -lean_dec(x_14); -lean_dec(x_13); -if (x_15 == 0) -{ -lean_object* x_16; -lean_dec(x_11); -lean_dec(x_3); -lean_dec(x_1); -x_16 = lean_box(0); -lean_ctor_set(x_9, 0, x_16); -return x_9; -} -else -{ -uint8_t x_17; -x_17 = l_Lean_Expr_hasExprMVar(x_11); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -lean_free_object(x_9); -x_18 = lean_ctor_get(x_1, 2); -lean_inc(x_18); -lean_dec(x_1); -x_19 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -lean_inc(x_3); -x_20 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(x_19, x_11, x_18, x_3, x_12); -lean_dec(x_18); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -if (lean_obj_tag(x_21) == 0) -{ -uint8_t x_22; -lean_dec(x_3); -x_22 = !lean_is_exclusive(x_20); -if (x_22 == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_20, 0); -lean_dec(x_23); -return x_20; -} -else -{ -lean_object* x_24; lean_object* x_25; -x_24 = lean_ctor_get(x_20, 1); -lean_inc(x_24); -lean_dec(x_20); -x_25 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_25, 0, x_21); -lean_ctor_set(x_25, 1, x_24); -return x_25; -} -} -else -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_20, 1); -lean_inc(x_26); -lean_dec(x_20); -x_27 = lean_ctor_get(x_21, 0); -lean_inc(x_27); -lean_dec(x_21); -lean_inc(x_27); -x_28 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_27, x_27, x_3, x_26); -lean_dec(x_27); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_28); -if (x_29 == 0) -{ -lean_object* x_30; lean_object* x_31; -x_30 = lean_ctor_get(x_28, 0); -lean_dec(x_30); -x_31 = lean_box(0); -lean_ctor_set(x_28, 0, x_31); -return x_28; -} -else -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_32 = lean_ctor_get(x_28, 1); -lean_inc(x_32); -lean_dec(x_28); -x_33 = lean_box(0); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_32); -return x_34; -} -} -else -{ -uint8_t x_35; -x_35 = !lean_is_exclusive(x_28); -if (x_35 == 0) -{ -return x_28; -} -else -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_28, 0); -x_37 = lean_ctor_get(x_28, 1); -lean_inc(x_37); -lean_inc(x_36); -lean_dec(x_28); -x_38 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_38, 0, x_36); -lean_ctor_set(x_38, 1, x_37); -return x_38; -} -} -} -} -else -{ -uint8_t x_39; -lean_dec(x_3); -x_39 = !lean_is_exclusive(x_20); -if (x_39 == 0) -{ -return x_20; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_40 = lean_ctor_get(x_20, 0); -x_41 = lean_ctor_get(x_20, 1); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_20); -x_42 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_42, 0, x_40); -lean_ctor_set(x_42, 1, x_41); -return x_42; -} -} -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; uint8_t x_52; -x_43 = lean_unsigned_to_nat(0u); -x_44 = l_Lean_Expr_getAppNumArgsAux___main(x_11, x_43); -x_45 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_44); -x_46 = lean_mk_array(x_44, x_45); -x_47 = lean_unsigned_to_nat(1u); -x_48 = lean_nat_sub(x_44, x_47); -lean_dec(x_44); -lean_inc(x_11); -x_49 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_11, x_46, x_48); -x_50 = lean_ctor_get(x_1, 2); -lean_inc(x_50); -lean_dec(x_1); -x_51 = lean_array_get_size(x_49); -x_52 = lean_nat_dec_le(x_51, x_51); -if (x_52 == 0) -{ -uint8_t x_53; -lean_inc(x_50); -x_53 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__9(x_11, x_49, x_51, x_50); -lean_dec(x_51); -lean_dec(x_49); -if (x_53 == 0) -{ -lean_object* x_54; lean_object* x_55; -lean_free_object(x_9); -x_54 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -lean_inc(x_3); -x_55 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(x_54, x_11, x_50, x_3, x_12); -lean_dec(x_50); -if (lean_obj_tag(x_55) == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_55, 0); -lean_inc(x_56); -if (lean_obj_tag(x_56) == 0) -{ -uint8_t x_57; -lean_dec(x_3); -x_57 = !lean_is_exclusive(x_55); -if (x_57 == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_55, 0); -lean_dec(x_58); -return x_55; -} -else -{ -lean_object* x_59; lean_object* x_60; -x_59 = lean_ctor_get(x_55, 1); -lean_inc(x_59); -lean_dec(x_55); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_56); -lean_ctor_set(x_60, 1, x_59); -return x_60; -} -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_55, 1); -lean_inc(x_61); -lean_dec(x_55); -x_62 = lean_ctor_get(x_56, 0); -lean_inc(x_62); -lean_dec(x_56); -lean_inc(x_62); -x_63 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_62, x_62, x_3, x_61); -lean_dec(x_62); -if (lean_obj_tag(x_63) == 0) -{ -uint8_t x_64; -x_64 = !lean_is_exclusive(x_63); -if (x_64 == 0) -{ -lean_object* x_65; lean_object* x_66; -x_65 = lean_ctor_get(x_63, 0); -lean_dec(x_65); -x_66 = lean_box(0); -lean_ctor_set(x_63, 0, x_66); -return x_63; -} -else -{ -lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_67 = lean_ctor_get(x_63, 1); -lean_inc(x_67); -lean_dec(x_63); -x_68 = lean_box(0); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_67); -return x_69; -} -} -else -{ -uint8_t x_70; -x_70 = !lean_is_exclusive(x_63); -if (x_70 == 0) -{ -return x_63; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_63, 0); -x_72 = lean_ctor_get(x_63, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_63); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_3); -x_74 = !lean_is_exclusive(x_55); -if (x_74 == 0) -{ -return x_55; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_55, 0); -x_76 = lean_ctor_get(x_55, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_55); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -lean_object* x_78; -lean_dec(x_50); -lean_dec(x_11); -lean_dec(x_3); -x_78 = lean_box(0); -lean_ctor_set(x_9, 0, x_78); -return x_9; -} -} -else -{ -uint8_t x_79; -lean_inc(x_50); -x_79 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__10(x_11, lean_box(0), x_49, x_51, x_50); -lean_dec(x_51); -lean_dec(x_49); -if (x_79 == 0) -{ -lean_object* x_80; lean_object* x_81; -lean_free_object(x_9); -x_80 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -lean_inc(x_3); -x_81 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(x_80, x_11, x_50, x_3, x_12); -lean_dec(x_50); -if (lean_obj_tag(x_81) == 0) -{ -lean_object* x_82; -x_82 = lean_ctor_get(x_81, 0); -lean_inc(x_82); -if (lean_obj_tag(x_82) == 0) -{ -uint8_t x_83; -lean_dec(x_3); -x_83 = !lean_is_exclusive(x_81); -if (x_83 == 0) -{ -lean_object* x_84; -x_84 = lean_ctor_get(x_81, 0); -lean_dec(x_84); -return x_81; -} -else -{ -lean_object* x_85; lean_object* x_86; -x_85 = lean_ctor_get(x_81, 1); -lean_inc(x_85); -lean_dec(x_81); -x_86 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_86, 0, x_82); -lean_ctor_set(x_86, 1, x_85); -return x_86; -} -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_81, 1); -lean_inc(x_87); -lean_dec(x_81); -x_88 = lean_ctor_get(x_82, 0); -lean_inc(x_88); -lean_dec(x_82); -lean_inc(x_88); -x_89 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_88, x_88, x_3, x_87); -lean_dec(x_88); -if (lean_obj_tag(x_89) == 0) -{ -uint8_t x_90; -x_90 = !lean_is_exclusive(x_89); -if (x_90 == 0) -{ -lean_object* x_91; lean_object* x_92; -x_91 = lean_ctor_get(x_89, 0); -lean_dec(x_91); -x_92 = lean_box(0); -lean_ctor_set(x_89, 0, x_92); -return x_89; -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_93 = lean_ctor_get(x_89, 1); -lean_inc(x_93); -lean_dec(x_89); -x_94 = lean_box(0); -x_95 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_95, 0, x_94); -lean_ctor_set(x_95, 1, x_93); -return x_95; -} -} -else -{ -uint8_t x_96; -x_96 = !lean_is_exclusive(x_89); -if (x_96 == 0) -{ -return x_89; -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_89, 0); -x_98 = lean_ctor_get(x_89, 1); -lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_89); -x_99 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_99, 0, x_97); -lean_ctor_set(x_99, 1, x_98); -return x_99; -} -} -} -} -else -{ -uint8_t x_100; -lean_dec(x_3); -x_100 = !lean_is_exclusive(x_81); -if (x_100 == 0) -{ -return x_81; -} -else -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_81, 0); -x_102 = lean_ctor_get(x_81, 1); -lean_inc(x_102); -lean_inc(x_101); -lean_dec(x_81); -x_103 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_103, 0, x_101); -lean_ctor_set(x_103, 1, x_102); -return x_103; -} -} -} -else -{ -lean_object* x_104; -lean_dec(x_50); -lean_dec(x_11); -lean_dec(x_3); -x_104 = lean_box(0); -lean_ctor_set(x_9, 0, x_104); -return x_9; -} -} -} -} -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; uint8_t x_109; -x_105 = lean_ctor_get(x_9, 0); -x_106 = lean_ctor_get(x_9, 1); -lean_inc(x_106); -lean_inc(x_105); -lean_dec(x_9); -x_107 = l_Lean_Expr_getAppFn___main(x_105); -x_108 = l_Lean_RecursorVal_getInduct(x_1); -x_109 = l_Lean_Expr_isConstOf(x_107, x_108); -lean_dec(x_108); -lean_dec(x_107); -if (x_109 == 0) -{ -lean_object* x_110; lean_object* x_111; -lean_dec(x_105); -lean_dec(x_3); -lean_dec(x_1); -x_110 = lean_box(0); -x_111 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_111, 0, x_110); -lean_ctor_set(x_111, 1, x_106); -return x_111; -} -else -{ -uint8_t x_112; -x_112 = l_Lean_Expr_hasExprMVar(x_105); -if (x_112 == 0) -{ -lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_113 = lean_ctor_get(x_1, 2); -lean_inc(x_113); -lean_dec(x_1); -x_114 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -lean_inc(x_3); -x_115 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(x_114, x_105, x_113, x_3, x_106); -lean_dec(x_113); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -if (lean_obj_tag(x_116) == 0) -{ -lean_object* x_117; lean_object* x_118; lean_object* x_119; -lean_dec(x_3); -x_117 = lean_ctor_get(x_115, 1); -lean_inc(x_117); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_118 = x_115; -} else { - lean_dec_ref(x_115); - x_118 = lean_box(0); -} -if (lean_is_scalar(x_118)) { - x_119 = lean_alloc_ctor(0, 2, 0); -} else { - x_119 = x_118; -} -lean_ctor_set(x_119, 0, x_116); -lean_ctor_set(x_119, 1, x_117); -return x_119; -} -else -{ -lean_object* x_120; lean_object* x_121; lean_object* x_122; -x_120 = lean_ctor_get(x_115, 1); -lean_inc(x_120); -lean_dec(x_115); -x_121 = lean_ctor_get(x_116, 0); -lean_inc(x_121); -lean_dec(x_116); -lean_inc(x_121); -x_122 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_121, x_121, x_3, x_120); -lean_dec(x_121); -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_123 = lean_ctor_get(x_122, 1); -lean_inc(x_123); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_124 = x_122; -} else { - lean_dec_ref(x_122); - x_124 = lean_box(0); -} -x_125 = lean_box(0); -if (lean_is_scalar(x_124)) { - x_126 = lean_alloc_ctor(0, 2, 0); -} else { - x_126 = x_124; -} -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_123); -return x_126; -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_127 = lean_ctor_get(x_122, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_122, 1); -lean_inc(x_128); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_129 = x_122; -} else { - lean_dec_ref(x_122); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(1, 2, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_127); -lean_ctor_set(x_130, 1, x_128); -return x_130; -} -} -} -else -{ -lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; -lean_dec(x_3); -x_131 = lean_ctor_get(x_115, 0); -lean_inc(x_131); -x_132 = lean_ctor_get(x_115, 1); -lean_inc(x_132); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - x_133 = x_115; -} else { - lean_dec_ref(x_115); - x_133 = lean_box(0); -} -if (lean_is_scalar(x_133)) { - x_134 = lean_alloc_ctor(1, 2, 0); -} else { - x_134 = x_133; -} -lean_ctor_set(x_134, 0, x_131); -lean_ctor_set(x_134, 1, x_132); -return x_134; -} -} -else -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; uint8_t x_144; -x_135 = lean_unsigned_to_nat(0u); -x_136 = l_Lean_Expr_getAppNumArgsAux___main(x_105, x_135); -x_137 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_136); -x_138 = lean_mk_array(x_136, x_137); -x_139 = lean_unsigned_to_nat(1u); -x_140 = lean_nat_sub(x_136, x_139); -lean_dec(x_136); -lean_inc(x_105); -x_141 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_105, x_138, x_140); -x_142 = lean_ctor_get(x_1, 2); -lean_inc(x_142); -lean_dec(x_1); -x_143 = lean_array_get_size(x_141); -x_144 = lean_nat_dec_le(x_143, x_143); -if (x_144 == 0) -{ -uint8_t x_145; -lean_inc(x_142); -x_145 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__9(x_105, x_141, x_143, x_142); -lean_dec(x_143); -lean_dec(x_141); -if (x_145 == 0) -{ -lean_object* x_146; lean_object* x_147; -x_146 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -lean_inc(x_3); -x_147 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(x_146, x_105, x_142, x_3, x_106); -lean_dec(x_142); -if (lean_obj_tag(x_147) == 0) -{ -lean_object* x_148; -x_148 = lean_ctor_get(x_147, 0); -lean_inc(x_148); -if (lean_obj_tag(x_148) == 0) -{ -lean_object* x_149; lean_object* x_150; lean_object* x_151; -lean_dec(x_3); -x_149 = lean_ctor_get(x_147, 1); -lean_inc(x_149); -if (lean_is_exclusive(x_147)) { - lean_ctor_release(x_147, 0); - lean_ctor_release(x_147, 1); - x_150 = x_147; -} else { - lean_dec_ref(x_147); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 2, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_148); -lean_ctor_set(x_151, 1, x_149); -return x_151; -} -else -{ -lean_object* x_152; lean_object* x_153; lean_object* x_154; -x_152 = lean_ctor_get(x_147, 1); -lean_inc(x_152); -lean_dec(x_147); -x_153 = lean_ctor_get(x_148, 0); -lean_inc(x_153); -lean_dec(x_148); -lean_inc(x_153); -x_154 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_153, x_153, x_3, x_152); -lean_dec(x_153); -if (lean_obj_tag(x_154) == 0) -{ -lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_155 = lean_ctor_get(x_154, 1); -lean_inc(x_155); -if (lean_is_exclusive(x_154)) { - lean_ctor_release(x_154, 0); - lean_ctor_release(x_154, 1); - x_156 = x_154; -} else { - lean_dec_ref(x_154); - x_156 = lean_box(0); -} -x_157 = lean_box(0); -if (lean_is_scalar(x_156)) { - x_158 = lean_alloc_ctor(0, 2, 0); -} else { - x_158 = x_156; -} -lean_ctor_set(x_158, 0, x_157); -lean_ctor_set(x_158, 1, x_155); -return x_158; -} -else -{ -lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_159 = lean_ctor_get(x_154, 0); -lean_inc(x_159); -x_160 = lean_ctor_get(x_154, 1); -lean_inc(x_160); -if (lean_is_exclusive(x_154)) { - lean_ctor_release(x_154, 0); - lean_ctor_release(x_154, 1); - x_161 = x_154; -} else { - lean_dec_ref(x_154); - x_161 = lean_box(0); -} -if (lean_is_scalar(x_161)) { - x_162 = lean_alloc_ctor(1, 2, 0); -} else { - x_162 = x_161; -} -lean_ctor_set(x_162, 0, x_159); -lean_ctor_set(x_162, 1, x_160); -return x_162; -} -} -} -else -{ -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_3); -x_163 = lean_ctor_get(x_147, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_147, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_147)) { - lean_ctor_release(x_147, 0); - lean_ctor_release(x_147, 1); - x_165 = x_147; -} else { - lean_dec_ref(x_147); - x_165 = lean_box(0); -} -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(1, 2, 0); -} else { - x_166 = x_165; -} -lean_ctor_set(x_166, 0, x_163); -lean_ctor_set(x_166, 1, x_164); -return x_166; -} -} -else -{ -lean_object* x_167; lean_object* x_168; -lean_dec(x_142); -lean_dec(x_105); -lean_dec(x_3); -x_167 = lean_box(0); -x_168 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_168, 0, x_167); -lean_ctor_set(x_168, 1, x_106); -return x_168; -} -} -else -{ -uint8_t x_169; -lean_inc(x_142); -x_169 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__10(x_105, lean_box(0), x_141, x_143, x_142); -lean_dec(x_143); -lean_dec(x_141); -if (x_169 == 0) -{ -lean_object* x_170; lean_object* x_171; -x_170 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -lean_inc(x_3); -x_171 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(x_170, x_105, x_142, x_3, x_106); -lean_dec(x_142); -if (lean_obj_tag(x_171) == 0) -{ -lean_object* x_172; -x_172 = lean_ctor_get(x_171, 0); -lean_inc(x_172); -if (lean_obj_tag(x_172) == 0) -{ -lean_object* x_173; lean_object* x_174; lean_object* x_175; -lean_dec(x_3); -x_173 = lean_ctor_get(x_171, 1); -lean_inc(x_173); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_174 = x_171; -} else { - lean_dec_ref(x_171); - x_174 = lean_box(0); -} -if (lean_is_scalar(x_174)) { - x_175 = lean_alloc_ctor(0, 2, 0); -} else { - x_175 = x_174; -} -lean_ctor_set(x_175, 0, x_172); -lean_ctor_set(x_175, 1, x_173); -return x_175; -} -else -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; -x_176 = lean_ctor_get(x_171, 1); -lean_inc(x_176); -lean_dec(x_171); -x_177 = lean_ctor_get(x_172, 0); -lean_inc(x_177); -lean_dec(x_172); -lean_inc(x_177); -x_178 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_177, x_177, x_3, x_176); -lean_dec(x_177); -if (lean_obj_tag(x_178) == 0) -{ -lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; -x_179 = lean_ctor_get(x_178, 1); -lean_inc(x_179); -if (lean_is_exclusive(x_178)) { - lean_ctor_release(x_178, 0); - lean_ctor_release(x_178, 1); - x_180 = x_178; -} else { - lean_dec_ref(x_178); - x_180 = lean_box(0); -} -x_181 = lean_box(0); -if (lean_is_scalar(x_180)) { - x_182 = lean_alloc_ctor(0, 2, 0); -} else { - x_182 = x_180; -} -lean_ctor_set(x_182, 0, x_181); -lean_ctor_set(x_182, 1, x_179); -return x_182; -} -else -{ -lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; -x_183 = lean_ctor_get(x_178, 0); -lean_inc(x_183); -x_184 = lean_ctor_get(x_178, 1); -lean_inc(x_184); -if (lean_is_exclusive(x_178)) { - lean_ctor_release(x_178, 0); - lean_ctor_release(x_178, 1); - x_185 = x_178; -} else { - lean_dec_ref(x_178); - x_185 = lean_box(0); -} -if (lean_is_scalar(x_185)) { - x_186 = lean_alloc_ctor(1, 2, 0); -} else { - x_186 = x_185; -} -lean_ctor_set(x_186, 0, x_183); -lean_ctor_set(x_186, 1, x_184); -return x_186; -} -} -} -else -{ -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; -lean_dec(x_3); -x_187 = lean_ctor_get(x_171, 0); -lean_inc(x_187); -x_188 = lean_ctor_get(x_171, 1); -lean_inc(x_188); -if (lean_is_exclusive(x_171)) { - lean_ctor_release(x_171, 0); - lean_ctor_release(x_171, 1); - x_189 = x_171; -} else { - lean_dec_ref(x_171); - x_189 = lean_box(0); -} -if (lean_is_scalar(x_189)) { - x_190 = lean_alloc_ctor(1, 2, 0); -} else { - x_190 = x_189; -} -lean_ctor_set(x_190, 0, x_187); -lean_ctor_set(x_190, 1, x_188); -return x_190; -} -} -else -{ -lean_object* x_191; lean_object* x_192; -lean_dec(x_142); -lean_dec(x_105); -lean_dec(x_3); -x_191 = lean_box(0); -x_192 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_192, 0, x_191); -lean_ctor_set(x_192, 1, x_106); -return x_192; -} -} -} -} -} -} -else -{ -uint8_t x_193; -lean_dec(x_3); -lean_dec(x_1); -x_193 = !lean_is_exclusive(x_9); -if (x_193 == 0) -{ -return x_9; -} -else -{ -lean_object* x_194; lean_object* x_195; lean_object* x_196; -x_194 = lean_ctor_get(x_9, 0); -x_195 = lean_ctor_get(x_9, 1); -lean_inc(x_195); -lean_inc(x_194); -lean_dec(x_9); -x_196 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_196, 0, x_194); -lean_ctor_set(x_196, 1, x_195); -return x_196; -} -} -} -else -{ -uint8_t x_197; -lean_dec(x_3); -lean_dec(x_1); -x_197 = !lean_is_exclusive(x_6); -if (x_197 == 0) -{ -return x_6; -} -else -{ -lean_object* x_198; lean_object* x_199; lean_object* x_200; -x_198 = lean_ctor_get(x_6, 0); -x_199 = lean_ctor_get(x_6, 1); -lean_inc(x_199); -lean_inc(x_198); -lean_dec(x_6); -x_200 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_200, 0, x_198); -lean_ctor_set(x_200, 1, x_199); -return x_200; -} -} -} -} -lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = l_Lean_RecursorVal_getMajorIdx(x_4); -x_10 = lean_array_get_size(x_6); -x_11 = lean_nat_dec_lt(x_9, x_10); -if (x_11 == 0) -{ -uint8_t x_12; -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -x_12 = lean_expr_eqv(x_2, x_3); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_8); -return x_14; -} -else -{ -lean_object* x_15; -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_1); -lean_ctor_set(x_15, 1, x_8); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; -x_16 = lean_array_fget(x_6, x_9); -lean_inc(x_7); -x_17 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_16, x_7, x_8); -if (lean_obj_tag(x_17) == 0) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_62; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_17, 1); -lean_inc(x_19); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - x_20 = x_17; -} else { - lean_dec_ref(x_17); - x_20 = lean_box(0); -} -x_62 = lean_ctor_get_uint8(x_4, sizeof(void*)*7); -if (x_62 == 0) -{ -lean_object* x_63; lean_object* x_64; -lean_dec(x_20); -x_63 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_18); -lean_dec(x_18); -lean_inc(x_4); -x_64 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_63); -if (lean_obj_tag(x_64) == 0) -{ -uint8_t x_65; -lean_dec(x_63); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -x_65 = lean_expr_eqv(x_2, x_3); -if (x_65 == 0) -{ -lean_object* x_66; lean_object* x_67; -x_66 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_66); -lean_ctor_set(x_67, 1, x_19); -return x_67; -} -else -{ -lean_object* x_68; -x_68 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_68, 0, x_1); -lean_ctor_set(x_68, 1, x_19); -return x_68; -} -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; uint8_t x_81; -x_69 = lean_ctor_get(x_64, 0); -lean_inc(x_69); -lean_dec(x_64); -x_70 = lean_unsigned_to_nat(0u); -x_71 = l_Lean_Expr_getAppNumArgsAux___main(x_63, x_70); -x_72 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_71); -x_73 = lean_mk_array(x_71, x_72); -x_74 = lean_unsigned_to_nat(1u); -x_75 = lean_nat_sub(x_71, x_74); -lean_dec(x_71); -x_76 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_63, x_73, x_75); -x_77 = l_List_lengthAux___main___rarg(x_5, x_70); -x_78 = lean_ctor_get(x_4, 0); -lean_inc(x_78); -x_79 = lean_ctor_get(x_78, 1); -lean_inc(x_79); -lean_dec(x_78); -x_80 = l_List_lengthAux___main___rarg(x_79, x_70); -x_81 = lean_nat_dec_eq(x_77, x_80); -lean_dec(x_80); -lean_dec(x_77); -if (x_81 == 0) -{ -uint8_t x_82; -lean_dec(x_79); -lean_dec(x_76); -lean_dec(x_69); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -x_82 = lean_expr_eqv(x_2, x_3); -if (x_82 == 0) -{ -lean_object* x_83; lean_object* x_84; -x_83 = l_Lean_Expr_updateFn___main(x_1, x_3); -x_84 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_84, 0, x_83); -lean_ctor_set(x_84, 1, x_19); -return x_84; -} -else -{ -lean_object* x_85; -x_85 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_85, 0, x_1); -lean_ctor_set(x_85, 1, x_19); -return x_85; -} -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -lean_dec(x_1); -x_86 = lean_ctor_get(x_69, 2); -lean_inc(x_86); -x_87 = lean_instantiate_lparams(x_86, x_79, x_5); -x_88 = lean_ctor_get(x_4, 2); -lean_inc(x_88); -x_89 = lean_ctor_get(x_4, 4); -lean_inc(x_89); -x_90 = lean_nat_add(x_88, x_89); -lean_dec(x_89); -lean_dec(x_88); -x_91 = lean_ctor_get(x_4, 5); -lean_inc(x_91); -lean_dec(x_4); -x_92 = lean_nat_add(x_90, x_91); -lean_dec(x_91); -lean_dec(x_90); -x_93 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_92, x_6, x_70, x_87); -lean_dec(x_92); -x_94 = lean_array_get_size(x_76); -x_95 = lean_ctor_get(x_69, 1); -lean_inc(x_95); -lean_dec(x_69); -x_96 = lean_nat_sub(x_94, x_95); -lean_dec(x_95); -x_97 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_94, x_76, x_96, x_93); -lean_dec(x_76); -lean_dec(x_94); -x_98 = lean_nat_add(x_9, x_74); -lean_dec(x_9); -x_99 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_98, x_97); -lean_dec(x_10); -x_100 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_99, x_7, x_19); -return x_100; -} -} -} -else -{ -lean_object* x_101; -lean_inc(x_7); -lean_inc(x_18); -lean_inc(x_4); -x_101 = l___private_Init_Lean_WHNF_5__toCtorWhenK___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__6(x_4, x_18, x_7, x_19); -if (lean_obj_tag(x_101) == 0) -{ -lean_object* x_102; -x_102 = lean_ctor_get(x_101, 0); -lean_inc(x_102); -if (lean_obj_tag(x_102) == 0) -{ -lean_object* x_103; -x_103 = lean_ctor_get(x_101, 1); -lean_inc(x_103); -lean_dec(x_101); -x_21 = x_18; -x_22 = x_103; -goto block_61; -} -else -{ -lean_object* x_104; lean_object* x_105; -lean_dec(x_18); -x_104 = lean_ctor_get(x_101, 1); -lean_inc(x_104); -lean_dec(x_101); -x_105 = lean_ctor_get(x_102, 0); -lean_inc(x_105); -lean_dec(x_102); -x_21 = x_105; -x_22 = x_104; -goto block_61; -} -} -else -{ -uint8_t x_106; -lean_dec(x_20); -lean_dec(x_18); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_106 = !lean_is_exclusive(x_101); -if (x_106 == 0) -{ -return x_101; -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; -x_107 = lean_ctor_get(x_101, 0); -x_108 = lean_ctor_get(x_101, 1); -lean_inc(x_108); -lean_inc(x_107); -lean_dec(x_101); -x_109 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_109, 0, x_107); -lean_ctor_set(x_109, 1, x_108); -return x_109; -} -} -} -block_61: -{ -lean_object* x_23; lean_object* x_24; -x_23 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_21); -lean_dec(x_21); -lean_inc(x_4); -x_24 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_23); -if (lean_obj_tag(x_24) == 0) -{ -uint8_t x_25; -lean_dec(x_23); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -x_25 = lean_expr_eqv(x_2, x_3); -if (x_25 == 0) -{ -lean_object* x_26; lean_object* x_27; -x_26 = l_Lean_Expr_updateFn___main(x_1, x_3); -if (lean_is_scalar(x_20)) { - x_27 = lean_alloc_ctor(0, 2, 0); -} else { - x_27 = x_20; -} -lean_ctor_set(x_27, 0, x_26); -lean_ctor_set(x_27, 1, x_22); -return x_27; -} -else -{ -lean_object* x_28; -if (lean_is_scalar(x_20)) { - x_28 = lean_alloc_ctor(0, 2, 0); -} else { - x_28 = x_20; -} -lean_ctor_set(x_28, 0, x_1); -lean_ctor_set(x_28, 1, x_22); -return x_28; -} -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_29 = lean_ctor_get(x_24, 0); -lean_inc(x_29); -lean_dec(x_24); -x_30 = lean_unsigned_to_nat(0u); -x_31 = l_Lean_Expr_getAppNumArgsAux___main(x_23, x_30); -x_32 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_31); -x_33 = lean_mk_array(x_31, x_32); -x_34 = lean_unsigned_to_nat(1u); -x_35 = lean_nat_sub(x_31, x_34); -lean_dec(x_31); -x_36 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_23, x_33, x_35); -x_37 = l_List_lengthAux___main___rarg(x_5, x_30); -x_38 = lean_ctor_get(x_4, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_38, 1); -lean_inc(x_39); -lean_dec(x_38); -x_40 = l_List_lengthAux___main___rarg(x_39, x_30); -x_41 = lean_nat_dec_eq(x_37, x_40); -lean_dec(x_40); -lean_dec(x_37); -if (x_41 == 0) -{ -uint8_t x_42; -lean_dec(x_39); -lean_dec(x_36); -lean_dec(x_29); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -x_42 = lean_expr_eqv(x_2, x_3); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; -x_43 = l_Lean_Expr_updateFn___main(x_1, x_3); -if (lean_is_scalar(x_20)) { - x_44 = lean_alloc_ctor(0, 2, 0); -} else { - x_44 = x_20; -} -lean_ctor_set(x_44, 0, x_43); -lean_ctor_set(x_44, 1, x_22); -return x_44; -} -else -{ -lean_object* x_45; -if (lean_is_scalar(x_20)) { - x_45 = lean_alloc_ctor(0, 2, 0); -} else { - x_45 = x_20; -} -lean_ctor_set(x_45, 0, x_1); -lean_ctor_set(x_45, 1, x_22); -return x_45; -} -} -else -{ -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -lean_dec(x_20); -lean_dec(x_1); -x_46 = lean_ctor_get(x_29, 2); -lean_inc(x_46); -x_47 = lean_instantiate_lparams(x_46, x_39, x_5); -x_48 = lean_ctor_get(x_4, 2); -lean_inc(x_48); -x_49 = lean_ctor_get(x_4, 4); -lean_inc(x_49); -x_50 = lean_nat_add(x_48, x_49); -lean_dec(x_49); -lean_dec(x_48); -x_51 = lean_ctor_get(x_4, 5); -lean_inc(x_51); -lean_dec(x_4); -x_52 = lean_nat_add(x_50, x_51); -lean_dec(x_51); -lean_dec(x_50); -x_53 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_52, x_6, x_30, x_47); -lean_dec(x_52); -x_54 = lean_array_get_size(x_36); -x_55 = lean_ctor_get(x_29, 1); -lean_inc(x_55); -lean_dec(x_29); -x_56 = lean_nat_sub(x_54, x_55); -lean_dec(x_55); -x_57 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_54, x_36, x_56, x_53); -lean_dec(x_36); -lean_dec(x_54); -x_58 = lean_nat_add(x_9, x_34); -lean_dec(x_9); -x_59 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_58, x_57); -lean_dec(x_10); -x_60 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_59, x_7, x_22); -return x_60; -} -} -} -} -else -{ -uint8_t x_110; -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_110 = !lean_is_exclusive(x_17); -if (x_110 == 0) -{ -return x_17; -} -else -{ -lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_111 = lean_ctor_get(x_17, 0); -x_112 = lean_ctor_get(x_17, 1); -lean_inc(x_112); -lean_inc(x_111); -lean_dec(x_17); -x_113 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_113, 0, x_111); -lean_ctor_set(x_113, 1, x_112); -return x_113; -} -} -} -} -} -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_LocalDecl_value_x3f(x_3); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = lean_ctor_get(x_1, 0); -lean_inc(x_7); -lean_dec(x_1); -x_8 = lean_ctor_get(x_7, 1); -lean_inc(x_8); -lean_dec(x_7); -x_9 = lean_apply_4(x_8, lean_box(0), x_2, x_4, x_5); -return x_9; -} -else -{ -lean_object* x_10; lean_object* x_11; -lean_dec(x_2); -x_10 = lean_ctor_get(x_6, 0); -lean_inc(x_10); -lean_dec(x_6); -x_11 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11(x_1, x_10, x_4, x_5); -return x_11; -} -} -} -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -if (lean_obj_tag(x_3) == 0) -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; -x_6 = lean_ctor_get(x_1, 0); -lean_inc(x_6); -lean_dec(x_1); -x_7 = lean_ctor_get(x_6, 1); -lean_inc(x_7); -lean_dec(x_6); -x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_4, x_5); -return x_8; -} -else -{ -lean_object* x_9; lean_object* x_10; -lean_dec(x_2); -x_9 = lean_ctor_get(x_3, 0); -lean_inc(x_9); -lean_dec(x_3); -x_10 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11(x_1, x_9, x_4, x_5); -return x_10; -} -} -} -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -switch (lean_obj_tag(x_2)) { -case 0: -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -lean_dec(x_2); -x_10 = l_Lean_Expr_Inhabited; -x_11 = l_monadInhabited___rarg(x_1, x_10); -x_12 = l_unreachable_x21___rarg(x_11); -x_13 = lean_apply_2(x_12, x_3, x_4); -return x_13; -} -case 1: -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_14 = lean_ctor_get(x_2, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_1, 1); -lean_inc(x_15); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_getLocalDecl), 3, 1); -lean_closure_set(x_16, 0, x_14); -x_17 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__1___boxed), 5, 2); -lean_closure_set(x_17, 0, x_1); -lean_closure_set(x_17, 1, x_2); -x_18 = lean_apply_6(x_15, lean_box(0), lean_box(0), x_16, x_17, x_3, x_4); -return x_18; -} -case 2: -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_19 = lean_ctor_get(x_2, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_1, 1); -lean_inc(x_20); -x_21 = lean_alloc_closure((void*)(l_Lean_Meta_getExprMVarAssignment___boxed), 3, 1); -lean_closure_set(x_21, 0, x_19); -x_22 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__2), 5, 2); -lean_closure_set(x_22, 0, x_1); -lean_closure_set(x_22, 1, x_2); -x_23 = lean_apply_6(x_20, lean_box(0), lean_box(0), x_21, x_22, x_3, x_4); -return x_23; -} -case 4: -{ -lean_object* x_24; -lean_dec(x_3); -lean_dec(x_1); -x_24 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_24, 0, x_2); -lean_ctor_set(x_24, 1, x_4); -return x_24; -} -case 5: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_1); -x_25 = lean_ctor_get(x_2, 0); -lean_inc(x_25); -x_26 = l_Lean_Expr_getAppFn___main(x_25); -lean_dec(x_25); -lean_inc(x_3); -lean_inc(x_26); -x_27 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_26, x_3, x_4); -if (lean_obj_tag(x_27) == 0) -{ -uint8_t x_28; -x_28 = !lean_is_exclusive(x_27); -if (x_28 == 0) -{ -lean_object* x_29; lean_object* x_30; uint8_t x_31; -x_29 = lean_ctor_get(x_27, 0); -x_30 = lean_ctor_get(x_27, 1); -x_31 = l_Lean_Expr_isLambda(x_29); -if (x_31 == 0) -{ -if (lean_obj_tag(x_29) == 4) -{ -lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; -lean_free_object(x_27); -x_32 = lean_ctor_get(x_29, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_29, 1); -lean_inc(x_33); -x_34 = 0; -x_35 = l_Lean_Meta_getConstAux(x_32, x_34, x_3, x_30); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -if (lean_obj_tag(x_36) == 0) -{ -uint8_t x_37; -lean_dec(x_33); -lean_dec(x_3); -x_37 = !lean_is_exclusive(x_35); -if (x_37 == 0) -{ -lean_object* x_38; uint8_t x_39; -x_38 = lean_ctor_get(x_35, 0); -lean_dec(x_38); -x_39 = lean_expr_eqv(x_26, x_29); -lean_dec(x_26); -if (x_39 == 0) -{ -lean_object* x_40; -x_40 = l_Lean_Expr_updateFn___main(x_2, x_29); -lean_dec(x_29); -lean_ctor_set(x_35, 0, x_40); -return x_35; -} -else -{ -lean_dec(x_29); -lean_ctor_set(x_35, 0, x_2); -return x_35; -} -} -else -{ -lean_object* x_41; uint8_t x_42; -x_41 = lean_ctor_get(x_35, 1); -lean_inc(x_41); -lean_dec(x_35); -x_42 = lean_expr_eqv(x_26, x_29); -lean_dec(x_26); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; -x_43 = l_Lean_Expr_updateFn___main(x_2, x_29); -lean_dec(x_29); -x_44 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_44, 0, x_43); -lean_ctor_set(x_44, 1, x_41); -return x_44; -} -else -{ -lean_object* x_45; -lean_dec(x_29); -x_45 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_45, 0, x_2); -lean_ctor_set(x_45, 1, x_41); -return x_45; -} -} -} -else -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_36, 0); -lean_inc(x_46); -lean_dec(x_36); -switch (lean_obj_tag(x_46)) { -case 1: -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; uint8_t x_51; -x_47 = lean_ctor_get(x_35, 1); -lean_inc(x_47); -lean_dec(x_35); -x_48 = l_Lean_ConstantInfo_name(x_46); -x_49 = l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f(x_48, x_3, x_47); -lean_dec(x_48); -x_50 = lean_ctor_get(x_49, 0); -lean_inc(x_50); -x_51 = lean_unbox(x_50); -lean_dec(x_50); -if (x_51 == 0) -{ -uint8_t x_52; -lean_dec(x_46); -lean_dec(x_33); -lean_dec(x_3); -x_52 = !lean_is_exclusive(x_49); -if (x_52 == 0) -{ -lean_object* x_53; uint8_t x_54; -x_53 = lean_ctor_get(x_49, 0); -lean_dec(x_53); -x_54 = lean_expr_eqv(x_26, x_29); -lean_dec(x_26); -if (x_54 == 0) -{ -lean_object* x_55; -x_55 = l_Lean_Expr_updateFn___main(x_2, x_29); -lean_dec(x_29); -lean_ctor_set(x_49, 0, x_55); -return x_49; -} -else -{ -lean_dec(x_29); -lean_ctor_set(x_49, 0, x_2); -return x_49; -} -} -else -{ -lean_object* x_56; uint8_t x_57; -x_56 = lean_ctor_get(x_49, 1); -lean_inc(x_56); -lean_dec(x_49); -x_57 = lean_expr_eqv(x_26, x_29); -lean_dec(x_26); -if (x_57 == 0) -{ -lean_object* x_58; lean_object* x_59; -x_58 = l_Lean_Expr_updateFn___main(x_2, x_29); -lean_dec(x_29); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_58); -lean_ctor_set(x_59, 1, x_56); -return x_59; -} -else -{ -lean_object* x_60; -lean_dec(x_29); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_2); -lean_ctor_set(x_60, 1, x_56); -return x_60; -} -} -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_49, 1); -lean_inc(x_61); -lean_dec(x_49); -x_62 = lean_unsigned_to_nat(0u); -x_63 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_62); -x_64 = lean_mk_empty_array_with_capacity(x_63); -lean_dec(x_63); -lean_inc(x_2); -x_65 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_64); -x_66 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__3(x_2, x_26, x_29, x_46, x_33, x_65, x_3, x_61); -lean_dec(x_29); -lean_dec(x_26); -return x_66; -} -} -case 4: -{ -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_67 = lean_ctor_get(x_35, 1); -lean_inc(x_67); -lean_dec(x_35); -x_68 = lean_ctor_get(x_46, 0); -lean_inc(x_68); -lean_dec(x_46); -x_69 = lean_unsigned_to_nat(0u); -x_70 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_69); -x_71 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_70); -x_72 = lean_mk_array(x_70, x_71); -x_73 = lean_unsigned_to_nat(1u); -x_74 = lean_nat_sub(x_70, x_73); -lean_dec(x_70); -lean_inc(x_2); -x_75 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_72, x_74); -x_76 = l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__4(x_2, x_26, x_29, x_68, x_33, x_75, x_3, x_67); -lean_dec(x_75); -lean_dec(x_33); -lean_dec(x_68); -lean_dec(x_29); -lean_dec(x_26); -return x_76; -} -case 7: -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_77 = lean_ctor_get(x_35, 1); -lean_inc(x_77); -lean_dec(x_35); -x_78 = lean_ctor_get(x_46, 0); -lean_inc(x_78); -lean_dec(x_46); -x_79 = lean_unsigned_to_nat(0u); -x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_79); -x_81 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_80); -x_82 = lean_mk_array(x_80, x_81); -x_83 = lean_unsigned_to_nat(1u); -x_84 = lean_nat_sub(x_80, x_83); -lean_dec(x_80); -lean_inc(x_2); -x_85 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_82, x_84); -x_86 = l_Lean_reduceRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__5(x_2, x_26, x_29, x_78, x_33, x_85, x_3, x_77); -lean_dec(x_85); -lean_dec(x_29); -lean_dec(x_26); -return x_86; -} -default: -{ -uint8_t x_87; -lean_dec(x_46); -lean_dec(x_33); -lean_dec(x_3); -x_87 = !lean_is_exclusive(x_35); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; -x_88 = lean_ctor_get(x_35, 0); -lean_dec(x_88); -x_89 = lean_expr_eqv(x_26, x_29); -lean_dec(x_26); -if (x_89 == 0) -{ -lean_object* x_90; -x_90 = l_Lean_Expr_updateFn___main(x_2, x_29); -lean_dec(x_29); -lean_ctor_set(x_35, 0, x_90); -return x_35; -} -else -{ -lean_dec(x_29); -lean_ctor_set(x_35, 0, x_2); -return x_35; -} -} -else -{ -lean_object* x_91; uint8_t x_92; -x_91 = lean_ctor_get(x_35, 1); -lean_inc(x_91); -lean_dec(x_35); -x_92 = lean_expr_eqv(x_26, x_29); -lean_dec(x_26); -if (x_92 == 0) -{ -lean_object* x_93; lean_object* x_94; -x_93 = l_Lean_Expr_updateFn___main(x_2, x_29); -lean_dec(x_29); -x_94 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_94, 0, x_93); -lean_ctor_set(x_94, 1, x_91); -return x_94; -} -else -{ -lean_object* x_95; -lean_dec(x_29); -x_95 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_95, 0, x_2); -lean_ctor_set(x_95, 1, x_91); -return x_95; -} -} -} -} -} -} -else -{ -uint8_t x_96; -lean_dec(x_33); -lean_dec(x_29); -lean_dec(x_26); -lean_dec(x_3); -lean_dec(x_2); -x_96 = !lean_is_exclusive(x_35); -if (x_96 == 0) -{ -return x_35; -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_35, 0); -x_98 = lean_ctor_get(x_35, 1); -lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_35); -x_99 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_99, 0, x_97); -lean_ctor_set(x_99, 1, x_98); -return x_99; -} -} -} -else -{ -uint8_t x_100; -lean_dec(x_3); -x_100 = lean_expr_eqv(x_26, x_29); -lean_dec(x_26); -if (x_100 == 0) -{ -lean_object* x_101; -x_101 = l_Lean_Expr_updateFn___main(x_2, x_29); -lean_dec(x_29); -lean_ctor_set(x_27, 0, x_101); -return x_27; -} -else -{ -lean_dec(x_29); -lean_ctor_set(x_27, 0, x_2); -return x_27; -} -} -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; -lean_free_object(x_27); -lean_dec(x_29); -x_102 = lean_unsigned_to_nat(0u); -x_103 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_102); -x_104 = lean_mk_empty_array_with_capacity(x_103); -lean_dec(x_103); -x_105 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_104); -x_106 = l_Lean_Expr_betaRev(x_26, x_105); -lean_dec(x_26); -x_107 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_106, x_3, x_30); -return x_107; -} -} -else -{ -lean_object* x_108; lean_object* x_109; uint8_t x_110; -x_108 = lean_ctor_get(x_27, 0); -x_109 = lean_ctor_get(x_27, 1); -lean_inc(x_109); -lean_inc(x_108); -lean_dec(x_27); -x_110 = l_Lean_Expr_isLambda(x_108); -if (x_110 == 0) -{ -if (lean_obj_tag(x_108) == 4) -{ -lean_object* x_111; lean_object* x_112; uint8_t x_113; lean_object* x_114; -x_111 = lean_ctor_get(x_108, 0); -lean_inc(x_111); -x_112 = lean_ctor_get(x_108, 1); -lean_inc(x_112); -x_113 = 0; -x_114 = l_Lean_Meta_getConstAux(x_111, x_113, x_3, x_109); -if (lean_obj_tag(x_114) == 0) -{ -lean_object* x_115; -x_115 = lean_ctor_get(x_114, 0); -lean_inc(x_115); -if (lean_obj_tag(x_115) == 0) -{ -lean_object* x_116; lean_object* x_117; uint8_t x_118; -lean_dec(x_112); -lean_dec(x_3); -x_116 = lean_ctor_get(x_114, 1); -lean_inc(x_116); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - x_117 = x_114; -} else { - lean_dec_ref(x_114); - x_117 = lean_box(0); -} -x_118 = lean_expr_eqv(x_26, x_108); -lean_dec(x_26); -if (x_118 == 0) -{ -lean_object* x_119; lean_object* x_120; -x_119 = l_Lean_Expr_updateFn___main(x_2, x_108); -lean_dec(x_108); -if (lean_is_scalar(x_117)) { - x_120 = lean_alloc_ctor(0, 2, 0); -} else { - x_120 = x_117; -} -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_116); -return x_120; -} -else -{ -lean_object* x_121; -lean_dec(x_108); -if (lean_is_scalar(x_117)) { - x_121 = lean_alloc_ctor(0, 2, 0); -} else { - x_121 = x_117; -} -lean_ctor_set(x_121, 0, x_2); -lean_ctor_set(x_121, 1, x_116); -return x_121; -} -} -else -{ -lean_object* x_122; -x_122 = lean_ctor_get(x_115, 0); -lean_inc(x_122); -lean_dec(x_115); -switch (lean_obj_tag(x_122)) { -case 1: -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; uint8_t x_127; -x_123 = lean_ctor_get(x_114, 1); -lean_inc(x_123); -lean_dec(x_114); -x_124 = l_Lean_ConstantInfo_name(x_122); -x_125 = l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f(x_124, x_3, x_123); -lean_dec(x_124); -x_126 = lean_ctor_get(x_125, 0); -lean_inc(x_126); -x_127 = lean_unbox(x_126); -lean_dec(x_126); -if (x_127 == 0) -{ -lean_object* x_128; lean_object* x_129; uint8_t x_130; -lean_dec(x_122); -lean_dec(x_112); -lean_dec(x_3); -x_128 = lean_ctor_get(x_125, 1); -lean_inc(x_128); -if (lean_is_exclusive(x_125)) { - lean_ctor_release(x_125, 0); - lean_ctor_release(x_125, 1); - x_129 = x_125; -} else { - lean_dec_ref(x_125); - x_129 = lean_box(0); -} -x_130 = lean_expr_eqv(x_26, x_108); -lean_dec(x_26); -if (x_130 == 0) -{ -lean_object* x_131; lean_object* x_132; -x_131 = l_Lean_Expr_updateFn___main(x_2, x_108); -lean_dec(x_108); -if (lean_is_scalar(x_129)) { - x_132 = lean_alloc_ctor(0, 2, 0); -} else { - x_132 = x_129; -} -lean_ctor_set(x_132, 0, x_131); -lean_ctor_set(x_132, 1, x_128); -return x_132; -} -else -{ -lean_object* x_133; -lean_dec(x_108); -if (lean_is_scalar(x_129)) { - x_133 = lean_alloc_ctor(0, 2, 0); -} else { - x_133 = x_129; -} -lean_ctor_set(x_133, 0, x_2); -lean_ctor_set(x_133, 1, x_128); -return x_133; -} -} -else -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_134 = lean_ctor_get(x_125, 1); -lean_inc(x_134); -lean_dec(x_125); -x_135 = lean_unsigned_to_nat(0u); -x_136 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_135); -x_137 = lean_mk_empty_array_with_capacity(x_136); -lean_dec(x_136); -lean_inc(x_2); -x_138 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_137); -x_139 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__3(x_2, x_26, x_108, x_122, x_112, x_138, x_3, x_134); -lean_dec(x_108); -lean_dec(x_26); -return x_139; -} -} -case 4: -{ -lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; -x_140 = lean_ctor_get(x_114, 1); -lean_inc(x_140); -lean_dec(x_114); -x_141 = lean_ctor_get(x_122, 0); -lean_inc(x_141); -lean_dec(x_122); -x_142 = lean_unsigned_to_nat(0u); -x_143 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_142); -x_144 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_143); -x_145 = lean_mk_array(x_143, x_144); -x_146 = lean_unsigned_to_nat(1u); -x_147 = lean_nat_sub(x_143, x_146); -lean_dec(x_143); -lean_inc(x_2); -x_148 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_145, x_147); -x_149 = l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__4(x_2, x_26, x_108, x_141, x_112, x_148, x_3, x_140); -lean_dec(x_148); -lean_dec(x_112); -lean_dec(x_141); -lean_dec(x_108); -lean_dec(x_26); -return x_149; -} -case 7: -{ -lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; -x_150 = lean_ctor_get(x_114, 1); -lean_inc(x_150); -lean_dec(x_114); -x_151 = lean_ctor_get(x_122, 0); -lean_inc(x_151); -lean_dec(x_122); -x_152 = lean_unsigned_to_nat(0u); -x_153 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_152); -x_154 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_153); -x_155 = lean_mk_array(x_153, x_154); -x_156 = lean_unsigned_to_nat(1u); -x_157 = lean_nat_sub(x_153, x_156); -lean_dec(x_153); -lean_inc(x_2); -x_158 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_155, x_157); -x_159 = l_Lean_reduceRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__5(x_2, x_26, x_108, x_151, x_112, x_158, x_3, x_150); -lean_dec(x_158); -lean_dec(x_108); -lean_dec(x_26); -return x_159; -} -default: -{ -lean_object* x_160; lean_object* x_161; uint8_t x_162; -lean_dec(x_122); -lean_dec(x_112); -lean_dec(x_3); -x_160 = lean_ctor_get(x_114, 1); -lean_inc(x_160); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - x_161 = x_114; -} else { - lean_dec_ref(x_114); - x_161 = lean_box(0); -} -x_162 = lean_expr_eqv(x_26, x_108); -lean_dec(x_26); -if (x_162 == 0) -{ -lean_object* x_163; lean_object* x_164; -x_163 = l_Lean_Expr_updateFn___main(x_2, x_108); -lean_dec(x_108); -if (lean_is_scalar(x_161)) { - x_164 = lean_alloc_ctor(0, 2, 0); -} else { - x_164 = x_161; -} -lean_ctor_set(x_164, 0, x_163); -lean_ctor_set(x_164, 1, x_160); -return x_164; -} -else -{ -lean_object* x_165; -lean_dec(x_108); -if (lean_is_scalar(x_161)) { - x_165 = lean_alloc_ctor(0, 2, 0); -} else { - x_165 = x_161; -} -lean_ctor_set(x_165, 0, x_2); -lean_ctor_set(x_165, 1, x_160); -return x_165; -} -} -} -} -} -else -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; -lean_dec(x_112); -lean_dec(x_108); -lean_dec(x_26); -lean_dec(x_3); -lean_dec(x_2); -x_166 = lean_ctor_get(x_114, 0); -lean_inc(x_166); -x_167 = lean_ctor_get(x_114, 1); -lean_inc(x_167); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - x_168 = x_114; -} else { - lean_dec_ref(x_114); - x_168 = lean_box(0); -} -if (lean_is_scalar(x_168)) { - x_169 = lean_alloc_ctor(1, 2, 0); -} else { - x_169 = x_168; -} -lean_ctor_set(x_169, 0, x_166); -lean_ctor_set(x_169, 1, x_167); -return x_169; -} -} -else -{ -uint8_t x_170; -lean_dec(x_3); -x_170 = lean_expr_eqv(x_26, x_108); -lean_dec(x_26); -if (x_170 == 0) -{ -lean_object* x_171; lean_object* x_172; -x_171 = l_Lean_Expr_updateFn___main(x_2, x_108); -lean_dec(x_108); -x_172 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_172, 0, x_171); -lean_ctor_set(x_172, 1, x_109); -return x_172; -} -else -{ -lean_object* x_173; -lean_dec(x_108); -x_173 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_173, 0, x_2); -lean_ctor_set(x_173, 1, x_109); -return x_173; -} -} -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; -lean_dec(x_108); -x_174 = lean_unsigned_to_nat(0u); -x_175 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_174); -x_176 = lean_mk_empty_array_with_capacity(x_175); -lean_dec(x_175); -x_177 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_176); -x_178 = l_Lean_Expr_betaRev(x_26, x_177); -lean_dec(x_26); -x_179 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_178, x_3, x_109); -return x_179; -} -} -} -else -{ -uint8_t x_180; -lean_dec(x_26); -lean_dec(x_3); -lean_dec(x_2); -x_180 = !lean_is_exclusive(x_27); -if (x_180 == 0) -{ -return x_27; -} -else -{ -lean_object* x_181; lean_object* x_182; lean_object* x_183; -x_181 = lean_ctor_get(x_27, 0); -x_182 = lean_ctor_get(x_27, 1); -lean_inc(x_182); -lean_inc(x_181); -lean_dec(x_27); -x_183 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_183, 0, x_181); -lean_ctor_set(x_183, 1, x_182); -return x_183; -} -} -} -case 8: -{ -lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; -lean_dec(x_1); -x_184 = lean_ctor_get(x_2, 2); -lean_inc(x_184); -x_185 = lean_ctor_get(x_2, 3); -lean_inc(x_185); -lean_dec(x_2); -x_186 = lean_expr_instantiate1(x_185, x_184); -lean_dec(x_184); -lean_dec(x_185); -x_187 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_186, x_3, x_4); -return x_187; -} -case 10: -{ -lean_object* x_188; -x_188 = lean_ctor_get(x_2, 1); -lean_inc(x_188); -lean_dec(x_2); -x_2 = x_188; -goto _start; -} -case 11: -{ -lean_object* x_190; lean_object* x_191; lean_object* x_192; -lean_dec(x_1); -x_190 = lean_ctor_get(x_2, 1); -lean_inc(x_190); -x_191 = lean_ctor_get(x_2, 2); -lean_inc(x_191); -lean_inc(x_3); -x_192 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_191, x_3, x_4); -if (lean_obj_tag(x_192) == 0) -{ -uint8_t x_193; -x_193 = !lean_is_exclusive(x_192); -if (x_193 == 0) -{ -lean_object* x_194; lean_object* x_195; lean_object* x_196; -x_194 = lean_ctor_get(x_192, 0); -x_195 = lean_ctor_get(x_192, 1); -x_196 = l_Lean_Expr_getAppFn___main(x_194); -if (lean_obj_tag(x_196) == 4) -{ -lean_object* x_197; uint8_t x_198; lean_object* x_199; -lean_free_object(x_192); -x_197 = lean_ctor_get(x_196, 0); -lean_inc(x_197); -lean_dec(x_196); -x_198 = 0; -x_199 = l_Lean_Meta_getConstAux(x_197, x_198, x_3, x_195); -lean_dec(x_3); -if (lean_obj_tag(x_199) == 0) -{ -lean_object* x_200; -x_200 = lean_ctor_get(x_199, 0); -lean_inc(x_200); -if (lean_obj_tag(x_200) == 0) -{ -uint8_t x_201; -lean_dec(x_194); -lean_dec(x_190); -x_201 = !lean_is_exclusive(x_199); -if (x_201 == 0) -{ -lean_object* x_202; -x_202 = lean_ctor_get(x_199, 0); -lean_dec(x_202); -lean_ctor_set(x_199, 0, x_2); -return x_199; -} -else -{ -lean_object* x_203; lean_object* x_204; -x_203 = lean_ctor_get(x_199, 1); -lean_inc(x_203); -lean_dec(x_199); -x_204 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_204, 0, x_2); -lean_ctor_set(x_204, 1, x_203); -return x_204; -} -} -else -{ -lean_object* x_205; -x_205 = lean_ctor_get(x_200, 0); -lean_inc(x_205); -lean_dec(x_200); -if (lean_obj_tag(x_205) == 6) -{ -uint8_t x_206; -x_206 = !lean_is_exclusive(x_199); -if (x_206 == 0) -{ -lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; -x_207 = lean_ctor_get(x_199, 0); -lean_dec(x_207); -x_208 = lean_ctor_get(x_205, 0); -lean_inc(x_208); -lean_dec(x_205); -x_209 = lean_ctor_get(x_208, 3); -lean_inc(x_209); -lean_dec(x_208); -x_210 = lean_nat_add(x_209, x_190); -lean_dec(x_190); -lean_dec(x_209); -x_211 = lean_unsigned_to_nat(0u); -x_212 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_211); -x_213 = lean_nat_sub(x_212, x_210); -lean_dec(x_210); -lean_dec(x_212); -x_214 = lean_unsigned_to_nat(1u); -x_215 = lean_nat_sub(x_213, x_214); -lean_dec(x_213); -x_216 = l_Lean_Expr_getRevArgD___main(x_194, x_215, x_2); -lean_dec(x_2); -lean_dec(x_194); -lean_ctor_set(x_199, 0, x_216); -return x_199; -} -else -{ -lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; -x_217 = lean_ctor_get(x_199, 1); -lean_inc(x_217); -lean_dec(x_199); -x_218 = lean_ctor_get(x_205, 0); -lean_inc(x_218); -lean_dec(x_205); -x_219 = lean_ctor_get(x_218, 3); -lean_inc(x_219); -lean_dec(x_218); -x_220 = lean_nat_add(x_219, x_190); -lean_dec(x_190); -lean_dec(x_219); -x_221 = lean_unsigned_to_nat(0u); -x_222 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_221); -x_223 = lean_nat_sub(x_222, x_220); -lean_dec(x_220); -lean_dec(x_222); -x_224 = lean_unsigned_to_nat(1u); -x_225 = lean_nat_sub(x_223, x_224); -lean_dec(x_223); -x_226 = l_Lean_Expr_getRevArgD___main(x_194, x_225, x_2); -lean_dec(x_2); -lean_dec(x_194); -x_227 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_227, 0, x_226); -lean_ctor_set(x_227, 1, x_217); -return x_227; -} -} -else -{ -uint8_t x_228; -lean_dec(x_205); -lean_dec(x_194); -lean_dec(x_190); -x_228 = !lean_is_exclusive(x_199); -if (x_228 == 0) -{ -lean_object* x_229; -x_229 = lean_ctor_get(x_199, 0); -lean_dec(x_229); -lean_ctor_set(x_199, 0, x_2); -return x_199; -} -else -{ -lean_object* x_230; lean_object* x_231; -x_230 = lean_ctor_get(x_199, 1); -lean_inc(x_230); -lean_dec(x_199); -x_231 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_231, 0, x_2); -lean_ctor_set(x_231, 1, x_230); -return x_231; -} -} -} -} -else -{ -uint8_t x_232; -lean_dec(x_194); -lean_dec(x_190); -lean_dec(x_2); -x_232 = !lean_is_exclusive(x_199); -if (x_232 == 0) -{ -return x_199; -} -else -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -x_233 = lean_ctor_get(x_199, 0); -x_234 = lean_ctor_get(x_199, 1); -lean_inc(x_234); -lean_inc(x_233); -lean_dec(x_199); -x_235 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_235, 0, x_233); -lean_ctor_set(x_235, 1, x_234); -return x_235; -} -} -} -else -{ -lean_dec(x_196); -lean_dec(x_194); -lean_dec(x_190); -lean_dec(x_3); -lean_ctor_set(x_192, 0, x_2); -return x_192; -} -} -else -{ -lean_object* x_236; lean_object* x_237; lean_object* x_238; -x_236 = lean_ctor_get(x_192, 0); -x_237 = lean_ctor_get(x_192, 1); -lean_inc(x_237); -lean_inc(x_236); -lean_dec(x_192); -x_238 = l_Lean_Expr_getAppFn___main(x_236); -if (lean_obj_tag(x_238) == 4) -{ -lean_object* x_239; uint8_t x_240; lean_object* x_241; -x_239 = lean_ctor_get(x_238, 0); -lean_inc(x_239); -lean_dec(x_238); -x_240 = 0; -x_241 = l_Lean_Meta_getConstAux(x_239, x_240, x_3, x_237); -lean_dec(x_3); -if (lean_obj_tag(x_241) == 0) -{ -lean_object* x_242; -x_242 = lean_ctor_get(x_241, 0); -lean_inc(x_242); -if (lean_obj_tag(x_242) == 0) -{ -lean_object* x_243; lean_object* x_244; lean_object* x_245; -lean_dec(x_236); -lean_dec(x_190); -x_243 = lean_ctor_get(x_241, 1); -lean_inc(x_243); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_244 = x_241; -} else { - lean_dec_ref(x_241); - x_244 = lean_box(0); -} -if (lean_is_scalar(x_244)) { - x_245 = lean_alloc_ctor(0, 2, 0); -} else { - x_245 = x_244; -} -lean_ctor_set(x_245, 0, x_2); -lean_ctor_set(x_245, 1, x_243); -return x_245; -} -else -{ -lean_object* x_246; -x_246 = lean_ctor_get(x_242, 0); -lean_inc(x_246); -lean_dec(x_242); -if (lean_obj_tag(x_246) == 6) -{ -lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; -x_247 = lean_ctor_get(x_241, 1); -lean_inc(x_247); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_248 = x_241; -} else { - lean_dec_ref(x_241); - x_248 = lean_box(0); -} -x_249 = lean_ctor_get(x_246, 0); -lean_inc(x_249); -lean_dec(x_246); -x_250 = lean_ctor_get(x_249, 3); -lean_inc(x_250); -lean_dec(x_249); -x_251 = lean_nat_add(x_250, x_190); -lean_dec(x_190); -lean_dec(x_250); -x_252 = lean_unsigned_to_nat(0u); -x_253 = l_Lean_Expr_getAppNumArgsAux___main(x_236, x_252); -x_254 = lean_nat_sub(x_253, x_251); -lean_dec(x_251); -lean_dec(x_253); -x_255 = lean_unsigned_to_nat(1u); -x_256 = lean_nat_sub(x_254, x_255); -lean_dec(x_254); -x_257 = l_Lean_Expr_getRevArgD___main(x_236, x_256, x_2); -lean_dec(x_2); -lean_dec(x_236); -if (lean_is_scalar(x_248)) { - x_258 = lean_alloc_ctor(0, 2, 0); -} else { - x_258 = x_248; -} -lean_ctor_set(x_258, 0, x_257); -lean_ctor_set(x_258, 1, x_247); -return x_258; -} -else -{ -lean_object* x_259; lean_object* x_260; lean_object* x_261; -lean_dec(x_246); -lean_dec(x_236); -lean_dec(x_190); -x_259 = lean_ctor_get(x_241, 1); -lean_inc(x_259); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_260 = x_241; -} else { - lean_dec_ref(x_241); - x_260 = lean_box(0); -} -if (lean_is_scalar(x_260)) { - x_261 = lean_alloc_ctor(0, 2, 0); -} else { - x_261 = x_260; -} -lean_ctor_set(x_261, 0, x_2); -lean_ctor_set(x_261, 1, x_259); -return x_261; -} -} -} -else -{ -lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; -lean_dec(x_236); -lean_dec(x_190); -lean_dec(x_2); -x_262 = lean_ctor_get(x_241, 0); -lean_inc(x_262); -x_263 = lean_ctor_get(x_241, 1); -lean_inc(x_263); -if (lean_is_exclusive(x_241)) { - lean_ctor_release(x_241, 0); - lean_ctor_release(x_241, 1); - x_264 = x_241; -} else { - lean_dec_ref(x_241); - x_264 = lean_box(0); -} -if (lean_is_scalar(x_264)) { - x_265 = lean_alloc_ctor(1, 2, 0); -} else { - x_265 = x_264; -} -lean_ctor_set(x_265, 0, x_262); -lean_ctor_set(x_265, 1, x_263); -return x_265; -} -} -else -{ -lean_object* x_266; -lean_dec(x_238); -lean_dec(x_236); -lean_dec(x_190); -lean_dec(x_3); -x_266 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_266, 0, x_2); -lean_ctor_set(x_266, 1, x_237); -return x_266; -} -} -} -else -{ -uint8_t x_267; -lean_dec(x_190); -lean_dec(x_3); -lean_dec(x_2); -x_267 = !lean_is_exclusive(x_192); -if (x_267 == 0) -{ -return x_192; -} -else -{ -lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_268 = lean_ctor_get(x_192, 0); -x_269 = lean_ctor_get(x_192, 1); -lean_inc(x_269); -lean_inc(x_268); -lean_dec(x_192); -x_270 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_270, 0, x_268); -lean_ctor_set(x_270, 1, x_269); -return x_270; -} -} -} -case 12: -{ -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; -lean_dec(x_2); -x_271 = l_Lean_Expr_Inhabited; -x_272 = l_monadInhabited___rarg(x_1, x_271); -x_273 = l_unreachable_x21___rarg(x_272); -x_274 = lean_apply_2(x_273, x_3, x_4); -return x_274; -} -default: -{ -lean_object* x_275; -x_275 = lean_box(0); -x_5 = x_275; -goto block_9; -} -} -block_9: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; -lean_dec(x_5); -x_6 = lean_ctor_get(x_1, 0); -lean_inc(x_6); -lean_dec(x_1); -x_7 = lean_ctor_get(x_6, 1); -lean_inc(x_7); -lean_dec(x_6); -x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_3, x_4); -return x_8; -} -} -} -lean_object* l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; -x_4 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_5 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11(x_4, x_1, x_2, x_3); -return x_5; -} -} -lean_object* l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_4, 0, x_1); -lean_ctor_set(x_4, 1, x_3); -return x_4; -} -} -lean_object* l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12___rarg___boxed), 3, 0); -return x_2; -} -} -lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__15(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; -x_6 = l_Lean_ConstantInfo_lparams(x_2); -x_7 = lean_unsigned_to_nat(0u); -x_8 = l_List_lengthAux___main___rarg(x_6, x_7); -lean_dec(x_6); -x_9 = l_List_lengthAux___main___rarg(x_3, x_7); -x_10 = lean_nat_dec_eq(x_8, x_9); -lean_dec(x_9); -lean_dec(x_8); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_11 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_11, 0, x_1); -lean_ctor_set(x_11, 1, x_5); -return x_11; -} -else -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; -lean_dec(x_1); -x_12 = lean_instantiate_value_lparams(x_2, x_3); -x_13 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_12); -x_14 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_13, x_4, x_5); -return x_14; -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__16(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__17(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__20(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_21; lean_object* x_22; -x_21 = lean_ctor_get_uint8(x_1, sizeof(void*)*1); -x_22 = lean_box(x_21); -switch (lean_obj_tag(x_22)) { -case 2: -{ -lean_object* x_23; -x_23 = lean_unsigned_to_nat(5u); -x_6 = x_23; -goto block_20; -} -case 3: -{ -lean_object* x_24; -x_24 = lean_unsigned_to_nat(4u); -x_6 = x_24; -goto block_20; -} -default: -{ -lean_object* x_25; lean_object* x_26; -lean_dec(x_22); -lean_dec(x_4); -x_25 = lean_box(0); -x_26 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_26, 0, x_25); -lean_ctor_set(x_26, 1, x_5); -return x_26; -} -} -block_20: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_6, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; -lean_dec(x_4); -x_9 = lean_box(0); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_5); -return x_10; -} -else -{ -lean_object* x_11; lean_object* x_12; -x_11 = lean_array_fget(x_3, x_6); -lean_inc(x_4); -x_12 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_11, x_4, x_5); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -x_15 = l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__19(x_13, x_4, x_14); -return x_15; -} -else -{ -uint8_t x_16; -lean_dec(x_4); -x_16 = !lean_is_exclusive(x_12); -if (x_16 == 0) -{ -return x_12; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_12, 0); -x_18 = lean_ctor_get(x_12, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_12); -x_19 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_18); -return x_19; -} -} -} -} -} -} -lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__21(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -uint8_t x_6; -x_6 = lean_ctor_get_uint8(x_1, sizeof(void*)*7); -if (x_6 == 0) -{ -lean_object* x_7; lean_object* x_8; uint8_t x_9; -x_7 = l_Lean_RecursorVal_getMajorIdx(x_1); -x_8 = lean_array_get_size(x_3); -x_9 = lean_nat_dec_lt(x_7, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; -lean_dec(x_7); -lean_dec(x_4); -x_10 = lean_box(0); -x_11 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_11, 0, x_10); -lean_ctor_set(x_11, 1, x_5); -return x_11; -} -else -{ -lean_object* x_12; lean_object* x_13; -x_12 = lean_array_fget(x_3, x_7); -lean_dec(x_7); -lean_inc(x_4); -x_13 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_12, x_4, x_5); -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -x_16 = l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__19(x_14, x_4, x_15); -return x_16; -} -else -{ -uint8_t x_17; -lean_dec(x_4); -x_17 = !lean_is_exclusive(x_13); -if (x_17 == 0) -{ -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_13, 0); -x_19 = lean_ctor_get(x_13, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_13); -x_20 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_19); -return x_20; -} -} -} -} -else -{ -lean_object* x_21; lean_object* x_22; -lean_dec(x_4); -x_21 = lean_box(0); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_5); -return x_22; -} -} -} -lean_object* l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__19(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -switch (lean_obj_tag(x_1)) { -case 2: -{ -lean_object* x_4; lean_object* x_5; -lean_dec(x_2); -x_4 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_4, 0, x_1); -x_5 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_5, 0, x_4); -lean_ctor_set(x_5, 1, x_3); -return x_5; -} -case 5: -{ -lean_object* x_6; lean_object* x_7; -x_6 = lean_ctor_get(x_1, 0); -lean_inc(x_6); -x_7 = l_Lean_Expr_getAppFn___main(x_6); -lean_dec(x_6); -switch (lean_obj_tag(x_7)) { -case 2: -{ -lean_object* x_8; lean_object* x_9; -lean_dec(x_2); -lean_dec(x_1); -x_8 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_8, 0, x_7); -x_9 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_9, 0, x_8); -lean_ctor_set(x_9, 1, x_3); -return x_9; -} -case 4: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; lean_object* x_13; -x_10 = lean_ctor_get(x_7, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_7, 1); -lean_inc(x_11); -lean_dec(x_7); -x_12 = 0; -x_13 = l_Lean_Meta_getConstAux(x_10, x_12, x_2, x_3); -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -if (lean_obj_tag(x_14) == 0) -{ -uint8_t x_15; -lean_dec(x_11); -lean_dec(x_2); -lean_dec(x_1); -x_15 = !lean_is_exclusive(x_13); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; -x_16 = lean_ctor_get(x_13, 0); -lean_dec(x_16); -x_17 = lean_box(0); -lean_ctor_set(x_13, 0, x_17); -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_13, 1); -lean_inc(x_18); -lean_dec(x_13); -x_19 = lean_box(0); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_19); -lean_ctor_set(x_20, 1, x_18); -return x_20; -} -} -else -{ -lean_object* x_21; -x_21 = lean_ctor_get(x_14, 0); -lean_inc(x_21); -lean_dec(x_14); -switch (lean_obj_tag(x_21)) { -case 4: -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_22 = lean_ctor_get(x_13, 1); -lean_inc(x_22); -lean_dec(x_13); -x_23 = lean_ctor_get(x_21, 0); -lean_inc(x_23); -lean_dec(x_21); -x_24 = lean_unsigned_to_nat(0u); -x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_24); -x_26 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_25); -x_27 = lean_mk_array(x_25, x_26); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_sub(x_25, x_28); -lean_dec(x_25); -x_30 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_27, x_29); -x_31 = l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__20(x_23, x_11, x_30, x_2, x_22); -lean_dec(x_30); -lean_dec(x_11); -lean_dec(x_23); -return x_31; -} -case 7: -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_32 = lean_ctor_get(x_13, 1); -lean_inc(x_32); -lean_dec(x_13); -x_33 = lean_ctor_get(x_21, 0); -lean_inc(x_33); -lean_dec(x_21); -x_34 = lean_unsigned_to_nat(0u); -x_35 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_34); -x_36 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_35); -x_37 = lean_mk_array(x_35, x_36); -x_38 = lean_unsigned_to_nat(1u); -x_39 = lean_nat_sub(x_35, x_38); -lean_dec(x_35); -x_40 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_37, x_39); -x_41 = l_Lean_isRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__21(x_33, x_11, x_40, x_2, x_32); -lean_dec(x_40); -lean_dec(x_11); -lean_dec(x_33); -return x_41; -} -default: -{ -uint8_t x_42; -lean_dec(x_21); -lean_dec(x_11); -lean_dec(x_2); -lean_dec(x_1); -x_42 = !lean_is_exclusive(x_13); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; -x_43 = lean_ctor_get(x_13, 0); -lean_dec(x_43); -x_44 = lean_box(0); -lean_ctor_set(x_13, 0, x_44); -return x_13; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_13, 1); -lean_inc(x_45); -lean_dec(x_13); -x_46 = lean_box(0); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_45); -return x_47; -} -} -} -} -} -else -{ -uint8_t x_48; -lean_dec(x_11); -lean_dec(x_2); -lean_dec(x_1); -x_48 = !lean_is_exclusive(x_13); -if (x_48 == 0) -{ -return x_13; -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_13, 0); -x_50 = lean_ctor_get(x_13, 1); -lean_inc(x_50); -lean_inc(x_49); -lean_dec(x_13); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_49); -lean_ctor_set(x_51, 1, x_50); -return x_51; -} -} -} -default: -{ -lean_object* x_52; lean_object* x_53; -lean_dec(x_7); -lean_dec(x_2); -lean_dec(x_1); -x_52 = lean_box(0); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_3); -return x_53; -} -} -} -case 10: -{ -lean_object* x_54; -x_54 = lean_ctor_get(x_1, 1); -lean_inc(x_54); -lean_dec(x_1); -x_1 = x_54; -goto _start; -} -case 11: -{ -lean_object* x_56; lean_object* x_57; -x_56 = lean_ctor_get(x_1, 2); -lean_inc(x_56); -lean_dec(x_1); -lean_inc(x_2); -x_57 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_56, x_2, x_3); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_57, 1); -lean_inc(x_59); -lean_dec(x_57); -x_1 = x_58; -x_3 = x_59; -goto _start; -} -else -{ -uint8_t x_61; -lean_dec(x_2); -x_61 = !lean_is_exclusive(x_57); -if (x_61 == 0) -{ -return x_57; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_62 = lean_ctor_get(x_57, 0); -x_63 = lean_ctor_get(x_57, 1); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_57); -x_64 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_64, 0, x_62); -lean_ctor_set(x_64, 1, x_63); -return x_64; -} -} -} -default: -{ -lean_object* x_65; lean_object* x_66; -lean_dec(x_2); -lean_dec(x_1); -x_65 = lean_box(0); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_66, 1, x_3); -return x_66; -} -} -} -} -lean_object* l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__18(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -x_4 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_1, x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_4, 1); -lean_inc(x_6); -lean_dec(x_4); -lean_inc(x_5); -x_7 = l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__19(x_5, x_2, x_6); -if (lean_obj_tag(x_7) == 0) -{ -uint8_t x_8; -x_8 = !lean_is_exclusive(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -x_9 = lean_ctor_get(x_7, 0); -lean_dec(x_9); -lean_ctor_set(x_7, 0, x_5); -return x_7; -} -else -{ -lean_object* x_10; lean_object* x_11; -x_10 = lean_ctor_get(x_7, 1); -lean_inc(x_10); -lean_dec(x_7); -x_11 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_11, 0, x_5); -lean_ctor_set(x_11, 1, x_10); -return x_11; -} -} -else -{ -uint8_t x_12; -lean_dec(x_5); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -return x_7; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_13 = lean_ctor_get(x_7, 0); -x_14 = lean_ctor_get(x_7, 1); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_7); -x_15 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_15, 0, x_13); -lean_ctor_set(x_15, 1, x_14); -return x_15; -} -} -} -else -{ -uint8_t x_16; -lean_dec(x_2); -x_16 = !lean_is_exclusive(x_4); -if (x_16 == 0) -{ -return x_4; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_4, 0); -x_18 = lean_ctor_get(x_4, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_4); -x_19 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_18); -return x_19; -} -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__22(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -lean_inc(x_5); -x_16 = l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__18(x_15, x_5, x_6); -if (lean_obj_tag(x_16) == 0) -{ -uint8_t x_17; -x_17 = !lean_is_exclusive(x_16); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; -x_18 = lean_ctor_get(x_16, 0); -x_19 = lean_ctor_get(x_16, 1); -x_20 = l___private_Init_Lean_WHNF_6__isIdRhsApp(x_18); -if (x_20 == 0) -{ -lean_dec(x_18); -lean_dec(x_5); -lean_ctor_set(x_16, 0, x_1); -return x_16; -} -else -{ -lean_object* x_21; lean_object* x_22; -lean_free_object(x_16); -lean_dec(x_1); -x_21 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_18); -x_22 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_21, x_5, x_19); -return x_22; -} -} -else -{ -lean_object* x_23; lean_object* x_24; uint8_t x_25; -x_23 = lean_ctor_get(x_16, 0); -x_24 = lean_ctor_get(x_16, 1); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_16); -x_25 = l___private_Init_Lean_WHNF_6__isIdRhsApp(x_23); -if (x_25 == 0) -{ -lean_object* x_26; -lean_dec(x_23); -lean_dec(x_5); -x_26 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_26, 0, x_1); -lean_ctor_set(x_26, 1, x_24); -return x_26; -} -else -{ -lean_object* x_27; lean_object* x_28; -lean_dec(x_1); -x_27 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_23); -x_28 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_27, x_5, x_24); -return x_28; -} -} -} -else -{ -uint8_t x_29; -lean_dec(x_5); -lean_dec(x_1); -x_29 = !lean_is_exclusive(x_16); -if (x_29 == 0) -{ -return x_16; -} -else -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_30 = lean_ctor_get(x_16, 0); -x_31 = lean_ctor_get(x_16, 1); -lean_inc(x_31); -lean_inc(x_30); -lean_dec(x_16); -x_32 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_32, 0, x_30); -lean_ctor_set(x_32, 1, x_31); -return x_32; -} -} -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__23(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__24(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__25(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__26(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__27(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__28(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_7 = l_Lean_ConstantInfo_lparams(x_2); -x_8 = lean_unsigned_to_nat(0u); -x_9 = l_List_lengthAux___main___rarg(x_7, x_8); -lean_dec(x_7); -x_10 = l_List_lengthAux___main___rarg(x_3, x_8); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -lean_dec(x_9); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_1); -lean_ctor_set(x_12, 1, x_6); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_1); -x_13 = lean_instantiate_value_lparams(x_2, x_3); -x_14 = l_Lean_Expr_betaRev(x_13, x_4); -lean_dec(x_13); -x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); -x_16 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_15, x_5, x_6); -return x_16; -} -} -} -lean_object* l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__14(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -switch (lean_obj_tag(x_2)) { -case 4: -{ -lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; -x_5 = lean_ctor_get(x_2, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_2, 1); -lean_inc(x_6); -lean_dec(x_2); -x_7 = 0; -x_8 = l_Lean_Meta_getConstAux(x_5, x_7, x_3, x_4); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -if (lean_obj_tag(x_9) == 0) -{ -uint8_t x_10; -lean_dec(x_6); -lean_dec(x_3); -x_10 = !lean_is_exclusive(x_8); -if (x_10 == 0) -{ -lean_object* x_11; -x_11 = lean_ctor_get(x_8, 0); -lean_dec(x_11); -lean_ctor_set(x_8, 0, x_1); -return x_8; -} -else -{ -lean_object* x_12; lean_object* x_13; -x_12 = lean_ctor_get(x_8, 1); -lean_inc(x_12); -lean_dec(x_8); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_1); -lean_ctor_set(x_13, 1, x_12); -return x_13; -} -} -else -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_9, 0); -lean_inc(x_14); -lean_dec(x_9); -if (lean_obj_tag(x_14) == 1) -{ -lean_object* x_15; lean_object* x_16; -x_15 = lean_ctor_get(x_8, 1); -lean_inc(x_15); -lean_dec(x_8); -x_16 = l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__15(x_1, x_14, x_6, x_3, x_15); -return x_16; -} -else -{ -uint8_t x_17; -lean_dec(x_14); -lean_dec(x_6); -lean_dec(x_3); -x_17 = !lean_is_exclusive(x_8); -if (x_17 == 0) -{ -lean_object* x_18; -x_18 = lean_ctor_get(x_8, 0); -lean_dec(x_18); -lean_ctor_set(x_8, 0, x_1); -return x_8; -} -else -{ -lean_object* x_19; lean_object* x_20; -x_19 = lean_ctor_get(x_8, 1); -lean_inc(x_19); -lean_dec(x_8); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_1); -lean_ctor_set(x_20, 1, x_19); -return x_20; -} -} -} -} -else -{ -uint8_t x_21; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_1); -x_21 = !lean_is_exclusive(x_8); -if (x_21 == 0) -{ -return x_8; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_8, 0); -x_23 = lean_ctor_get(x_8, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_8); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -case 5: -{ -lean_object* x_25; lean_object* x_26; -x_25 = lean_ctor_get(x_2, 0); -lean_inc(x_25); -x_26 = l_Lean_Expr_getAppFn___main(x_25); -lean_dec(x_25); -if (lean_obj_tag(x_26) == 4) -{ -lean_object* x_27; lean_object* x_28; uint8_t x_29; lean_object* x_30; -x_27 = lean_ctor_get(x_26, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_26, 1); -lean_inc(x_28); -lean_dec(x_26); -x_29 = 0; -x_30 = l_Lean_Meta_getConstAux(x_27, x_29, x_3, x_4); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; -x_31 = lean_ctor_get(x_30, 0); -lean_inc(x_31); -if (lean_obj_tag(x_31) == 0) -{ -uint8_t x_32; -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_32 = !lean_is_exclusive(x_30); -if (x_32 == 0) -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_30, 0); -lean_dec(x_33); -lean_ctor_set(x_30, 0, x_1); -return x_30; -} -else -{ -lean_object* x_34; lean_object* x_35; -x_34 = lean_ctor_get(x_30, 1); -lean_inc(x_34); -lean_dec(x_30); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_1); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -else -{ -uint8_t x_36; -x_36 = !lean_is_exclusive(x_30); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_37 = lean_ctor_get(x_30, 1); -x_38 = lean_ctor_get(x_30, 0); -lean_dec(x_38); -x_39 = lean_ctor_get(x_31, 0); -lean_inc(x_39); -lean_dec(x_31); -x_40 = l_Lean_ConstantInfo_lparams(x_39); -x_41 = lean_unsigned_to_nat(0u); -x_42 = l_List_lengthAux___main___rarg(x_40, x_41); -lean_dec(x_40); -x_43 = l_List_lengthAux___main___rarg(x_28, x_41); -x_44 = lean_nat_dec_eq(x_42, x_43); -lean_dec(x_43); -lean_dec(x_42); -if (x_44 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_30, 0, x_1); -return x_30; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -lean_free_object(x_30); -x_45 = l_Lean_ConstantInfo_name(x_39); -x_46 = l_Lean_smartUnfoldingSuffix; -x_47 = lean_name_mk_string(x_45, x_46); -x_48 = l_Lean_Meta_getConstAux(x_47, x_29, x_3, x_37); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -uint8_t x_50; -x_50 = !lean_is_exclusive(x_48); -if (x_50 == 0) -{ -lean_object* x_51; lean_object* x_52; uint8_t x_53; -x_51 = lean_ctor_get(x_48, 1); -x_52 = lean_ctor_get(x_48, 0); -lean_dec(x_52); -x_53 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_53 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -lean_free_object(x_48); -x_54 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_55 = lean_mk_empty_array_with_capacity(x_54); -lean_dec(x_54); -x_56 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_55); -x_57 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__16(x_1, x_39, x_28, x_56, x_3, x_51); -return x_57; -} -} -else -{ -lean_object* x_58; uint8_t x_59; -x_58 = lean_ctor_get(x_48, 1); -lean_inc(x_58); -lean_dec(x_48); -x_59 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_59 == 0) -{ -lean_object* x_60; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_1); -lean_ctor_set(x_60, 1, x_58); -return x_60; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_61 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_62 = lean_mk_empty_array_with_capacity(x_61); -lean_dec(x_61); -x_63 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_62); -x_64 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__16(x_1, x_39, x_28, x_63, x_3, x_58); -return x_64; -} -} -} -else -{ -lean_object* x_65; -x_65 = lean_ctor_get(x_49, 0); -lean_inc(x_65); -lean_dec(x_49); -switch (lean_obj_tag(x_65)) { -case 0: -{ -uint8_t x_66; -lean_dec(x_65); -x_66 = !lean_is_exclusive(x_48); -if (x_66 == 0) -{ -lean_object* x_67; lean_object* x_68; uint8_t x_69; -x_67 = lean_ctor_get(x_48, 1); -x_68 = lean_ctor_get(x_48, 0); -lean_dec(x_68); -x_69 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_69 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; -lean_free_object(x_48); -x_70 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_71 = lean_mk_empty_array_with_capacity(x_70); -lean_dec(x_70); -x_72 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_71); -x_73 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__17(x_1, x_39, x_28, x_72, x_3, x_67); -return x_73; -} -} -else -{ -lean_object* x_74; uint8_t x_75; -x_74 = lean_ctor_get(x_48, 1); -lean_inc(x_74); -lean_dec(x_48); -x_75 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_75 == 0) -{ -lean_object* x_76; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_1); -lean_ctor_set(x_76, 1, x_74); -return x_76; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_77 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_78 = lean_mk_empty_array_with_capacity(x_77); -lean_dec(x_77); -x_79 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_78); -x_80 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__17(x_1, x_39, x_28, x_79, x_3, x_74); -return x_80; -} -} -} -case 1: -{ -lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; -lean_dec(x_39); -x_81 = lean_ctor_get(x_48, 1); -lean_inc(x_81); -lean_dec(x_48); -x_82 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_83 = lean_mk_empty_array_with_capacity(x_82); -lean_dec(x_82); -x_84 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_83); -x_85 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__22(x_1, x_65, x_28, x_84, x_3, x_81); -return x_85; -} -case 2: -{ -uint8_t x_86; -lean_dec(x_65); -x_86 = !lean_is_exclusive(x_48); -if (x_86 == 0) -{ -lean_object* x_87; lean_object* x_88; uint8_t x_89; -x_87 = lean_ctor_get(x_48, 1); -x_88 = lean_ctor_get(x_48, 0); -lean_dec(x_88); -x_89 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_89 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -lean_free_object(x_48); -x_90 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_91 = lean_mk_empty_array_with_capacity(x_90); -lean_dec(x_90); -x_92 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_91); -x_93 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__23(x_1, x_39, x_28, x_92, x_3, x_87); -return x_93; -} -} -else -{ -lean_object* x_94; uint8_t x_95; -x_94 = lean_ctor_get(x_48, 1); -lean_inc(x_94); -lean_dec(x_48); -x_95 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_95 == 0) -{ -lean_object* x_96; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_96 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_96, 0, x_1); -lean_ctor_set(x_96, 1, x_94); -return x_96; -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_97 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_98 = lean_mk_empty_array_with_capacity(x_97); -lean_dec(x_97); -x_99 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_98); -x_100 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__23(x_1, x_39, x_28, x_99, x_3, x_94); -return x_100; -} -} -} -case 3: -{ -uint8_t x_101; -lean_dec(x_65); -x_101 = !lean_is_exclusive(x_48); -if (x_101 == 0) -{ -lean_object* x_102; lean_object* x_103; uint8_t x_104; -x_102 = lean_ctor_get(x_48, 1); -x_103 = lean_ctor_get(x_48, 0); -lean_dec(x_103); -x_104 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_104 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -lean_free_object(x_48); -x_105 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_106 = lean_mk_empty_array_with_capacity(x_105); -lean_dec(x_105); -x_107 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_106); -x_108 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__24(x_1, x_39, x_28, x_107, x_3, x_102); -return x_108; -} -} -else -{ -lean_object* x_109; uint8_t x_110; -x_109 = lean_ctor_get(x_48, 1); -lean_inc(x_109); -lean_dec(x_48); -x_110 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_110 == 0) -{ -lean_object* x_111; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_111 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_111, 0, x_1); -lean_ctor_set(x_111, 1, x_109); -return x_111; -} -else -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -x_112 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_113 = lean_mk_empty_array_with_capacity(x_112); -lean_dec(x_112); -x_114 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_113); -x_115 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__24(x_1, x_39, x_28, x_114, x_3, x_109); -return x_115; -} -} -} -case 4: -{ -uint8_t x_116; -lean_dec(x_65); -x_116 = !lean_is_exclusive(x_48); -if (x_116 == 0) -{ -lean_object* x_117; lean_object* x_118; uint8_t x_119; -x_117 = lean_ctor_get(x_48, 1); -x_118 = lean_ctor_get(x_48, 0); -lean_dec(x_118); -x_119 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_119 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; -lean_free_object(x_48); -x_120 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_121 = lean_mk_empty_array_with_capacity(x_120); -lean_dec(x_120); -x_122 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_121); -x_123 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__25(x_1, x_39, x_28, x_122, x_3, x_117); -return x_123; -} -} -else -{ -lean_object* x_124; uint8_t x_125; -x_124 = lean_ctor_get(x_48, 1); -lean_inc(x_124); -lean_dec(x_48); -x_125 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_125 == 0) -{ -lean_object* x_126; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_126 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_126, 0, x_1); -lean_ctor_set(x_126, 1, x_124); -return x_126; -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_127 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_128 = lean_mk_empty_array_with_capacity(x_127); -lean_dec(x_127); -x_129 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_128); -x_130 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__25(x_1, x_39, x_28, x_129, x_3, x_124); -return x_130; -} -} -} -case 5: -{ -uint8_t x_131; -lean_dec(x_65); -x_131 = !lean_is_exclusive(x_48); -if (x_131 == 0) -{ -lean_object* x_132; lean_object* x_133; uint8_t x_134; -x_132 = lean_ctor_get(x_48, 1); -x_133 = lean_ctor_get(x_48, 0); -lean_dec(x_133); -x_134 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_134 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; -lean_free_object(x_48); -x_135 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_136 = lean_mk_empty_array_with_capacity(x_135); -lean_dec(x_135); -x_137 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_136); -x_138 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__26(x_1, x_39, x_28, x_137, x_3, x_132); -return x_138; -} -} -else -{ -lean_object* x_139; uint8_t x_140; -x_139 = lean_ctor_get(x_48, 1); -lean_inc(x_139); -lean_dec(x_48); -x_140 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_140 == 0) -{ -lean_object* x_141; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_141 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_141, 0, x_1); -lean_ctor_set(x_141, 1, x_139); -return x_141; -} -else -{ -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; -x_142 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_143 = lean_mk_empty_array_with_capacity(x_142); -lean_dec(x_142); -x_144 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_143); -x_145 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__26(x_1, x_39, x_28, x_144, x_3, x_139); -return x_145; -} -} -} -case 6: -{ -uint8_t x_146; -lean_dec(x_65); -x_146 = !lean_is_exclusive(x_48); -if (x_146 == 0) -{ -lean_object* x_147; lean_object* x_148; uint8_t x_149; -x_147 = lean_ctor_get(x_48, 1); -x_148 = lean_ctor_get(x_48, 0); -lean_dec(x_148); -x_149 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_149 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; -lean_free_object(x_48); -x_150 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_151 = lean_mk_empty_array_with_capacity(x_150); -lean_dec(x_150); -x_152 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_151); -x_153 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__27(x_1, x_39, x_28, x_152, x_3, x_147); -return x_153; -} -} -else -{ -lean_object* x_154; uint8_t x_155; -x_154 = lean_ctor_get(x_48, 1); -lean_inc(x_154); -lean_dec(x_48); -x_155 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_155 == 0) -{ -lean_object* x_156; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_156 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_156, 0, x_1); -lean_ctor_set(x_156, 1, x_154); -return x_156; -} -else -{ -lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; -x_157 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_158 = lean_mk_empty_array_with_capacity(x_157); -lean_dec(x_157); -x_159 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_158); -x_160 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__27(x_1, x_39, x_28, x_159, x_3, x_154); -return x_160; -} -} -} -default: -{ -uint8_t x_161; -lean_dec(x_65); -x_161 = !lean_is_exclusive(x_48); -if (x_161 == 0) -{ -lean_object* x_162; lean_object* x_163; uint8_t x_164; -x_162 = lean_ctor_get(x_48, 1); -x_163 = lean_ctor_get(x_48, 0); -lean_dec(x_163); -x_164 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_164 == 0) -{ -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_ctor_set(x_48, 0, x_1); -return x_48; -} -else -{ -lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -lean_free_object(x_48); -x_165 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_166 = lean_mk_empty_array_with_capacity(x_165); -lean_dec(x_165); -x_167 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_166); -x_168 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__28(x_1, x_39, x_28, x_167, x_3, x_162); -return x_168; -} -} -else -{ -lean_object* x_169; uint8_t x_170; -x_169 = lean_ctor_get(x_48, 1); -lean_inc(x_169); -lean_dec(x_48); -x_170 = l_Lean_ConstantInfo_hasValue(x_39); -if (x_170 == 0) -{ -lean_object* x_171; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_171 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_171, 0, x_1); -lean_ctor_set(x_171, 1, x_169); -return x_171; -} -else -{ -lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; -x_172 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); -x_173 = lean_mk_empty_array_with_capacity(x_172); -lean_dec(x_172); -x_174 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_173); -x_175 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__28(x_1, x_39, x_28, x_174, x_3, x_169); -return x_175; -} -} -} -} -} -} -else -{ -uint8_t x_176; -lean_dec(x_39); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_176 = !lean_is_exclusive(x_48); -if (x_176 == 0) -{ -return x_48; -} -else -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; -x_177 = lean_ctor_get(x_48, 0); -x_178 = lean_ctor_get(x_48, 1); -lean_inc(x_178); -lean_inc(x_177); -lean_dec(x_48); -x_179 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_179, 0, x_177); -lean_ctor_set(x_179, 1, x_178); -return x_179; -} -} -} -} -else -{ -lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; uint8_t x_186; -x_180 = lean_ctor_get(x_30, 1); -lean_inc(x_180); -lean_dec(x_30); -x_181 = lean_ctor_get(x_31, 0); -lean_inc(x_181); -lean_dec(x_31); -x_182 = l_Lean_ConstantInfo_lparams(x_181); -x_183 = lean_unsigned_to_nat(0u); -x_184 = l_List_lengthAux___main___rarg(x_182, x_183); -lean_dec(x_182); -x_185 = l_List_lengthAux___main___rarg(x_28, x_183); -x_186 = lean_nat_dec_eq(x_184, x_185); -lean_dec(x_185); -lean_dec(x_184); -if (x_186 == 0) -{ -lean_object* x_187; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -x_187 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_187, 0, x_1); -lean_ctor_set(x_187, 1, x_180); -return x_187; -} -else -{ -lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; -x_188 = l_Lean_ConstantInfo_name(x_181); -x_189 = l_Lean_smartUnfoldingSuffix; -x_190 = lean_name_mk_string(x_188, x_189); -x_191 = l_Lean_Meta_getConstAux(x_190, x_29, x_3, x_180); -if (lean_obj_tag(x_191) == 0) -{ -lean_object* x_192; -x_192 = lean_ctor_get(x_191, 0); -lean_inc(x_192); -if (lean_obj_tag(x_192) == 0) -{ -lean_object* x_193; lean_object* x_194; uint8_t x_195; -x_193 = lean_ctor_get(x_191, 1); -lean_inc(x_193); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_194 = x_191; -} else { - lean_dec_ref(x_191); - x_194 = lean_box(0); -} -x_195 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_195 == 0) -{ -lean_object* x_196; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_194)) { - x_196 = lean_alloc_ctor(0, 2, 0); -} else { - x_196 = x_194; -} -lean_ctor_set(x_196, 0, x_1); -lean_ctor_set(x_196, 1, x_193); -return x_196; -} -else -{ -lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; -lean_dec(x_194); -x_197 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_198 = lean_mk_empty_array_with_capacity(x_197); -lean_dec(x_197); -x_199 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_198); -x_200 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__16(x_1, x_181, x_28, x_199, x_3, x_193); -return x_200; -} -} -else -{ -lean_object* x_201; -x_201 = lean_ctor_get(x_192, 0); -lean_inc(x_201); -lean_dec(x_192); -switch (lean_obj_tag(x_201)) { -case 0: -{ -lean_object* x_202; lean_object* x_203; uint8_t x_204; -lean_dec(x_201); -x_202 = lean_ctor_get(x_191, 1); -lean_inc(x_202); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_203 = x_191; -} else { - lean_dec_ref(x_191); - x_203 = lean_box(0); -} -x_204 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_204 == 0) -{ -lean_object* x_205; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_203)) { - x_205 = lean_alloc_ctor(0, 2, 0); -} else { - x_205 = x_203; -} -lean_ctor_set(x_205, 0, x_1); -lean_ctor_set(x_205, 1, x_202); -return x_205; -} -else -{ -lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; -lean_dec(x_203); -x_206 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_207 = lean_mk_empty_array_with_capacity(x_206); -lean_dec(x_206); -x_208 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_207); -x_209 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__17(x_1, x_181, x_28, x_208, x_3, x_202); -return x_209; -} -} -case 1: -{ -lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; -lean_dec(x_181); -x_210 = lean_ctor_get(x_191, 1); -lean_inc(x_210); -lean_dec(x_191); -x_211 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_212 = lean_mk_empty_array_with_capacity(x_211); -lean_dec(x_211); -x_213 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_212); -x_214 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__22(x_1, x_201, x_28, x_213, x_3, x_210); -return x_214; -} -case 2: -{ -lean_object* x_215; lean_object* x_216; uint8_t x_217; -lean_dec(x_201); -x_215 = lean_ctor_get(x_191, 1); -lean_inc(x_215); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_216 = x_191; -} else { - lean_dec_ref(x_191); - x_216 = lean_box(0); -} -x_217 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_217 == 0) -{ -lean_object* x_218; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_216)) { - x_218 = lean_alloc_ctor(0, 2, 0); -} else { - x_218 = x_216; -} -lean_ctor_set(x_218, 0, x_1); -lean_ctor_set(x_218, 1, x_215); -return x_218; -} -else -{ -lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; -lean_dec(x_216); -x_219 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_220 = lean_mk_empty_array_with_capacity(x_219); -lean_dec(x_219); -x_221 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_220); -x_222 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__23(x_1, x_181, x_28, x_221, x_3, x_215); -return x_222; -} -} -case 3: -{ -lean_object* x_223; lean_object* x_224; uint8_t x_225; -lean_dec(x_201); -x_223 = lean_ctor_get(x_191, 1); -lean_inc(x_223); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_224 = x_191; -} else { - lean_dec_ref(x_191); - x_224 = lean_box(0); -} -x_225 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_225 == 0) -{ -lean_object* x_226; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_224)) { - x_226 = lean_alloc_ctor(0, 2, 0); -} else { - x_226 = x_224; -} -lean_ctor_set(x_226, 0, x_1); -lean_ctor_set(x_226, 1, x_223); -return x_226; -} -else -{ -lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; -lean_dec(x_224); -x_227 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_228 = lean_mk_empty_array_with_capacity(x_227); -lean_dec(x_227); -x_229 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_228); -x_230 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__24(x_1, x_181, x_28, x_229, x_3, x_223); -return x_230; -} -} -case 4: -{ -lean_object* x_231; lean_object* x_232; uint8_t x_233; -lean_dec(x_201); -x_231 = lean_ctor_get(x_191, 1); -lean_inc(x_231); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_232 = x_191; -} else { - lean_dec_ref(x_191); - x_232 = lean_box(0); -} -x_233 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_233 == 0) -{ -lean_object* x_234; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_232)) { - x_234 = lean_alloc_ctor(0, 2, 0); -} else { - x_234 = x_232; -} -lean_ctor_set(x_234, 0, x_1); -lean_ctor_set(x_234, 1, x_231); -return x_234; -} -else -{ -lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; -lean_dec(x_232); -x_235 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_236 = lean_mk_empty_array_with_capacity(x_235); -lean_dec(x_235); -x_237 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_236); -x_238 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__25(x_1, x_181, x_28, x_237, x_3, x_231); -return x_238; -} -} -case 5: -{ -lean_object* x_239; lean_object* x_240; uint8_t x_241; -lean_dec(x_201); -x_239 = lean_ctor_get(x_191, 1); -lean_inc(x_239); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_240 = x_191; -} else { - lean_dec_ref(x_191); - x_240 = lean_box(0); -} -x_241 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_241 == 0) -{ -lean_object* x_242; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_240)) { - x_242 = lean_alloc_ctor(0, 2, 0); -} else { - x_242 = x_240; -} -lean_ctor_set(x_242, 0, x_1); -lean_ctor_set(x_242, 1, x_239); -return x_242; -} -else -{ -lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; -lean_dec(x_240); -x_243 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_244 = lean_mk_empty_array_with_capacity(x_243); -lean_dec(x_243); -x_245 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_244); -x_246 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__26(x_1, x_181, x_28, x_245, x_3, x_239); -return x_246; -} -} -case 6: -{ -lean_object* x_247; lean_object* x_248; uint8_t x_249; -lean_dec(x_201); -x_247 = lean_ctor_get(x_191, 1); -lean_inc(x_247); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_248 = x_191; -} else { - lean_dec_ref(x_191); - x_248 = lean_box(0); -} -x_249 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_249 == 0) -{ -lean_object* x_250; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_248)) { - x_250 = lean_alloc_ctor(0, 2, 0); -} else { - x_250 = x_248; -} -lean_ctor_set(x_250, 0, x_1); -lean_ctor_set(x_250, 1, x_247); -return x_250; -} -else -{ -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; -lean_dec(x_248); -x_251 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_252 = lean_mk_empty_array_with_capacity(x_251); -lean_dec(x_251); -x_253 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_252); -x_254 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__27(x_1, x_181, x_28, x_253, x_3, x_247); -return x_254; -} -} -default: -{ -lean_object* x_255; lean_object* x_256; uint8_t x_257; -lean_dec(x_201); -x_255 = lean_ctor_get(x_191, 1); -lean_inc(x_255); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_256 = x_191; -} else { - lean_dec_ref(x_191); - x_256 = lean_box(0); -} -x_257 = l_Lean_ConstantInfo_hasValue(x_181); -if (x_257 == 0) -{ -lean_object* x_258; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -if (lean_is_scalar(x_256)) { - x_258 = lean_alloc_ctor(0, 2, 0); -} else { - x_258 = x_256; -} -lean_ctor_set(x_258, 0, x_1); -lean_ctor_set(x_258, 1, x_255); -return x_258; -} -else -{ -lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; -lean_dec(x_256); -x_259 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); -x_260 = lean_mk_empty_array_with_capacity(x_259); -lean_dec(x_259); -x_261 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_260); -x_262 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__28(x_1, x_181, x_28, x_261, x_3, x_255); -return x_262; -} -} -} -} -} -else -{ -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; -lean_dec(x_181); -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_263 = lean_ctor_get(x_191, 0); -lean_inc(x_263); -x_264 = lean_ctor_get(x_191, 1); -lean_inc(x_264); -if (lean_is_exclusive(x_191)) { - lean_ctor_release(x_191, 0); - lean_ctor_release(x_191, 1); - x_265 = x_191; -} else { - lean_dec_ref(x_191); - x_265 = lean_box(0); -} -if (lean_is_scalar(x_265)) { - x_266 = lean_alloc_ctor(1, 2, 0); -} else { - x_266 = x_265; -} -lean_ctor_set(x_266, 0, x_263); -lean_ctor_set(x_266, 1, x_264); -return x_266; -} -} -} -} -} -else -{ -uint8_t x_267; -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_267 = !lean_is_exclusive(x_30); -if (x_267 == 0) -{ -return x_30; -} -else -{ -lean_object* x_268; lean_object* x_269; lean_object* x_270; -x_268 = lean_ctor_get(x_30, 0); -x_269 = lean_ctor_get(x_30, 1); -lean_inc(x_269); -lean_inc(x_268); -lean_dec(x_30); -x_270 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_270, 0, x_268); -lean_ctor_set(x_270, 1, x_269); -return x_270; -} -} -} -else -{ -lean_object* x_271; -lean_dec(x_26); -lean_dec(x_3); -lean_dec(x_2); -x_271 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_271, 0, x_1); -lean_ctor_set(x_271, 1, x_4); -return x_271; -} -} -default: -{ -lean_object* x_272; -lean_dec(x_3); -lean_dec(x_2); -x_272 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_272, 0, x_1); -lean_ctor_set(x_272, 1, x_4); -return x_272; -} -} -} -} -lean_object* l_Lean_Meta_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__13(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__14(x_1, x_2, x_3, x_4); -return x_5; -} -} -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -switch (lean_obj_tag(x_1)) { -case 0: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; -lean_dec(x_1); -x_4 = l_Lean_Meta_CheckAssignment_check___main___closed__1; -x_5 = l_unreachable_x21___rarg(x_4); -x_6 = lean_apply_2(x_5, x_2, x_3); -return x_6; -} -case 1: -{ -lean_object* x_7; lean_object* x_8; -x_7 = lean_ctor_get(x_1, 0); -lean_inc(x_7); -lean_inc(x_2); -x_8 = l_Lean_Meta_getLocalDecl(x_7, x_2, x_3); -if (lean_obj_tag(x_8) == 0) -{ -uint8_t x_9; -x_9 = !lean_is_exclusive(x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_8, 0); -x_11 = lean_ctor_get(x_8, 1); -x_12 = l_Lean_LocalDecl_value_x3f(x_10); -lean_dec(x_10); -if (lean_obj_tag(x_12) == 0) -{ -lean_dec(x_2); -lean_ctor_set(x_8, 0, x_1); -return x_8; -} -else -{ -lean_object* x_13; -lean_free_object(x_8); -lean_dec(x_1); -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -lean_dec(x_12); -x_1 = x_13; -x_3 = x_11; -goto _start; -} -} -else -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_8, 0); -x_16 = lean_ctor_get(x_8, 1); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_8); -x_17 = l_Lean_LocalDecl_value_x3f(x_15); -lean_dec(x_15); -if (lean_obj_tag(x_17) == 0) -{ -lean_object* x_18; -lean_dec(x_2); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_1); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -else -{ -lean_object* x_19; -lean_dec(x_1); -x_19 = lean_ctor_get(x_17, 0); -lean_inc(x_19); -lean_dec(x_17); -x_1 = x_19; -x_3 = x_16; -goto _start; -} -} -} -else -{ -uint8_t x_21; -lean_dec(x_2); -lean_dec(x_1); -x_21 = !lean_is_exclusive(x_8); -if (x_21 == 0) -{ -return x_8; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_8, 0); -x_23 = lean_ctor_get(x_8, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_8); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -case 2: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_1, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_3, 1); -lean_inc(x_26); -x_27 = lean_metavar_ctx_get_expr_assignment(x_26, x_25); -if (lean_obj_tag(x_27) == 0) -{ -lean_object* x_28; -lean_dec(x_2); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_1); -lean_ctor_set(x_28, 1, x_3); -return x_28; -} -else -{ -lean_object* x_29; -lean_dec(x_1); -x_29 = lean_ctor_get(x_27, 0); -lean_inc(x_29); -lean_dec(x_27); -x_1 = x_29; -goto _start; -} -} -case 4: -{ -lean_object* x_31; -lean_inc(x_2); -x_31 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_1, x_2, x_3); -if (lean_obj_tag(x_31) == 0) -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_32 = lean_ctor_get(x_31, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_31, 1); -lean_inc(x_33); -lean_dec(x_31); -lean_inc(x_32); -x_34 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__14(x_32, x_32, x_2, x_33); -return x_34; -} -else -{ -uint8_t x_35; -lean_dec(x_2); -x_35 = !lean_is_exclusive(x_31); -if (x_35 == 0) -{ -return x_31; -} -else -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_31, 0); -x_37 = lean_ctor_get(x_31, 1); -lean_inc(x_37); -lean_inc(x_36); -lean_dec(x_31); -x_38 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_38, 0, x_36); -lean_ctor_set(x_38, 1, x_37); -return x_38; -} -} -} -case 5: -{ -lean_object* x_39; -lean_inc(x_2); -x_39 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_1, x_2, x_3); -if (lean_obj_tag(x_39) == 0) -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_40 = lean_ctor_get(x_39, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_39, 1); -lean_inc(x_41); -lean_dec(x_39); -lean_inc(x_40); -x_42 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__14(x_40, x_40, x_2, x_41); -return x_42; -} -else -{ -uint8_t x_43; -lean_dec(x_2); -x_43 = !lean_is_exclusive(x_39); -if (x_43 == 0) -{ -return x_39; -} -else -{ -lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_44 = lean_ctor_get(x_39, 0); -x_45 = lean_ctor_get(x_39, 1); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_39); -x_46 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_45); -return x_46; -} -} -} -case 8: -{ -lean_object* x_47; -lean_inc(x_2); -x_47 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_1, x_2, x_3); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -lean_inc(x_48); -x_50 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__14(x_48, x_48, x_2, x_49); -return x_50; -} -else -{ -uint8_t x_51; -lean_dec(x_2); -x_51 = !lean_is_exclusive(x_47); -if (x_51 == 0) -{ -return x_47; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_47, 0); -x_53 = lean_ctor_get(x_47, 1); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_47); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; -} -} -} -case 10: -{ -lean_object* x_55; -x_55 = lean_ctor_get(x_1, 1); -lean_inc(x_55); -lean_dec(x_1); -x_1 = x_55; -goto _start; -} -case 11: -{ -lean_object* x_57; -lean_inc(x_2); -x_57 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__2(x_1, x_2, x_3); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_57, 1); -lean_inc(x_59); -lean_dec(x_57); -lean_inc(x_58); -x_60 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__14(x_58, x_58, x_2, x_59); -return x_60; -} -else -{ -uint8_t x_61; -lean_dec(x_2); -x_61 = !lean_is_exclusive(x_57); -if (x_61 == 0) -{ -return x_57; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_62 = lean_ctor_get(x_57, 0); -x_63 = lean_ctor_get(x_57, 1); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_57); -x_64 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_64, 0, x_62); -lean_ctor_set(x_64, 1, x_63); -return x_64; -} -} -} -case 12: -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; -lean_dec(x_1); -x_65 = l_Lean_Meta_CheckAssignment_check___main___closed__1; -x_66 = l_unreachable_x21___rarg(x_65); -x_67 = lean_apply_2(x_66, x_2, x_3); -return x_67; -} -default: -{ -lean_object* x_68; -lean_dec(x_2); -x_68 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_68, 0, x_1); -lean_ctor_set(x_68, 1, x_3); -return x_68; -} -} -} -} -lean_object* l_Lean_Meta_whnfAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__38(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_array_get_size(x_2); -x_7 = lean_nat_dec_lt(x_3, x_6); -lean_dec(x_6); -if (x_7 == 0) -{ -lean_object* x_8; -lean_dec(x_4); -lean_dec(x_3); -x_8 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_8) == 4) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -lean_dec(x_8); -x_10 = lean_ctor_get(x_5, 0); -lean_inc(x_10); -lean_inc(x_9); -x_11 = lean_is_class(x_10, x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -lean_dec(x_9); -x_12 = lean_box(0); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_5); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_14, 0, x_9); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_5); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_8); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_5); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_array_fget(x_2, x_3); -lean_inc(x_4); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_LocalDecl_type(x_20); -lean_dec(x_20); -lean_inc(x_4); -lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -switch (lean_obj_tag(x_24)) { -case 0: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_18); -x_25 = lean_ctor_get(x_23, 1); -lean_inc(x_25); -lean_dec(x_23); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_3, x_26); -lean_dec(x_3); -x_3 = x_27; -x_5 = x_25; -goto _start; -} -case 1: -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); -lean_dec(x_3); -x_33 = !lean_is_exclusive(x_4); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_4, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_18); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_4, 2, x_36); -x_3 = x_32; -x_5 = x_29; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_4, 0); -x_39 = lean_ctor_get(x_4, 1); -x_40 = lean_ctor_get(x_4, 2); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_dec(x_4); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_30); -lean_ctor_set(x_41, 1, x_18); -x_42 = lean_array_push(x_40, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_39); -lean_ctor_set(x_43, 2, x_42); -x_3 = x_32; -x_4 = x_43; -x_5 = x_29; -goto _start; -} -} -default: -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_ctor_get(x_23, 1); -lean_inc(x_45); -lean_dec(x_23); -lean_inc(x_4); -x_46 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_22, x_4, x_45); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_18); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_3, x_49); -lean_dec(x_3); -x_3 = x_50; -x_5 = x_48; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_ctor_get(x_47, 0); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_3, x_54); -lean_dec(x_3); -x_56 = !lean_is_exclusive(x_4); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_4, 2); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_18); -x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_4, 2, x_59); -x_3 = x_55; -x_5 = x_52; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_4, 0); -x_62 = lean_ctor_get(x_4, 1); -x_63 = lean_ctor_get(x_4, 2); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_4); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_53); -lean_ctor_set(x_64, 1, x_18); -x_65 = lean_array_push(x_63, x_64); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_62); -lean_ctor_set(x_66, 2, x_65); -x_3 = x_55; -x_4 = x_66; -x_5 = x_52; -goto _start; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_68 = !lean_is_exclusive(x_46); -if (x_68 == 0) -{ -return x_46; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_46, 0); -x_70 = lean_ctor_get(x_46, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_46); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_72 = !lean_is_exclusive(x_23); -if (x_72 == 0) -{ -return x_23; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_23, 0); -x_74 = lean_ctor_get(x_23, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_23); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -uint8_t x_76; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_76 = !lean_is_exclusive(x_19); -if (x_76 == 0) -{ -return x_19; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_19, 0); -x_78 = lean_ctor_get(x_19, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_19); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -uint8_t x_4; lean_object* x_5; -x_4 = 0; -lean_inc(x_1); -x_5 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_4, x_1, x_1, x_2, x_3); -lean_dec(x_1); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__2(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; -x_10 = l_Lean_Expr_isForall(x_7); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -x_11 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_11) == 4) -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -lean_dec(x_11); -x_13 = lean_ctor_get(x_9, 0); -lean_inc(x_13); -lean_inc(x_12); -x_14 = lean_is_class(x_13, x_12); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; -lean_dec(x_12); -x_15 = lean_box(0); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_9); -return x_16; -} -else -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_17, 0, x_12); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_9); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; -lean_dec(x_11); -x_19 = lean_box(0); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_19); -lean_ctor_set(x_20, 1, x_9); -return x_20; -} -} -else -{ -lean_object* x_21; -x_21 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37(x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_21; -} -} -} -lean_object* _init_l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___closed__1() { -_start: -{ -lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__1), 3, 0); -return x_1; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_13 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___closed__1; -lean_inc(x_8); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_13); -lean_closure_set(x_14, 1, x_8); -x_15 = lean_box(x_1); -lean_inc(x_7); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_8); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__2___boxed), 9, 6); -lean_closure_set(x_16, 0, x_8); -lean_closure_set(x_16, 1, x_15); -lean_closure_set(x_16, 2, x_2); -lean_closure_set(x_16, 3, x_3); -lean_closure_set(x_16, 4, x_4); -lean_closure_set(x_16, 5, x_7); -x_17 = lean_array_get_size(x_9); -x_18 = lean_nat_dec_lt(x_10, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_11, x_12); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_9, x_10); -lean_inc(x_11); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_11, x_12); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_11); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_11, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_10, x_28); -lean_dec(x_10); -x_10 = x_29; -x_12 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_10, x_33); -lean_dec(x_10); -x_35 = !lean_is_exclusive(x_11); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_11, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_11, 2, x_38); -x_10 = x_34; -x_12 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_11, 0); -x_41 = lean_ctor_get(x_11, 1); -x_42 = lean_ctor_get(x_11, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_11); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_10 = x_34; -x_11 = x_45; -x_12 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_11); -x_48 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_24, x_11, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_10, x_51); -lean_dec(x_10); -x_10 = x_52; -x_12 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_10, x_56); -lean_dec(x_10); -x_58 = !lean_is_exclusive(x_11); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_11, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_11, 2, x_61); -x_10 = x_57; -x_12 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_11, 0); -x_64 = lean_ctor_get(x_11, 1); -x_65 = lean_ctor_get(x_11, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_11); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_10 = x_57; -x_11 = x_68; -x_12 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__40(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_array_get_size(x_2); -x_7 = lean_nat_dec_lt(x_3, x_6); -lean_dec(x_6); -if (x_7 == 0) -{ -lean_object* x_8; -lean_dec(x_4); -lean_dec(x_3); -x_8 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_8) == 4) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -lean_dec(x_8); -x_10 = lean_ctor_get(x_5, 0); -lean_inc(x_10); -lean_inc(x_9); -x_11 = lean_is_class(x_10, x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -lean_dec(x_9); -x_12 = lean_box(0); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_5); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_14, 0, x_9); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_5); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_8); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_5); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_array_fget(x_2, x_3); -lean_inc(x_4); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_LocalDecl_type(x_20); -lean_dec(x_20); -lean_inc(x_4); -lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -switch (lean_obj_tag(x_24)) { -case 0: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_18); -x_25 = lean_ctor_get(x_23, 1); -lean_inc(x_25); -lean_dec(x_23); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_3, x_26); -lean_dec(x_3); -x_3 = x_27; -x_5 = x_25; -goto _start; -} -case 1: -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); -lean_dec(x_3); -x_33 = !lean_is_exclusive(x_4); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_4, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_18); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_4, 2, x_36); -x_3 = x_32; -x_5 = x_29; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_4, 0); -x_39 = lean_ctor_get(x_4, 1); -x_40 = lean_ctor_get(x_4, 2); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_dec(x_4); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_30); -lean_ctor_set(x_41, 1, x_18); -x_42 = lean_array_push(x_40, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_39); -lean_ctor_set(x_43, 2, x_42); -x_3 = x_32; -x_4 = x_43; -x_5 = x_29; -goto _start; -} -} -default: -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_ctor_get(x_23, 1); -lean_inc(x_45); -lean_dec(x_23); -lean_inc(x_4); -x_46 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_22, x_4, x_45); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_18); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_3, x_49); -lean_dec(x_3); -x_3 = x_50; -x_5 = x_48; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_ctor_get(x_47, 0); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_3, x_54); -lean_dec(x_3); -x_56 = !lean_is_exclusive(x_4); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_4, 2); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_18); -x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_4, 2, x_59); -x_3 = x_55; -x_5 = x_52; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_4, 0); -x_62 = lean_ctor_get(x_4, 1); -x_63 = lean_ctor_get(x_4, 2); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_4); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_53); -lean_ctor_set(x_64, 1, x_18); -x_65 = lean_array_push(x_63, x_64); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_62); -lean_ctor_set(x_66, 2, x_65); -x_3 = x_55; -x_4 = x_66; -x_5 = x_52; -goto _start; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_68 = !lean_is_exclusive(x_46); -if (x_68 == 0) -{ -return x_46; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_46, 0); -x_70 = lean_ctor_get(x_46, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_46); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_72 = !lean_is_exclusive(x_23); -if (x_72 == 0) -{ -return x_23; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_23, 0); -x_74 = lean_ctor_get(x_23, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_23); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -uint8_t x_76; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_76 = !lean_is_exclusive(x_19); -if (x_76 == 0) -{ -return x_19; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_19, 0); -x_78 = lean_ctor_get(x_19, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_19); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_22 = lean_ctor_get(x_6, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_6, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 2); -lean_inc(x_24); -x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); -lean_dec(x_6); -x_26 = lean_array_get_size(x_4); -lean_inc(x_4); -x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); -lean_dec(x_26); -lean_dec(x_23); -x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = (uint8_t)((x_25 << 24) >> 61); -lean_inc(x_29); -x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); -x_33 = l_Lean_mkFVar(x_29); -x_34 = lean_array_push(x_4, x_33); -if (lean_obj_tag(x_2) == 0) -{ -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -else -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_2, 0); -lean_inc(x_36); -x_37 = lean_array_get_size(x_34); -x_38 = lean_nat_dec_lt(x_37, x_36); -lean_dec(x_36); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -lean_dec(x_2); -lean_inc(x_34); -x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); -lean_dec(x_37); -lean_dec(x_24); -x_40 = !lean_is_exclusive(x_7); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_7, 1); -lean_dec(x_41); -lean_ctor_set(x_7, 1, x_32); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__40(x_39, x_34, x_5, x_7, x_30); -lean_dec(x_34); -lean_dec(x_39); -return x_42; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_7, 0); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_32); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__40(x_39, x_34, x_5, x_45, x_30); -lean_dec(x_34); -lean_dec(x_39); -return x_46; -} -} -else -{ -lean_dec(x_37); -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -} -} -else -{ -lean_object* x_48; -x_48 = lean_box(0); -x_9 = x_48; -goto block_21; -} -block_21: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_7, 1); -lean_dec(x_13); -lean_inc(x_3); -lean_ctor_set(x_7, 1, x_3); -if (x_1 == 0) -{ -lean_object* x_14; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__38(x_11, x_4, x_5, x_7, x_8); -lean_dec(x_4); -lean_dec(x_11); -return x_14; -} -else -{ -lean_object* x_15; -lean_inc(x_5); -lean_inc(x_4); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_7, 0); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_7); -lean_inc(x_3); -x_18 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_3); -lean_ctor_set(x_18, 2, x_17); -if (x_1 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__38(x_11, x_4, x_5, x_18, x_8); -lean_dec(x_4); -lean_dec(x_11); -return x_19; -} -else -{ -lean_object* x_20; -lean_inc(x_5); -lean_inc(x_4); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_20; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__36(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; -x_5 = lean_ctor_get(x_3, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_3, 1); -lean_inc(x_6); -x_7 = lean_ctor_get(x_3, 2); -lean_inc(x_7); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -uint8_t x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; -x_9 = 1; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 4, x_9); -lean_inc(x_6); -x_10 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_10, 0, x_5); -lean_ctor_set(x_10, 1, x_6); -lean_ctor_set(x_10, 2, x_7); -x_11 = 0; -lean_inc(x_1); -x_12 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_11, x_1, x_1, x_10, x_4); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; uint8_t x_16; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_ctor_get(x_12, 1); -x_16 = l_Lean_Expr_isForall(x_14); -if (x_16 == 0) -{ -lean_object* x_17; -lean_dec(x_14); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_17 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_17) == 4) -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -lean_dec(x_17); -x_19 = lean_ctor_get(x_15, 0); -lean_inc(x_19); -lean_inc(x_18); -x_20 = lean_is_class(x_19, x_18); -if (x_20 == 0) -{ -lean_object* x_21; -lean_dec(x_18); -x_21 = lean_box(0); -lean_ctor_set(x_12, 0, x_21); -return x_12; -} -else -{ -lean_object* x_22; -x_22 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_22, 0, x_18); -lean_ctor_set(x_12, 0, x_22); -return x_12; -} -} -else -{ -lean_object* x_23; -lean_dec(x_17); -x_23 = lean_box(0); -lean_ctor_set(x_12, 0, x_23); -return x_12; -} -} -else -{ -lean_object* x_24; uint8_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_free_object(x_12); -lean_dec(x_1); -x_24 = lean_ctor_get(x_15, 2); -lean_inc(x_24); -x_25 = 1; -x_26 = l_Array_empty___closed__1; -x_27 = lean_unsigned_to_nat(0u); -x_28 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37(x_25, x_2, x_6, x_26, x_27, x_14, x_3, x_15); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_28); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_28, 1); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = lean_ctor_get(x_30, 2); -lean_dec(x_32); -lean_ctor_set(x_30, 2, x_24); -return x_28; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_33 = lean_ctor_get(x_30, 0); -x_34 = lean_ctor_get(x_30, 1); -x_35 = lean_ctor_get(x_30, 3); -x_36 = lean_ctor_get(x_30, 4); -x_37 = lean_ctor_get(x_30, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_30); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_34); -lean_ctor_set(x_38, 2, x_24); -lean_ctor_set(x_38, 3, x_35); -lean_ctor_set(x_38, 4, x_36); -lean_ctor_set(x_38, 5, x_37); -lean_ctor_set(x_28, 1, x_38); -return x_28; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_39 = lean_ctor_get(x_28, 1); -x_40 = lean_ctor_get(x_28, 0); -lean_inc(x_39); -lean_inc(x_40); -lean_dec(x_28); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_39, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_39, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_46 = x_39; -} else { - lean_dec_ref(x_39); - x_46 = lean_box(0); -} -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_46; -} -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); -lean_ctor_set(x_47, 2, x_24); -lean_ctor_set(x_47, 3, x_43); -lean_ctor_set(x_47, 4, x_44); -lean_ctor_set(x_47, 5, x_45); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_40); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -else -{ -uint8_t x_49; -x_49 = !lean_is_exclusive(x_28); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_28, 1); -x_51 = !lean_is_exclusive(x_50); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_50, 2); -lean_dec(x_52); -lean_ctor_set(x_50, 2, x_24); -return x_28; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_53 = lean_ctor_get(x_50, 0); -x_54 = lean_ctor_get(x_50, 1); -x_55 = lean_ctor_get(x_50, 3); -x_56 = lean_ctor_get(x_50, 4); -x_57 = lean_ctor_get(x_50, 5); -lean_inc(x_57); -lean_inc(x_56); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_50); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_54); -lean_ctor_set(x_58, 2, x_24); -lean_ctor_set(x_58, 3, x_55); -lean_ctor_set(x_58, 4, x_56); -lean_ctor_set(x_58, 5, x_57); -lean_ctor_set(x_28, 1, x_58); -return x_28; -} -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_59 = lean_ctor_get(x_28, 1); -x_60 = lean_ctor_get(x_28, 0); -lean_inc(x_59); -lean_inc(x_60); -lean_dec(x_28); -x_61 = lean_ctor_get(x_59, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_59, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_59, 3); -lean_inc(x_63); -x_64 = lean_ctor_get(x_59, 4); -lean_inc(x_64); -x_65 = lean_ctor_get(x_59, 5); -lean_inc(x_65); -if (lean_is_exclusive(x_59)) { - lean_ctor_release(x_59, 0); - lean_ctor_release(x_59, 1); - lean_ctor_release(x_59, 2); - lean_ctor_release(x_59, 3); - lean_ctor_release(x_59, 4); - lean_ctor_release(x_59, 5); - x_66 = x_59; -} else { - lean_dec_ref(x_59); - x_66 = lean_box(0); -} -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 6, 0); -} else { - x_67 = x_66; -} -lean_ctor_set(x_67, 0, x_61); -lean_ctor_set(x_67, 1, x_62); -lean_ctor_set(x_67, 2, x_24); -lean_ctor_set(x_67, 3, x_63); -lean_ctor_set(x_67, 4, x_64); -lean_ctor_set(x_67, 5, x_65); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_60); -lean_ctor_set(x_68, 1, x_67); -return x_68; -} -} -} -} -else -{ -lean_object* x_69; lean_object* x_70; uint8_t x_71; -x_69 = lean_ctor_get(x_12, 0); -x_70 = lean_ctor_get(x_12, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_12); -x_71 = l_Lean_Expr_isForall(x_69); -if (x_71 == 0) -{ -lean_object* x_72; -lean_dec(x_69); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_72 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_72) == 4) -{ -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -lean_dec(x_72); -x_74 = lean_ctor_get(x_70, 0); -lean_inc(x_74); -lean_inc(x_73); -x_75 = lean_is_class(x_74, x_73); -if (x_75 == 0) -{ -lean_object* x_76; lean_object* x_77; -lean_dec(x_73); -x_76 = lean_box(0); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_70); -return x_77; -} -else -{ -lean_object* x_78; lean_object* x_79; -x_78 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_78, 0, x_73); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_70); -return x_79; -} -} -else -{ -lean_object* x_80; lean_object* x_81; -lean_dec(x_72); -x_80 = lean_box(0); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_70); -return x_81; -} -} -else -{ -lean_object* x_82; uint8_t x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_1); -x_82 = lean_ctor_get(x_70, 2); -lean_inc(x_82); -x_83 = 1; -x_84 = l_Array_empty___closed__1; -x_85 = lean_unsigned_to_nat(0u); -x_86 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37(x_83, x_2, x_6, x_84, x_85, x_69, x_3, x_70); -if (lean_obj_tag(x_86) == 0) -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_87 = lean_ctor_get(x_86, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_86, 0); -lean_inc(x_88); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_89 = x_86; -} else { - lean_dec_ref(x_86); - x_89 = lean_box(0); -} -x_90 = lean_ctor_get(x_87, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_87, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_87, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_87, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_87, 5); -lean_inc(x_94); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - lean_ctor_release(x_87, 4); - lean_ctor_release(x_87, 5); - x_95 = x_87; -} else { - lean_dec_ref(x_87); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 6, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_90); -lean_ctor_set(x_96, 1, x_91); -lean_ctor_set(x_96, 2, x_82); -lean_ctor_set(x_96, 3, x_92); -lean_ctor_set(x_96, 4, x_93); -lean_ctor_set(x_96, 5, x_94); -if (lean_is_scalar(x_89)) { - x_97 = lean_alloc_ctor(0, 2, 0); -} else { - x_97 = x_89; -} -lean_ctor_set(x_97, 0, x_88); -lean_ctor_set(x_97, 1, x_96); -return x_97; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_86, 0); -lean_inc(x_99); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_100 = x_86; -} else { - lean_dec_ref(x_86); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_98, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_98, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_98, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_98, 5); -lean_inc(x_105); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - lean_ctor_release(x_98, 2); - lean_ctor_release(x_98, 3); - lean_ctor_release(x_98, 4); - lean_ctor_release(x_98, 5); - x_106 = x_98; -} else { - lean_dec_ref(x_98); - x_106 = lean_box(0); -} -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 6, 0); -} else { - x_107 = x_106; -} -lean_ctor_set(x_107, 0, x_101); -lean_ctor_set(x_107, 1, x_102); -lean_ctor_set(x_107, 2, x_82); -lean_ctor_set(x_107, 3, x_103); -lean_ctor_set(x_107, 4, x_104); -lean_ctor_set(x_107, 5, x_105); -if (lean_is_scalar(x_100)) { - x_108 = lean_alloc_ctor(1, 2, 0); -} else { - x_108 = x_100; -} -lean_ctor_set(x_108, 0, x_99); -lean_ctor_set(x_108, 1, x_107); -return x_108; -} -} -} -} -else -{ -uint8_t x_109; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_109 = !lean_is_exclusive(x_12); -if (x_109 == 0) -{ -return x_12; -} -else -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_12, 0); -x_111 = lean_ctor_get(x_12, 1); -lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_12); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_110); -lean_ctor_set(x_112, 1, x_111); -return x_112; -} -} -} -else -{ -lean_object* x_113; uint8_t x_114; uint8_t x_115; uint8_t x_116; uint8_t x_117; uint8_t x_118; lean_object* x_119; lean_object* x_120; uint8_t x_121; lean_object* x_122; -x_113 = lean_ctor_get(x_5, 0); -x_114 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_115 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_116 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_117 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -lean_inc(x_113); -lean_dec(x_5); -x_118 = 1; -x_119 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_119, 0, x_113); -lean_ctor_set_uint8(x_119, sizeof(void*)*1, x_114); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 1, x_115); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 2, x_116); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 3, x_117); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 4, x_118); -lean_inc(x_6); -x_120 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_6); -lean_ctor_set(x_120, 2, x_7); -x_121 = 0; -lean_inc(x_1); -x_122 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_121, x_1, x_1, x_120, x_4); -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; uint8_t x_126; -x_123 = lean_ctor_get(x_122, 0); -lean_inc(x_123); -x_124 = lean_ctor_get(x_122, 1); -lean_inc(x_124); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_125 = x_122; -} else { - lean_dec_ref(x_122); - x_125 = lean_box(0); -} -x_126 = l_Lean_Expr_isForall(x_123); -if (x_126 == 0) -{ -lean_object* x_127; -lean_dec(x_123); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_127 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_127) == 4) -{ -lean_object* x_128; lean_object* x_129; uint8_t x_130; -x_128 = lean_ctor_get(x_127, 0); -lean_inc(x_128); -lean_dec(x_127); -x_129 = lean_ctor_get(x_124, 0); -lean_inc(x_129); -lean_inc(x_128); -x_130 = lean_is_class(x_129, x_128); -if (x_130 == 0) -{ -lean_object* x_131; lean_object* x_132; -lean_dec(x_128); -x_131 = lean_box(0); -if (lean_is_scalar(x_125)) { - x_132 = lean_alloc_ctor(0, 2, 0); -} else { - x_132 = x_125; -} -lean_ctor_set(x_132, 0, x_131); -lean_ctor_set(x_132, 1, x_124); -return x_132; -} -else -{ -lean_object* x_133; lean_object* x_134; -x_133 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_133, 0, x_128); -if (lean_is_scalar(x_125)) { - x_134 = lean_alloc_ctor(0, 2, 0); -} else { - x_134 = x_125; -} -lean_ctor_set(x_134, 0, x_133); -lean_ctor_set(x_134, 1, x_124); -return x_134; -} -} -else -{ -lean_object* x_135; lean_object* x_136; -lean_dec(x_127); -x_135 = lean_box(0); -if (lean_is_scalar(x_125)) { - x_136 = lean_alloc_ctor(0, 2, 0); -} else { - x_136 = x_125; -} -lean_ctor_set(x_136, 0, x_135); -lean_ctor_set(x_136, 1, x_124); -return x_136; -} -} -else -{ -lean_object* x_137; uint8_t x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; -lean_dec(x_125); -lean_dec(x_1); -x_137 = lean_ctor_get(x_124, 2); -lean_inc(x_137); -x_138 = 1; -x_139 = l_Array_empty___closed__1; -x_140 = lean_unsigned_to_nat(0u); -x_141 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37(x_138, x_2, x_6, x_139, x_140, x_123, x_3, x_124); -if (lean_obj_tag(x_141) == 0) -{ -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; -x_142 = lean_ctor_get(x_141, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_141, 0); -lean_inc(x_143); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - x_144 = x_141; -} else { - lean_dec_ref(x_141); - x_144 = lean_box(0); -} -x_145 = lean_ctor_get(x_142, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_142, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - lean_ctor_release(x_142, 2); - lean_ctor_release(x_142, 3); - lean_ctor_release(x_142, 4); - lean_ctor_release(x_142, 5); - x_150 = x_142; -} else { - lean_dec_ref(x_142); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 6, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_145); -lean_ctor_set(x_151, 1, x_146); -lean_ctor_set(x_151, 2, x_137); -lean_ctor_set(x_151, 3, x_147); -lean_ctor_set(x_151, 4, x_148); -lean_ctor_set(x_151, 5, x_149); -if (lean_is_scalar(x_144)) { - x_152 = lean_alloc_ctor(0, 2, 0); -} else { - x_152 = x_144; -} -lean_ctor_set(x_152, 0, x_143); -lean_ctor_set(x_152, 1, x_151); -return x_152; -} -else -{ -lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_153 = lean_ctor_get(x_141, 1); -lean_inc(x_153); -x_154 = lean_ctor_get(x_141, 0); -lean_inc(x_154); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - x_155 = x_141; -} else { - lean_dec_ref(x_141); - x_155 = lean_box(0); -} -x_156 = lean_ctor_get(x_153, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_153, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_153, 3); -lean_inc(x_158); -x_159 = lean_ctor_get(x_153, 4); -lean_inc(x_159); -x_160 = lean_ctor_get(x_153, 5); -lean_inc(x_160); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - lean_ctor_release(x_153, 1); - lean_ctor_release(x_153, 2); - lean_ctor_release(x_153, 3); - lean_ctor_release(x_153, 4); - lean_ctor_release(x_153, 5); - x_161 = x_153; -} else { - lean_dec_ref(x_153); - x_161 = lean_box(0); -} -if (lean_is_scalar(x_161)) { - x_162 = lean_alloc_ctor(0, 6, 0); -} else { - x_162 = x_161; -} -lean_ctor_set(x_162, 0, x_156); -lean_ctor_set(x_162, 1, x_157); -lean_ctor_set(x_162, 2, x_137); -lean_ctor_set(x_162, 3, x_158); -lean_ctor_set(x_162, 4, x_159); -lean_ctor_set(x_162, 5, x_160); -if (lean_is_scalar(x_155)) { - x_163 = lean_alloc_ctor(1, 2, 0); -} else { - x_163 = x_155; -} -lean_ctor_set(x_163, 0, x_154); -lean_ctor_set(x_163, 1, x_162); -return x_163; -} -} -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_164 = lean_ctor_get(x_122, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_122, 1); -lean_inc(x_165); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_166 = x_122; -} else { - lean_dec_ref(x_122); - x_166 = lean_box(0); -} -if (lean_is_scalar(x_166)) { - x_167 = lean_alloc_ctor(1, 2, 0); -} else { - x_167 = x_166; -} -lean_ctor_set(x_167, 0, x_164); -lean_ctor_set(x_167, 1, x_165); -return x_167; -} -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; uint8_t x_5; -x_4 = lean_box(0); -x_5 = !lean_is_exclusive(x_2); -if (x_5 == 0) -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_ctor_get(x_2, 0); -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -uint8_t x_8; lean_object* x_9; -x_8 = 2; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_8); -x_9 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__36(x_1, x_4, x_2, x_3); -return x_9; -} -else -{ -lean_object* x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; -x_10 = lean_ctor_get(x_6, 0); -x_11 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_12 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_13 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_14 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_10); -lean_dec(x_6); -x_15 = 2; -x_16 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_16, 0, x_10); -lean_ctor_set_uint8(x_16, sizeof(void*)*1, x_11); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 1, x_12); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 2, x_13); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 3, x_14); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_15); -lean_ctor_set(x_2, 0, x_16); -x_17 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__36(x_1, x_4, x_2, x_3); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_18 = lean_ctor_get(x_2, 0); -x_19 = lean_ctor_get(x_2, 1); -x_20 = lean_ctor_get(x_2, 2); -lean_inc(x_20); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_2); -x_21 = lean_ctor_get(x_18, 0); -lean_inc(x_21); -x_22 = lean_ctor_get_uint8(x_18, sizeof(void*)*1); -x_23 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 1); -x_24 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 2); -x_25 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - x_26 = x_18; -} else { - lean_dec_ref(x_18); - x_26 = lean_box(0); -} -x_27 = 2; -if (lean_is_scalar(x_26)) { - x_28 = lean_alloc_ctor(0, 1, 5); -} else { - x_28 = x_26; -} -lean_ctor_set(x_28, 0, x_21); -lean_ctor_set_uint8(x_28, sizeof(void*)*1, x_22); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 1, x_23); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 2, x_24); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 3, x_25); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 4, x_27); -x_29 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_29, 0, x_28); -lean_ctor_set(x_29, 1, x_19); -lean_ctor_set(x_29, 2, x_20); -x_30 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__36(x_1, x_4, x_29, x_3); -return x_30; -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__34(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__41(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -lean_dec(x_4); -lean_inc(x_5); -x_9 = l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(x_2, x_5, x_6); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_9, 1); -lean_inc(x_11); -lean_dec(x_9); -x_12 = l_Lean_Meta_mkForall(x_1, x_10, x_5, x_11); -return x_12; -} -else -{ -uint8_t x_13; -lean_dec(x_5); -lean_dec(x_1); -x_13 = !lean_is_exclusive(x_9); -if (x_13 == 0) -{ -return x_9; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_9, 0); -x_15 = lean_ctor_get(x_9, 1); -lean_inc(x_15); -lean_inc(x_14); -lean_dec(x_9); -x_16 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_16, 0, x_14); -lean_ctor_set(x_16, 1, x_15); -return x_16; -} -} -} -else -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_5, x_6); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_18, 1); -lean_inc(x_20); -lean_dec(x_18); -x_21 = l_Lean_LocalDecl_type(x_19); -lean_dec(x_19); -lean_inc(x_5); -lean_inc(x_21); -x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_5, x_20); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -switch (lean_obj_tag(x_23)) { -case 0: -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -lean_dec(x_21); -lean_dec(x_17); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_unsigned_to_nat(1u); -x_26 = lean_nat_add(x_4, x_25); -lean_dec(x_4); -x_4 = x_26; -x_6 = x_24; -goto _start; -} -case 1: -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; -lean_dec(x_21); -x_28 = lean_ctor_get(x_22, 1); -lean_inc(x_28); -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 0); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_unsigned_to_nat(1u); -x_31 = lean_nat_add(x_4, x_30); -lean_dec(x_4); -x_32 = !lean_is_exclusive(x_5); -if (x_32 == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_5, 2); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_29); -lean_ctor_set(x_34, 1, x_17); -x_35 = lean_array_push(x_33, x_34); -lean_ctor_set(x_5, 2, x_35); -x_4 = x_31; -x_6 = x_28; -goto _start; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_5, 0); -x_38 = lean_ctor_get(x_5, 1); -x_39 = lean_ctor_get(x_5, 2); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_5); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_29); -lean_ctor_set(x_40, 1, x_17); -x_41 = lean_array_push(x_39, x_40); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_37); -lean_ctor_set(x_42, 1, x_38); -lean_ctor_set(x_42, 2, x_41); -x_4 = x_31; -x_5 = x_42; -x_6 = x_28; -goto _start; -} -} -default: -{ -lean_object* x_44; lean_object* x_45; -x_44 = lean_ctor_get(x_22, 1); -lean_inc(x_44); -lean_dec(x_22); -lean_inc(x_5); -x_45 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_21, x_5, x_44); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_45, 0); -lean_inc(x_46); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -lean_dec(x_17); -x_47 = lean_ctor_get(x_45, 1); -lean_inc(x_47); -lean_dec(x_45); -x_48 = lean_unsigned_to_nat(1u); -x_49 = lean_nat_add(x_4, x_48); -lean_dec(x_4); -x_4 = x_49; -x_6 = x_47; -goto _start; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; -x_51 = lean_ctor_get(x_45, 1); -lean_inc(x_51); -lean_dec(x_45); -x_52 = lean_ctor_get(x_46, 0); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_unsigned_to_nat(1u); -x_54 = lean_nat_add(x_4, x_53); -lean_dec(x_4); -x_55 = !lean_is_exclusive(x_5); -if (x_55 == 0) -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_5, 2); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_52); -lean_ctor_set(x_57, 1, x_17); -x_58 = lean_array_push(x_56, x_57); -lean_ctor_set(x_5, 2, x_58); -x_4 = x_54; -x_6 = x_51; -goto _start; -} -else -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_60 = lean_ctor_get(x_5, 0); -x_61 = lean_ctor_get(x_5, 1); -x_62 = lean_ctor_get(x_5, 2); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_dec(x_5); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_52); -lean_ctor_set(x_63, 1, x_17); -x_64 = lean_array_push(x_62, x_63); -x_65 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_65, 0, x_60); -lean_ctor_set(x_65, 1, x_61); -lean_ctor_set(x_65, 2, x_64); -x_4 = x_54; -x_5 = x_65; -x_6 = x_51; -goto _start; -} -} -} -else -{ -uint8_t x_67; -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_67 = !lean_is_exclusive(x_45); -if (x_67 == 0) -{ -return x_45; -} -else -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_68 = lean_ctor_get(x_45, 0); -x_69 = lean_ctor_get(x_45, 1); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_45); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -return x_70; -} -} -} -} -} -else -{ -uint8_t x_71; -lean_dec(x_21); -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_71 = !lean_is_exclusive(x_22); -if (x_71 == 0) -{ -return x_22; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_22, 0); -x_73 = lean_ctor_get(x_22, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_22); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_75 = !lean_is_exclusive(x_18); -if (x_75 == 0) -{ -return x_18; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_18, 0); -x_77 = lean_ctor_get(x_18, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_18); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__33(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -switch (lean_obj_tag(x_4)) { -case 6: -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; uint64_t x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_18 = lean_ctor_get(x_4, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_4, 1); -lean_inc(x_19); -x_20 = lean_ctor_get(x_4, 2); -lean_inc(x_20); -x_21 = lean_ctor_get_uint64(x_4, sizeof(void*)*3); -lean_dec(x_4); -x_22 = lean_array_get_size(x_2); -lean_inc(x_2); -x_23 = lean_expr_instantiate_rev_range(x_19, x_3, x_22, x_2); -lean_dec(x_22); -lean_dec(x_19); -x_24 = l_Lean_Meta_mkFreshId___rarg(x_6); -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = (uint8_t)((x_21 << 24) >> 61); -lean_inc(x_25); -x_28 = lean_local_ctx_mk_local_decl(x_1, x_25, x_18, x_23, x_27); -x_29 = l_Lean_mkFVar(x_25); -x_30 = lean_array_push(x_2, x_29); -x_1 = x_28; -x_2 = x_30; -x_4 = x_20; -x_6 = x_26; -goto _start; -} -case 8: -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_32 = lean_ctor_get(x_4, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_4, 1); -lean_inc(x_33); -x_34 = lean_ctor_get(x_4, 2); -lean_inc(x_34); -x_35 = lean_ctor_get(x_4, 3); -lean_inc(x_35); -lean_dec(x_4); -x_36 = lean_array_get_size(x_2); -lean_inc(x_2); -x_37 = lean_expr_instantiate_rev_range(x_33, x_3, x_36, x_2); -lean_dec(x_33); -lean_inc(x_2); -x_38 = lean_expr_instantiate_rev_range(x_34, x_3, x_36, x_2); -lean_dec(x_36); -lean_dec(x_34); -x_39 = l_Lean_Meta_mkFreshId___rarg(x_6); -x_40 = lean_ctor_get(x_39, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_39, 1); -lean_inc(x_41); -lean_dec(x_39); -lean_inc(x_40); -x_42 = lean_local_ctx_mk_let_decl(x_1, x_40, x_32, x_37, x_38); -x_43 = l_Lean_mkFVar(x_40); -x_44 = lean_array_push(x_2, x_43); -x_1 = x_42; -x_2 = x_44; -x_4 = x_35; -x_6 = x_41; -goto _start; -} -default: -{ -lean_object* x_46; -x_46 = lean_box(0); -x_7 = x_46; -goto block_17; -} -} -block_17: -{ -lean_object* x_8; lean_object* x_9; uint8_t x_10; -lean_dec(x_7); -x_8 = lean_array_get_size(x_2); -lean_inc(x_2); -x_9 = lean_expr_instantiate_rev_range(x_4, x_3, x_8, x_2); -lean_dec(x_8); -lean_dec(x_4); -x_10 = !lean_is_exclusive(x_5); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; -x_11 = lean_ctor_get(x_5, 1); -lean_dec(x_11); -lean_ctor_set(x_5, 1, x_1); -lean_inc(x_2); -x_12 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__41(x_2, x_9, x_2, x_3, x_5, x_6); -lean_dec(x_2); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_5, 0); -x_14 = lean_ctor_get(x_5, 2); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_5); -x_15 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_15, 0, x_13); -lean_ctor_set(x_15, 1, x_1); -lean_ctor_set(x_15, 2, x_14); -lean_inc(x_2); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__41(x_2, x_9, x_2, x_3, x_15, x_6); -lean_dec(x_2); -return x_16; -} -} -} -} -lean_object* l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__32(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; -x_4 = lean_ctor_get(x_3, 2); -lean_inc(x_4); -x_5 = lean_ctor_get(x_2, 1); -lean_inc(x_5); -x_6 = l_Array_empty___closed__1; -x_7 = lean_unsigned_to_nat(0u); -x_8 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__33(x_5, x_6, x_7, x_1, x_2, x_3); -if (lean_obj_tag(x_8) == 0) -{ -uint8_t x_9; -x_9 = !lean_is_exclusive(x_8); -if (x_9 == 0) -{ -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_8, 1); -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) -{ -lean_object* x_12; -x_12 = lean_ctor_get(x_10, 2); -lean_dec(x_12); -lean_ctor_set(x_10, 2, x_4); -return x_8; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_13 = lean_ctor_get(x_10, 0); -x_14 = lean_ctor_get(x_10, 1); -x_15 = lean_ctor_get(x_10, 3); -x_16 = lean_ctor_get(x_10, 4); -x_17 = lean_ctor_get(x_10, 5); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_10); -x_18 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_18, 0, x_13); -lean_ctor_set(x_18, 1, x_14); -lean_ctor_set(x_18, 2, x_4); -lean_ctor_set(x_18, 3, x_15); -lean_ctor_set(x_18, 4, x_16); -lean_ctor_set(x_18, 5, x_17); -lean_ctor_set(x_8, 1, x_18); -return x_8; -} -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_19 = lean_ctor_get(x_8, 1); -x_20 = lean_ctor_get(x_8, 0); -lean_inc(x_19); -lean_inc(x_20); -lean_dec(x_8); -x_21 = lean_ctor_get(x_19, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_19, 1); -lean_inc(x_22); -x_23 = lean_ctor_get(x_19, 3); -lean_inc(x_23); -x_24 = lean_ctor_get(x_19, 4); -lean_inc(x_24); -x_25 = lean_ctor_get(x_19, 5); -lean_inc(x_25); -if (lean_is_exclusive(x_19)) { - lean_ctor_release(x_19, 0); - lean_ctor_release(x_19, 1); - lean_ctor_release(x_19, 2); - lean_ctor_release(x_19, 3); - lean_ctor_release(x_19, 4); - lean_ctor_release(x_19, 5); - x_26 = x_19; -} else { - lean_dec_ref(x_19); - x_26 = lean_box(0); -} -if (lean_is_scalar(x_26)) { - x_27 = lean_alloc_ctor(0, 6, 0); -} else { - x_27 = x_26; -} -lean_ctor_set(x_27, 0, x_21); -lean_ctor_set(x_27, 1, x_22); -lean_ctor_set(x_27, 2, x_4); -lean_ctor_set(x_27, 3, x_23); -lean_ctor_set(x_27, 4, x_24); -lean_ctor_set(x_27, 5, x_25); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_20); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -else -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_8); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_8, 1); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = lean_ctor_get(x_30, 2); -lean_dec(x_32); -lean_ctor_set(x_30, 2, x_4); -return x_8; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_33 = lean_ctor_get(x_30, 0); -x_34 = lean_ctor_get(x_30, 1); -x_35 = lean_ctor_get(x_30, 3); -x_36 = lean_ctor_get(x_30, 4); -x_37 = lean_ctor_get(x_30, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_30); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_34); -lean_ctor_set(x_38, 2, x_4); -lean_ctor_set(x_38, 3, x_35); -lean_ctor_set(x_38, 4, x_36); -lean_ctor_set(x_38, 5, x_37); -lean_ctor_set(x_8, 1, x_38); -return x_8; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_39 = lean_ctor_get(x_8, 1); -x_40 = lean_ctor_get(x_8, 0); -lean_inc(x_39); -lean_inc(x_40); -lean_dec(x_8); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_39, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_39, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_46 = x_39; -} else { - lean_dec_ref(x_39); - x_46 = lean_box(0); -} -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_46; -} -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); -lean_ctor_set(x_47, 2, x_4); -lean_ctor_set(x_47, 3, x_43); -lean_ctor_set(x_47, 4, x_44); -lean_ctor_set(x_47, 5, x_45); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_40); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__31(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__32(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__43(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_nat_dec_eq(x_4, x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_sub(x_4, x_10); -lean_dec(x_4); -x_21 = lean_nat_sub(x_3, x_11); -x_22 = lean_nat_sub(x_21, x_10); -lean_dec(x_21); -x_23 = lean_ctor_get(x_5, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_5, 1); -lean_inc(x_24); -if (lean_is_exclusive(x_5)) { - lean_ctor_release(x_5, 0); - lean_ctor_release(x_5, 1); - x_25 = x_5; -} else { - lean_dec_ref(x_5); - x_25 = lean_box(0); -} -if (lean_obj_tag(x_24) == 7) -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; -lean_dec(x_25); -lean_dec(x_22); -x_89 = lean_ctor_get(x_24, 2); -lean_inc(x_89); -lean_dec(x_24); -x_90 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_90, 0, x_23); -lean_ctor_set(x_90, 1, x_89); -x_91 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_91, 0, x_90); -lean_ctor_set(x_91, 1, x_7); -x_12 = x_91; -goto block_20; -} -else -{ -lean_object* x_92; -x_92 = lean_box(0); -x_26 = x_92; -goto block_88; -} -block_20: -{ -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -x_4 = x_11; -x_5 = x_13; -x_7 = x_14; -goto _start; -} -else -{ -uint8_t x_16; -lean_dec(x_11); -lean_dec(x_6); -lean_dec(x_2); -lean_dec(x_1); -x_16 = !lean_is_exclusive(x_12); -if (x_16 == 0) -{ -return x_12; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_12, 0); -x_18 = lean_ctor_get(x_12, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_12); -x_19 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_18); -return x_19; -} -} -} -block_88: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; -lean_dec(x_26); -lean_inc(x_2); -x_27 = lean_expr_instantiate_rev_range(x_24, x_23, x_22, x_2); -lean_dec(x_23); -lean_dec(x_24); -x_28 = lean_ctor_get(x_6, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_6, 1); -lean_inc(x_29); -x_30 = lean_ctor_get(x_6, 2); -lean_inc(x_30); -x_31 = !lean_is_exclusive(x_28); -if (x_31 == 0) -{ -uint8_t x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; -x_32 = 1; -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 4, x_32); -lean_inc(x_29); -x_33 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_33, 0, x_28); -lean_ctor_set(x_33, 1, x_29); -lean_ctor_set(x_33, 2, x_30); -x_34 = 0; -lean_inc(x_27); -x_35 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_34, x_27, x_27, x_33, x_7); -lean_dec(x_27); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_35, 1); -lean_inc(x_37); -if (lean_is_exclusive(x_35)) { - lean_ctor_release(x_35, 0); - lean_ctor_release(x_35, 1); - x_38 = x_35; -} else { - lean_dec_ref(x_35); - x_38 = lean_box(0); -} -if (lean_obj_tag(x_36) == 7) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_38); -lean_dec(x_29); -x_49 = lean_ctor_get(x_36, 2); -lean_inc(x_49); -lean_dec(x_36); -if (lean_is_scalar(x_25)) { - x_50 = lean_alloc_ctor(0, 2, 0); -} else { - x_50 = x_25; -} -lean_ctor_set(x_50, 0, x_22); -lean_ctor_set(x_50, 1, x_49); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_37); -x_12 = x_51; -goto block_20; -} -else -{ -lean_object* x_52; -lean_dec(x_36); -lean_dec(x_25); -x_52 = lean_box(0); -x_39 = x_52; -goto block_48; -} -block_48: -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -lean_dec(x_39); -x_40 = lean_ctor_get(x_37, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_37, 1); -lean_inc(x_41); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_40); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set(x_42, 2, x_29); -lean_inc(x_1); -x_43 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_22, x_2, x_8, x_1); -x_44 = l_Lean_Expr_Inhabited; -x_45 = lean_array_get(x_44, x_2, x_22); -lean_dec(x_22); -x_46 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_42); -if (lean_is_scalar(x_38)) { - x_47 = lean_alloc_ctor(1, 2, 0); -} else { - x_47 = x_38; - lean_ctor_set_tag(x_47, 1); -} -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_37); -x_12 = x_47; -goto block_20; -} -} -else -{ -uint8_t x_53; -lean_dec(x_29); -lean_dec(x_25); -lean_dec(x_22); -x_53 = !lean_is_exclusive(x_35); -if (x_53 == 0) -{ -x_12 = x_35; -goto block_20; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_35, 0); -x_55 = lean_ctor_get(x_35, 1); -lean_inc(x_55); -lean_inc(x_54); -lean_dec(x_35); -x_56 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_56, 0, x_54); -lean_ctor_set(x_56, 1, x_55); -x_12 = x_56; -goto block_20; -} -} -} -else -{ -lean_object* x_57; uint8_t x_58; uint8_t x_59; uint8_t x_60; uint8_t x_61; uint8_t x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; lean_object* x_66; -x_57 = lean_ctor_get(x_28, 0); -x_58 = lean_ctor_get_uint8(x_28, sizeof(void*)*1); -x_59 = lean_ctor_get_uint8(x_28, sizeof(void*)*1 + 1); -x_60 = lean_ctor_get_uint8(x_28, sizeof(void*)*1 + 2); -x_61 = lean_ctor_get_uint8(x_28, sizeof(void*)*1 + 3); -lean_inc(x_57); -lean_dec(x_28); -x_62 = 1; -x_63 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_63, 0, x_57); -lean_ctor_set_uint8(x_63, sizeof(void*)*1, x_58); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 1, x_59); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 2, x_60); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 3, x_61); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 4, x_62); -lean_inc(x_29); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_63); -lean_ctor_set(x_64, 1, x_29); -lean_ctor_set(x_64, 2, x_30); -x_65 = 0; -lean_inc(x_27); -x_66 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_65, x_27, x_27, x_64, x_7); -lean_dec(x_27); -if (lean_obj_tag(x_66) == 0) -{ -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_66, 1); -lean_inc(x_68); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - x_69 = x_66; -} else { - lean_dec_ref(x_66); - x_69 = lean_box(0); -} -if (lean_obj_tag(x_67) == 7) -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -lean_dec(x_69); -lean_dec(x_29); -x_80 = lean_ctor_get(x_67, 2); -lean_inc(x_80); -lean_dec(x_67); -if (lean_is_scalar(x_25)) { - x_81 = lean_alloc_ctor(0, 2, 0); -} else { - x_81 = x_25; -} -lean_ctor_set(x_81, 0, x_22); -lean_ctor_set(x_81, 1, x_80); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_81); -lean_ctor_set(x_82, 1, x_68); -x_12 = x_82; -goto block_20; -} -else -{ -lean_object* x_83; -lean_dec(x_67); -lean_dec(x_25); -x_83 = lean_box(0); -x_70 = x_83; -goto block_79; -} -block_79: -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -lean_dec(x_70); -x_71 = lean_ctor_get(x_68, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_68, 1); -lean_inc(x_72); -x_73 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -lean_ctor_set(x_73, 2, x_29); -lean_inc(x_1); -x_74 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_22, x_2, x_8, x_1); -x_75 = l_Lean_Expr_Inhabited; -x_76 = lean_array_get(x_75, x_2, x_22); -lean_dec(x_22); -x_77 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_77, 0, x_74); -lean_ctor_set(x_77, 1, x_76); -lean_ctor_set(x_77, 2, x_73); -if (lean_is_scalar(x_69)) { - x_78 = lean_alloc_ctor(1, 2, 0); -} else { - x_78 = x_69; - lean_ctor_set_tag(x_78, 1); -} -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_68); -x_12 = x_78; -goto block_20; -} -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -lean_dec(x_29); -lean_dec(x_25); -lean_dec(x_22); -x_84 = lean_ctor_get(x_66, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_66, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - x_86 = x_66; -} else { - lean_dec_ref(x_66); - x_86 = lean_box(0); -} -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(1, 2, 0); -} else { - x_87 = x_86; -} -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -x_12 = x_87; -goto block_20; -} -} -} -} -else -{ -lean_object* x_93; -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_93 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_93, 0, x_5); -lean_ctor_set(x_93, 1, x_7); -return x_93; -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__42(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -lean_inc(x_3); -lean_inc(x_1); -x_5 = l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(x_1, x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_6 = lean_ctor_get(x_5, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_5, 1); -lean_inc(x_7); -lean_dec(x_5); -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_9, 0, x_8); -lean_ctor_set(x_9, 1, x_6); -x_10 = lean_array_get_size(x_2); -lean_inc(x_10); -lean_inc(x_2); -x_11 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__43(x_1, x_2, x_10, x_10, x_9, x_3, x_7); -if (lean_obj_tag(x_11) == 0) -{ -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_11, 0); -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -x_16 = lean_expr_instantiate_rev_range(x_15, x_14, x_10, x_2); -lean_dec(x_10); -lean_dec(x_14); -lean_dec(x_15); -lean_ctor_set(x_11, 0, x_16); -return x_11; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_17 = lean_ctor_get(x_11, 0); -x_18 = lean_ctor_get(x_11, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_11); -x_19 = lean_ctor_get(x_17, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_17, 1); -lean_inc(x_20); -lean_dec(x_17); -x_21 = lean_expr_instantiate_rev_range(x_20, x_19, x_10, x_2); -lean_dec(x_10); -lean_dec(x_19); -lean_dec(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_18); -return x_22; -} -} -else -{ -uint8_t x_23; -lean_dec(x_10); -lean_dec(x_2); -x_23 = !lean_is_exclusive(x_11); -if (x_23 == 0) -{ -return x_11; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_11, 0); -x_25 = lean_ctor_get(x_11, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_11); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -uint8_t x_27; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_27 = !lean_is_exclusive(x_5); -if (x_27 == 0) -{ -return x_5; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_5, 0); -x_29 = lean_ctor_get(x_5, 1); -lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_5); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -} -} -lean_object* l_Lean_Meta_getLevelAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__45(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -lean_inc(x_1); -x_4 = l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(x_1, x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; -x_5 = lean_ctor_get(x_2, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_4, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = lean_ctor_get(x_2, 1); -lean_inc(x_8); -x_9 = lean_ctor_get(x_2, 2); -lean_inc(x_9); -x_10 = !lean_is_exclusive(x_5); -if (x_10 == 0) -{ -uint8_t x_11; lean_object* x_12; uint8_t x_13; lean_object* x_14; -x_11 = 1; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 4, x_11); -lean_inc(x_8); -x_12 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_12, 0, x_5); -lean_ctor_set(x_12, 1, x_8); -lean_ctor_set(x_12, 2, x_9); -x_13 = 0; -lean_inc(x_6); -x_14 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_13, x_6, x_6, x_12, x_7); -lean_dec(x_6); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -switch (lean_obj_tag(x_15)) { -case 2: -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -x_17 = lean_ctor_get(x_15, 0); -lean_inc(x_17); -lean_dec(x_15); -lean_inc(x_17); -x_18 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_17, x_2, x_16); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; uint8_t x_20; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_unbox(x_19); -lean_dec(x_19); -if (x_20 == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_8); -lean_dec(x_1); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -lean_dec(x_18); -x_22 = l_Lean_Meta_mkFreshId___rarg(x_21); -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = l_Lean_mkLevelMVar(x_23); -lean_inc(x_25); -x_26 = l_Lean_mkSort(x_25); -x_27 = l_Lean_Meta_assignExprMVar(x_17, x_26, x_2, x_24); -lean_dec(x_2); -if (lean_obj_tag(x_27) == 0) -{ -uint8_t x_28; -x_28 = !lean_is_exclusive(x_27); -if (x_28 == 0) -{ -lean_object* x_29; -x_29 = lean_ctor_get(x_27, 0); -lean_dec(x_29); -lean_ctor_set(x_27, 0, x_25); -return x_27; -} -else -{ -lean_object* x_30; lean_object* x_31; -x_30 = lean_ctor_get(x_27, 1); -lean_inc(x_30); -lean_dec(x_27); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_25); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -else -{ -uint8_t x_32; -lean_dec(x_25); -x_32 = !lean_is_exclusive(x_27); -if (x_32 == 0) -{ -return x_27; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_27, 0); -x_34 = lean_ctor_get(x_27, 1); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_27); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_33); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -} -else -{ -uint8_t x_36; -lean_dec(x_17); -lean_dec(x_2); -x_36 = !lean_is_exclusive(x_18); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_18, 1); -x_38 = lean_ctor_get(x_18, 0); -lean_dec(x_38); -x_39 = lean_ctor_get(x_37, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_37, 1); -lean_inc(x_40); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -lean_ctor_set(x_41, 2, x_8); -x_42 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_42, 0, x_1); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set_tag(x_18, 1); -lean_ctor_set(x_18, 0, x_42); -return x_18; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_43 = lean_ctor_get(x_18, 1); -lean_inc(x_43); -lean_dec(x_18); -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_8); -x_47 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_47, 0, x_1); -lean_ctor_set(x_47, 1, x_46); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_47); -lean_ctor_set(x_48, 1, x_43); -return x_48; -} -} -} -else -{ -uint8_t x_49; -lean_dec(x_17); -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_49 = !lean_is_exclusive(x_18); -if (x_49 == 0) -{ -return x_18; -} -else -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_18, 0); -x_51 = lean_ctor_get(x_18, 1); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_18); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); -return x_52; -} -} -} -case 3: -{ -uint8_t x_53; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_53 = !lean_is_exclusive(x_14); -if (x_53 == 0) -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_14, 0); -lean_dec(x_54); -x_55 = lean_ctor_get(x_15, 0); -lean_inc(x_55); -lean_dec(x_15); -lean_ctor_set(x_14, 0, x_55); -return x_14; -} -else -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_14, 1); -lean_inc(x_56); -lean_dec(x_14); -x_57 = lean_ctor_get(x_15, 0); -lean_inc(x_57); -lean_dec(x_15); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_56); -return x_58; -} -} -default: -{ -uint8_t x_59; -lean_dec(x_15); -lean_dec(x_2); -x_59 = !lean_is_exclusive(x_14); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_60 = lean_ctor_get(x_14, 1); -x_61 = lean_ctor_get(x_14, 0); -lean_dec(x_61); -x_62 = lean_ctor_get(x_60, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_60, 1); -lean_inc(x_63); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_62); -lean_ctor_set(x_64, 1, x_63); -lean_ctor_set(x_64, 2, x_8); -x_65 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_65, 0, x_1); -lean_ctor_set(x_65, 1, x_64); -lean_ctor_set_tag(x_14, 1); -lean_ctor_set(x_14, 0, x_65); -return x_14; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_14, 1); -lean_inc(x_66); -lean_dec(x_14); -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_66, 1); -lean_inc(x_68); -x_69 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_69, 0, x_67); -lean_ctor_set(x_69, 1, x_68); -lean_ctor_set(x_69, 2, x_8); -x_70 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_70, 0, x_1); -lean_ctor_set(x_70, 1, x_69); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_66); -return x_71; -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_72 = !lean_is_exclusive(x_14); -if (x_72 == 0) -{ -return x_14; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_14, 0); -x_74 = lean_ctor_get(x_14, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_14); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -lean_object* x_76; uint8_t x_77; uint8_t x_78; uint8_t x_79; uint8_t x_80; uint8_t x_81; lean_object* x_82; lean_object* x_83; uint8_t x_84; lean_object* x_85; -x_76 = lean_ctor_get(x_5, 0); -x_77 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_78 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_79 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_80 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -lean_inc(x_76); -lean_dec(x_5); -x_81 = 1; -x_82 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_82, 0, x_76); -lean_ctor_set_uint8(x_82, sizeof(void*)*1, x_77); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 1, x_78); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 2, x_79); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 3, x_80); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 4, x_81); -lean_inc(x_8); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_8); -lean_ctor_set(x_83, 2, x_9); -x_84 = 0; -lean_inc(x_6); -x_85 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_84, x_6, x_6, x_83, x_7); -lean_dec(x_6); -if (lean_obj_tag(x_85) == 0) -{ -lean_object* x_86; -x_86 = lean_ctor_get(x_85, 0); -lean_inc(x_86); -switch (lean_obj_tag(x_86)) { -case 2: -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_85, 1); -lean_inc(x_87); -lean_dec(x_85); -x_88 = lean_ctor_get(x_86, 0); -lean_inc(x_88); -lean_dec(x_86); -lean_inc(x_88); -x_89 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_88, x_2, x_87); -if (lean_obj_tag(x_89) == 0) -{ -lean_object* x_90; uint8_t x_91; -x_90 = lean_ctor_get(x_89, 0); -lean_inc(x_90); -x_91 = lean_unbox(x_90); -lean_dec(x_90); -if (x_91 == 0) -{ -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -lean_dec(x_8); -lean_dec(x_1); -x_92 = lean_ctor_get(x_89, 1); -lean_inc(x_92); -lean_dec(x_89); -x_93 = l_Lean_Meta_mkFreshId___rarg(x_92); -x_94 = lean_ctor_get(x_93, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_93, 1); -lean_inc(x_95); -lean_dec(x_93); -x_96 = l_Lean_mkLevelMVar(x_94); -lean_inc(x_96); -x_97 = l_Lean_mkSort(x_96); -x_98 = l_Lean_Meta_assignExprMVar(x_88, x_97, x_2, x_95); -lean_dec(x_2); -if (lean_obj_tag(x_98) == 0) -{ -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_98, 1); -lean_inc(x_99); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_100 = x_98; -} else { - lean_dec_ref(x_98); - x_100 = lean_box(0); -} -if (lean_is_scalar(x_100)) { - x_101 = lean_alloc_ctor(0, 2, 0); -} else { - x_101 = x_100; -} -lean_ctor_set(x_101, 0, x_96); -lean_ctor_set(x_101, 1, x_99); -return x_101; -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -lean_dec(x_96); -x_102 = lean_ctor_get(x_98, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 1); -lean_inc(x_103); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_104 = x_98; -} else { - lean_dec_ref(x_98); - x_104 = lean_box(0); -} -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(1, 2, 0); -} else { - x_105 = x_104; -} -lean_ctor_set(x_105, 0, x_102); -lean_ctor_set(x_105, 1, x_103); -return x_105; -} -} -else -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; -lean_dec(x_88); -lean_dec(x_2); -x_106 = lean_ctor_get(x_89, 1); -lean_inc(x_106); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - x_107 = x_89; -} else { - lean_dec_ref(x_89); - x_107 = lean_box(0); -} -x_108 = lean_ctor_get(x_106, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_106, 1); -lean_inc(x_109); -x_110 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_110, 0, x_108); -lean_ctor_set(x_110, 1, x_109); -lean_ctor_set(x_110, 2, x_8); -x_111 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_111, 0, x_1); -lean_ctor_set(x_111, 1, x_110); -if (lean_is_scalar(x_107)) { - x_112 = lean_alloc_ctor(1, 2, 0); -} else { - x_112 = x_107; - lean_ctor_set_tag(x_112, 1); -} -lean_ctor_set(x_112, 0, x_111); -lean_ctor_set(x_112, 1, x_106); -return x_112; -} -} -else -{ -lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; -lean_dec(x_88); -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_113 = lean_ctor_get(x_89, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_89, 1); -lean_inc(x_114); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - x_115 = x_89; -} else { - lean_dec_ref(x_89); - x_115 = lean_box(0); -} -if (lean_is_scalar(x_115)) { - x_116 = lean_alloc_ctor(1, 2, 0); -} else { - x_116 = x_115; -} -lean_ctor_set(x_116, 0, x_113); -lean_ctor_set(x_116, 1, x_114); -return x_116; -} -} -case 3: -{ -lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_117 = lean_ctor_get(x_85, 1); -lean_inc(x_117); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_118 = x_85; -} else { - lean_dec_ref(x_85); - x_118 = lean_box(0); -} -x_119 = lean_ctor_get(x_86, 0); -lean_inc(x_119); -lean_dec(x_86); -if (lean_is_scalar(x_118)) { - x_120 = lean_alloc_ctor(0, 2, 0); -} else { - x_120 = x_118; -} -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_117); -return x_120; -} -default: -{ -lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; -lean_dec(x_86); -lean_dec(x_2); -x_121 = lean_ctor_get(x_85, 1); -lean_inc(x_121); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_122 = x_85; -} else { - lean_dec_ref(x_85); - x_122 = lean_box(0); -} -x_123 = lean_ctor_get(x_121, 0); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 1); -lean_inc(x_124); -x_125 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_125, 0, x_123); -lean_ctor_set(x_125, 1, x_124); -lean_ctor_set(x_125, 2, x_8); -x_126 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_126, 0, x_1); -lean_ctor_set(x_126, 1, x_125); -if (lean_is_scalar(x_122)) { - x_127 = lean_alloc_ctor(1, 2, 0); -} else { - x_127 = x_122; - lean_ctor_set_tag(x_127, 1); -} -lean_ctor_set(x_127, 0, x_126); -lean_ctor_set(x_127, 1, x_121); -return x_127; -} -} -} -else -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_128 = lean_ctor_get(x_85, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_85, 1); -lean_inc(x_129); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_130 = x_85; -} else { - lean_dec_ref(x_85); - x_130 = lean_box(0); -} -if (lean_is_scalar(x_130)) { - x_131 = lean_alloc_ctor(1, 2, 0); -} else { - x_131 = x_130; -} -lean_ctor_set(x_131, 0, x_128); -lean_ctor_set(x_131, 1, x_129); -return x_131; -} -} -} -else -{ -uint8_t x_132; -lean_dec(x_2); -lean_dec(x_1); -x_132 = !lean_is_exclusive(x_4); -if (x_132 == 0) -{ -return x_4; -} -else -{ -lean_object* x_133; lean_object* x_134; lean_object* x_135; -x_133 = lean_ctor_get(x_4, 0); -x_134 = lean_ctor_get(x_4, 1); -lean_inc(x_134); -lean_inc(x_133); -lean_dec(x_4); -x_135 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_135, 0, x_133); -lean_ctor_set(x_135, 1, x_134); -return x_135; -} -} -} -} -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_nat_dec_eq(x_3, x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_sub(x_3, x_10); -lean_dec(x_3); -x_12 = lean_array_fget(x_2, x_11); -lean_inc(x_6); -x_13 = l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(x_12, x_6, x_7); -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -lean_inc(x_6); -x_16 = l_Lean_Meta_getLevelAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__45(x_14, x_6, x_15); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -x_19 = l_Lean_mkLevelIMax(x_17, x_5); -x_3 = x_11; -x_4 = lean_box(0); -x_5 = x_19; -x_7 = x_18; -goto _start; -} -else -{ -uint8_t x_21; -lean_dec(x_11); -lean_dec(x_6); -lean_dec(x_5); -x_21 = !lean_is_exclusive(x_16); -if (x_21 == 0) -{ -return x_16; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_16, 0); -x_23 = lean_ctor_get(x_16, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_16); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -else -{ -uint8_t x_25; -lean_dec(x_11); -lean_dec(x_6); -lean_dec(x_5); -x_25 = !lean_is_exclusive(x_13); -if (x_25 == 0) -{ -return x_13; -} -else -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_13, 0); -x_27 = lean_ctor_get(x_13, 1); -lean_inc(x_27); -lean_inc(x_26); -lean_dec(x_13); -x_28 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_28, 0, x_26); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -} -else -{ -lean_object* x_29; -lean_dec(x_6); -lean_dec(x_3); -x_29 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_29, 0, x_5); -lean_ctor_set(x_29, 1, x_7); -return x_29; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__48(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_4); -x_9 = lean_nat_dec_lt(x_5, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; -lean_dec(x_5); -lean_inc(x_6); -x_10 = l_Lean_Meta_getLevelAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__45(x_3, x_6, x_7); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); -lean_inc(x_12); -lean_dec(x_10); -x_13 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46(x_1, x_1, x_2, lean_box(0), x_11, x_6, x_12); -if (lean_obj_tag(x_13) == 0) -{ -uint8_t x_14; -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_13, 0); -x_16 = l_Lean_Level_normalize___main(x_15); -lean_dec(x_15); -x_17 = l_Lean_mkSort(x_16); -lean_ctor_set(x_13, 0, x_17); -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_13, 0); -x_19 = lean_ctor_get(x_13, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_13); -x_20 = l_Lean_Level_normalize___main(x_18); -lean_dec(x_18); -x_21 = l_Lean_mkSort(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_19); -return x_22; -} -} -else -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_13); -if (x_23 == 0) -{ -return x_13; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_13, 0); -x_25 = lean_ctor_get(x_13, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_13); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -uint8_t x_27; -lean_dec(x_6); -lean_dec(x_2); -x_27 = !lean_is_exclusive(x_10); -if (x_27 == 0) -{ -return x_10; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_10, 0); -x_29 = lean_ctor_get(x_10, 1); -lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_10); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -} -else -{ -lean_object* x_31; lean_object* x_32; -x_31 = lean_array_fget(x_4, x_5); -lean_inc(x_6); -x_32 = l_Lean_Meta_getFVarLocalDecl(x_31, x_6, x_7); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = l_Lean_LocalDecl_type(x_33); -lean_dec(x_33); -lean_inc(x_6); -lean_inc(x_35); -x_36 = l_Lean_Meta_isClassQuick___main(x_35, x_6, x_34); -if (lean_obj_tag(x_36) == 0) -{ -lean_object* x_37; -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -switch (lean_obj_tag(x_37)) { -case 0: -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; -lean_dec(x_35); -lean_dec(x_31); -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -x_39 = lean_unsigned_to_nat(1u); -x_40 = lean_nat_add(x_5, x_39); -lean_dec(x_5); -x_5 = x_40; -x_7 = x_38; -goto _start; -} -case 1: -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; -lean_dec(x_35); -x_42 = lean_ctor_get(x_36, 1); -lean_inc(x_42); -lean_dec(x_36); -x_43 = lean_ctor_get(x_37, 0); -lean_inc(x_43); -lean_dec(x_37); -x_44 = lean_unsigned_to_nat(1u); -x_45 = lean_nat_add(x_5, x_44); -lean_dec(x_5); -x_46 = !lean_is_exclusive(x_6); -if (x_46 == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_47 = lean_ctor_get(x_6, 2); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_43); -lean_ctor_set(x_48, 1, x_31); -x_49 = lean_array_push(x_47, x_48); -lean_ctor_set(x_6, 2, x_49); -x_5 = x_45; -x_7 = x_42; -goto _start; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_51 = lean_ctor_get(x_6, 0); -x_52 = lean_ctor_get(x_6, 1); -x_53 = lean_ctor_get(x_6, 2); -lean_inc(x_53); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_6); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_43); -lean_ctor_set(x_54, 1, x_31); -x_55 = lean_array_push(x_53, x_54); -x_56 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_56, 0, x_51); -lean_ctor_set(x_56, 1, x_52); -lean_ctor_set(x_56, 2, x_55); -x_5 = x_45; -x_6 = x_56; -x_7 = x_42; -goto _start; -} -} -default: -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_36, 1); -lean_inc(x_58); -lean_dec(x_36); -lean_inc(x_6); -x_59 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_35, x_6, x_58); -if (lean_obj_tag(x_59) == 0) -{ -lean_object* x_60; -x_60 = lean_ctor_get(x_59, 0); -lean_inc(x_60); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -lean_dec(x_31); -x_61 = lean_ctor_get(x_59, 1); -lean_inc(x_61); -lean_dec(x_59); -x_62 = lean_unsigned_to_nat(1u); -x_63 = lean_nat_add(x_5, x_62); -lean_dec(x_5); -x_5 = x_63; -x_7 = x_61; -goto _start; -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; -x_65 = lean_ctor_get(x_59, 1); -lean_inc(x_65); -lean_dec(x_59); -x_66 = lean_ctor_get(x_60, 0); -lean_inc(x_66); -lean_dec(x_60); -x_67 = lean_unsigned_to_nat(1u); -x_68 = lean_nat_add(x_5, x_67); -lean_dec(x_5); -x_69 = !lean_is_exclusive(x_6); -if (x_69 == 0) -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_6, 2); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_31); -x_72 = lean_array_push(x_70, x_71); -lean_ctor_set(x_6, 2, x_72); -x_5 = x_68; -x_7 = x_65; -goto _start; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_74 = lean_ctor_get(x_6, 0); -x_75 = lean_ctor_get(x_6, 1); -x_76 = lean_ctor_get(x_6, 2); -lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_6); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_66); -lean_ctor_set(x_77, 1, x_31); -x_78 = lean_array_push(x_76, x_77); -x_79 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_79, 0, x_74); -lean_ctor_set(x_79, 1, x_75); -lean_ctor_set(x_79, 2, x_78); -x_5 = x_68; -x_6 = x_79; -x_7 = x_65; -goto _start; -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_59); -if (x_81 == 0) -{ -return x_59; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_59, 0); -x_83 = lean_ctor_get(x_59, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_59); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -} -} -else -{ -uint8_t x_85; -lean_dec(x_35); -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_85 = !lean_is_exclusive(x_36); -if (x_85 == 0) -{ -return x_36; -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_36, 0); -x_87 = lean_ctor_get(x_36, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_36); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} -} -} -else -{ -uint8_t x_89; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_89 = !lean_is_exclusive(x_32); -if (x_89 == 0) -{ -return x_32; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_32, 0); -x_91 = lean_ctor_get(x_32, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_32); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; -x_10 = l_Lean_Expr_isForall(x_7); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_inc(x_8); -x_11 = l_Lean_Meta_getLevelAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__45(x_1, x_8, x_9); -if (lean_obj_tag(x_11) == 0) -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -x_13 = lean_ctor_get(x_11, 1); -lean_inc(x_13); -lean_dec(x_11); -x_14 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46(x_2, x_2, x_3, lean_box(0), x_12, x_8, x_13); -lean_dec(x_2); -if (lean_obj_tag(x_14) == 0) -{ -uint8_t x_15; -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 0); -x_17 = l_Lean_Level_normalize___main(x_16); -lean_dec(x_16); -x_18 = l_Lean_mkSort(x_17); -lean_ctor_set(x_14, 0, x_18); -return x_14; -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_19 = lean_ctor_get(x_14, 0); -x_20 = lean_ctor_get(x_14, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_14); -x_21 = l_Lean_Level_normalize___main(x_19); -lean_dec(x_19); -x_22 = l_Lean_mkSort(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_20); -return x_23; -} -} -else -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_14); -if (x_24 == 0) -{ -return x_14; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_14, 0); -x_26 = lean_ctor_get(x_14, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_14); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -uint8_t x_28; -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_28 = !lean_is_exclusive(x_11); -if (x_28 == 0) -{ -return x_11; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_11, 0); -x_30 = lean_ctor_get(x_11, 1); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_11); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -} -else -{ -lean_object* x_32; -lean_dec(x_1); -x_32 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__47(x_4, x_5, x_6, x_2, x_3, x_7, x_8, x_9); -return x_32; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_13 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___closed__1; -lean_inc(x_8); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_13); -lean_closure_set(x_14, 1, x_8); -x_15 = lean_box(x_1); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_7); -lean_inc(x_4); -lean_inc(x_8); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___lambda__1___boxed), 9, 6); -lean_closure_set(x_16, 0, x_8); -lean_closure_set(x_16, 1, x_4); -lean_closure_set(x_16, 2, x_7); -lean_closure_set(x_16, 3, x_15); -lean_closure_set(x_16, 4, x_2); -lean_closure_set(x_16, 5, x_3); -x_17 = lean_array_get_size(x_9); -x_18 = lean_nat_dec_lt(x_10, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_11, x_12); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_9, x_10); -lean_inc(x_11); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_11, x_12); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_11); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_11, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_10, x_28); -lean_dec(x_10); -x_10 = x_29; -x_12 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_10, x_33); -lean_dec(x_10); -x_35 = !lean_is_exclusive(x_11); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_11, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_11, 2, x_38); -x_10 = x_34; -x_12 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_11, 0); -x_41 = lean_ctor_get(x_11, 1); -x_42 = lean_ctor_get(x_11, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_11); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_10 = x_34; -x_11 = x_45; -x_12 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_11); -x_48 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_24, x_11, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_10, x_51); -lean_dec(x_10); -x_10 = x_52; -x_12 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_10, x_56); -lean_dec(x_10); -x_58 = !lean_is_exclusive(x_11); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_11, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_11, 2, x_61); -x_10 = x_57; -x_12 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_11, 0); -x_64 = lean_ctor_get(x_11, 1); -x_65 = lean_ctor_get(x_11, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_11); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_10 = x_57; -x_11 = x_68; -x_12 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__50(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_4); -x_9 = lean_nat_dec_lt(x_5, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; -lean_dec(x_5); -lean_inc(x_6); -x_10 = l_Lean_Meta_getLevelAux___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__45(x_3, x_6, x_7); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); -lean_inc(x_12); -lean_dec(x_10); -x_13 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46(x_1, x_1, x_2, lean_box(0), x_11, x_6, x_12); -if (lean_obj_tag(x_13) == 0) -{ -uint8_t x_14; -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_13, 0); -x_16 = l_Lean_Level_normalize___main(x_15); -lean_dec(x_15); -x_17 = l_Lean_mkSort(x_16); -lean_ctor_set(x_13, 0, x_17); -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_13, 0); -x_19 = lean_ctor_get(x_13, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_13); -x_20 = l_Lean_Level_normalize___main(x_18); -lean_dec(x_18); -x_21 = l_Lean_mkSort(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_19); -return x_22; -} -} -else -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_13); -if (x_23 == 0) -{ -return x_13; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_13, 0); -x_25 = lean_ctor_get(x_13, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_13); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -uint8_t x_27; -lean_dec(x_6); -lean_dec(x_2); -x_27 = !lean_is_exclusive(x_10); -if (x_27 == 0) -{ -return x_10; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_10, 0); -x_29 = lean_ctor_get(x_10, 1); -lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_10); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -} -else -{ -lean_object* x_31; lean_object* x_32; -x_31 = lean_array_fget(x_4, x_5); -lean_inc(x_6); -x_32 = l_Lean_Meta_getFVarLocalDecl(x_31, x_6, x_7); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = l_Lean_LocalDecl_type(x_33); -lean_dec(x_33); -lean_inc(x_6); -lean_inc(x_35); -x_36 = l_Lean_Meta_isClassQuick___main(x_35, x_6, x_34); -if (lean_obj_tag(x_36) == 0) -{ -lean_object* x_37; -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -switch (lean_obj_tag(x_37)) { -case 0: -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; -lean_dec(x_35); -lean_dec(x_31); -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -x_39 = lean_unsigned_to_nat(1u); -x_40 = lean_nat_add(x_5, x_39); -lean_dec(x_5); -x_5 = x_40; -x_7 = x_38; -goto _start; -} -case 1: -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; -lean_dec(x_35); -x_42 = lean_ctor_get(x_36, 1); -lean_inc(x_42); -lean_dec(x_36); -x_43 = lean_ctor_get(x_37, 0); -lean_inc(x_43); -lean_dec(x_37); -x_44 = lean_unsigned_to_nat(1u); -x_45 = lean_nat_add(x_5, x_44); -lean_dec(x_5); -x_46 = !lean_is_exclusive(x_6); -if (x_46 == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_47 = lean_ctor_get(x_6, 2); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_43); -lean_ctor_set(x_48, 1, x_31); -x_49 = lean_array_push(x_47, x_48); -lean_ctor_set(x_6, 2, x_49); -x_5 = x_45; -x_7 = x_42; -goto _start; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_51 = lean_ctor_get(x_6, 0); -x_52 = lean_ctor_get(x_6, 1); -x_53 = lean_ctor_get(x_6, 2); -lean_inc(x_53); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_6); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_43); -lean_ctor_set(x_54, 1, x_31); -x_55 = lean_array_push(x_53, x_54); -x_56 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_56, 0, x_51); -lean_ctor_set(x_56, 1, x_52); -lean_ctor_set(x_56, 2, x_55); -x_5 = x_45; -x_6 = x_56; -x_7 = x_42; -goto _start; -} -} -default: -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_36, 1); -lean_inc(x_58); -lean_dec(x_36); -lean_inc(x_6); -x_59 = l_Lean_Meta_isClassExpensive___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__35(x_35, x_6, x_58); -if (lean_obj_tag(x_59) == 0) -{ -lean_object* x_60; -x_60 = lean_ctor_get(x_59, 0); -lean_inc(x_60); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -lean_dec(x_31); -x_61 = lean_ctor_get(x_59, 1); -lean_inc(x_61); -lean_dec(x_59); -x_62 = lean_unsigned_to_nat(1u); -x_63 = lean_nat_add(x_5, x_62); -lean_dec(x_5); -x_5 = x_63; -x_7 = x_61; -goto _start; -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; -x_65 = lean_ctor_get(x_59, 1); -lean_inc(x_65); -lean_dec(x_59); -x_66 = lean_ctor_get(x_60, 0); -lean_inc(x_66); -lean_dec(x_60); -x_67 = lean_unsigned_to_nat(1u); -x_68 = lean_nat_add(x_5, x_67); -lean_dec(x_5); -x_69 = !lean_is_exclusive(x_6); -if (x_69 == 0) -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_6, 2); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_31); -x_72 = lean_array_push(x_70, x_71); -lean_ctor_set(x_6, 2, x_72); -x_5 = x_68; -x_7 = x_65; -goto _start; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_74 = lean_ctor_get(x_6, 0); -x_75 = lean_ctor_get(x_6, 1); -x_76 = lean_ctor_get(x_6, 2); -lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_6); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_66); -lean_ctor_set(x_77, 1, x_31); -x_78 = lean_array_push(x_76, x_77); -x_79 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_79, 0, x_74); -lean_ctor_set(x_79, 1, x_75); -lean_ctor_set(x_79, 2, x_78); -x_5 = x_68; -x_6 = x_79; -x_7 = x_65; -goto _start; -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_59); -if (x_81 == 0) -{ -return x_59; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_59, 0); -x_83 = lean_ctor_get(x_59, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_59); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -} -} -else -{ -uint8_t x_85; -lean_dec(x_35); -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_85 = !lean_is_exclusive(x_36); -if (x_85 == 0) -{ -return x_36; -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_36, 0); -x_87 = lean_ctor_get(x_36, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_36); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} -} -} -else -{ -uint8_t x_89; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_89 = !lean_is_exclusive(x_32); -if (x_89 == 0) -{ -return x_32; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_32, 0); -x_91 = lean_ctor_get(x_32, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_32); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__47(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_22 = lean_ctor_get(x_6, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_6, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 2); -lean_inc(x_24); -x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); -lean_dec(x_6); -x_26 = lean_array_get_size(x_4); -lean_inc(x_4); -x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); -lean_dec(x_26); -lean_dec(x_23); -x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = (uint8_t)((x_25 << 24) >> 61); -lean_inc(x_29); -x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); -x_33 = l_Lean_mkFVar(x_29); -x_34 = lean_array_push(x_4, x_33); -if (lean_obj_tag(x_2) == 0) -{ -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -else -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_2, 0); -lean_inc(x_36); -x_37 = lean_array_get_size(x_34); -x_38 = lean_nat_dec_lt(x_37, x_36); -lean_dec(x_36); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -lean_dec(x_2); -lean_inc(x_34); -x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); -lean_dec(x_24); -x_40 = !lean_is_exclusive(x_7); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_7, 1); -lean_dec(x_41); -lean_ctor_set(x_7, 1, x_32); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__50(x_34, x_37, x_39, x_34, x_5, x_7, x_30); -lean_dec(x_34); -return x_42; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_7, 0); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_32); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__50(x_34, x_37, x_39, x_34, x_5, x_45, x_30); -lean_dec(x_34); -return x_46; -} -} -else -{ -lean_dec(x_37); -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -} -} -else -{ -lean_object* x_48; -x_48 = lean_box(0); -x_9 = x_48; -goto block_21; -} -block_21: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_7, 1); -lean_dec(x_13); -lean_inc(x_3); -lean_ctor_set(x_7, 1, x_3); -if (x_1 == 0) -{ -lean_object* x_14; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__48(x_4, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_4); -return x_14; -} -else -{ -lean_object* x_15; -lean_inc(x_5); -lean_inc(x_4); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_7, 0); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_7); -lean_inc(x_3); -x_18 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_3); -lean_ctor_set(x_18, 2, x_17); -if (x_1 == 0) -{ -lean_object* x_19; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__48(x_4, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_4); -return x_19; -} -else -{ -lean_object* x_20; -lean_inc(x_5); -lean_inc(x_4); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_20; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__44(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_4 = lean_ctor_get(x_3, 2); -lean_inc(x_4); -x_5 = lean_ctor_get(x_2, 1); -lean_inc(x_5); -x_6 = lean_box(0); -x_7 = 0; -x_8 = l_Array_empty___closed__1; -x_9 = lean_unsigned_to_nat(0u); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__47(x_7, x_6, x_5, x_8, x_9, x_1, x_2, x_3); -if (lean_obj_tag(x_10) == 0) -{ -uint8_t x_11; -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) -{ -lean_object* x_12; uint8_t x_13; -x_12 = lean_ctor_get(x_10, 1); -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_12, 2); -lean_dec(x_14); -lean_ctor_set(x_12, 2, x_4); -return x_10; -} -else -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_15 = lean_ctor_get(x_12, 0); -x_16 = lean_ctor_get(x_12, 1); -x_17 = lean_ctor_get(x_12, 3); -x_18 = lean_ctor_get(x_12, 4); -x_19 = lean_ctor_get(x_12, 5); -lean_inc(x_19); -lean_inc(x_18); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_12); -x_20 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_20, 0, x_15); -lean_ctor_set(x_20, 1, x_16); -lean_ctor_set(x_20, 2, x_4); -lean_ctor_set(x_20, 3, x_17); -lean_ctor_set(x_20, 4, x_18); -lean_ctor_set(x_20, 5, x_19); -lean_ctor_set(x_10, 1, x_20); -return x_10; -} -} -else -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_21 = lean_ctor_get(x_10, 1); -x_22 = lean_ctor_get(x_10, 0); -lean_inc(x_21); -lean_inc(x_22); -lean_dec(x_10); -x_23 = lean_ctor_get(x_21, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_21, 1); -lean_inc(x_24); -x_25 = lean_ctor_get(x_21, 3); -lean_inc(x_25); -x_26 = lean_ctor_get(x_21, 4); -lean_inc(x_26); -x_27 = lean_ctor_get(x_21, 5); -lean_inc(x_27); -if (lean_is_exclusive(x_21)) { - lean_ctor_release(x_21, 0); - lean_ctor_release(x_21, 1); - lean_ctor_release(x_21, 2); - lean_ctor_release(x_21, 3); - lean_ctor_release(x_21, 4); - lean_ctor_release(x_21, 5); - x_28 = x_21; -} else { - lean_dec_ref(x_21); - x_28 = lean_box(0); -} -if (lean_is_scalar(x_28)) { - x_29 = lean_alloc_ctor(0, 6, 0); -} else { - x_29 = x_28; -} -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_4); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -lean_ctor_set(x_29, 5, x_27); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_22); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -else -{ -uint8_t x_31; -x_31 = !lean_is_exclusive(x_10); -if (x_31 == 0) -{ -lean_object* x_32; uint8_t x_33; -x_32 = lean_ctor_get(x_10, 1); -x_33 = !lean_is_exclusive(x_32); -if (x_33 == 0) -{ -lean_object* x_34; -x_34 = lean_ctor_get(x_32, 2); -lean_dec(x_34); -lean_ctor_set(x_32, 2, x_4); -return x_10; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_35 = lean_ctor_get(x_32, 0); -x_36 = lean_ctor_get(x_32, 1); -x_37 = lean_ctor_get(x_32, 3); -x_38 = lean_ctor_get(x_32, 4); -x_39 = lean_ctor_get(x_32, 5); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_dec(x_32); -x_40 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_36); -lean_ctor_set(x_40, 2, x_4); -lean_ctor_set(x_40, 3, x_37); -lean_ctor_set(x_40, 4, x_38); -lean_ctor_set(x_40, 5, x_39); -lean_ctor_set(x_10, 1, x_40); -return x_10; -} -} -else -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_41 = lean_ctor_get(x_10, 1); -x_42 = lean_ctor_get(x_10, 0); -lean_inc(x_41); -lean_inc(x_42); -lean_dec(x_10); -x_43 = lean_ctor_get(x_41, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_41, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_41, 3); -lean_inc(x_45); -x_46 = lean_ctor_get(x_41, 4); -lean_inc(x_46); -x_47 = lean_ctor_get(x_41, 5); -lean_inc(x_47); -if (lean_is_exclusive(x_41)) { - lean_ctor_release(x_41, 0); - lean_ctor_release(x_41, 1); - lean_ctor_release(x_41, 2); - lean_ctor_release(x_41, 3); - lean_ctor_release(x_41, 4); - lean_ctor_release(x_41, 5); - x_48 = x_41; -} else { - lean_dec_ref(x_41); - x_48 = lean_box(0); -} -if (lean_is_scalar(x_48)) { - x_49 = lean_alloc_ctor(0, 6, 0); -} else { - x_49 = x_48; -} -lean_ctor_set(x_49, 0, x_43); -lean_ctor_set(x_49, 1, x_44); -lean_ctor_set(x_49, 2, x_4); -lean_ctor_set(x_49, 3, x_45); -lean_ctor_set(x_49, 4, x_46); -lean_ctor_set(x_49, 5, x_47); -x_50 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_50, 0, x_42); -lean_ctor_set(x_50, 1, x_49); -return x_50; -} -} -} -} -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_nat_dec_eq(x_5, x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_sub(x_5, x_11); -lean_dec(x_5); -x_13 = lean_nat_sub(x_4, x_12); -x_14 = lean_nat_sub(x_13, x_11); -lean_dec(x_13); -x_15 = lean_ctor_get(x_7, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_7, 1); -lean_inc(x_16); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -x_18 = !lean_is_exclusive(x_15); -if (x_18 == 0) -{ -uint8_t x_19; lean_object* x_20; uint8_t x_21; lean_object* x_22; -x_19 = 1; -lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 4, x_19); -lean_inc(x_16); -x_20 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_20, 0, x_15); -lean_ctor_set(x_20, 1, x_16); -lean_ctor_set(x_20, 2, x_17); -x_21 = 0; -lean_inc(x_6); -x_22 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_21, x_6, x_6, x_20, x_8); -lean_dec(x_6); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -if (lean_obj_tag(x_23) == 7) -{ -lean_object* x_24; lean_object* x_25; uint8_t x_26; -lean_dec(x_16); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_ctor_get(x_23, 2); -lean_inc(x_25); -lean_dec(x_23); -x_26 = l_Lean_Expr_hasLooseBVars(x_25); -if (x_26 == 0) -{ -lean_dec(x_14); -x_5 = x_12; -x_6 = x_25; -x_8 = x_24; -goto _start; -} -else -{ -lean_object* x_28; lean_object* x_29; -lean_inc(x_3); -lean_inc(x_1); -x_28 = l_Lean_mkProj(x_1, x_14, x_3); -x_29 = lean_expr_instantiate1(x_25, x_28); -lean_dec(x_28); -lean_dec(x_25); -x_5 = x_12; -x_6 = x_29; -x_8 = x_24; -goto _start; -} -} -else -{ -uint8_t x_31; -lean_dec(x_23); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -x_31 = !lean_is_exclusive(x_22); -if (x_31 == 0) -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_32 = lean_ctor_get(x_22, 1); -x_33 = lean_ctor_get(x_22, 0); -lean_dec(x_33); -x_34 = lean_ctor_get(x_32, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_32, 1); -lean_inc(x_35); -x_36 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_36, 0, x_34); -lean_ctor_set(x_36, 1, x_35); -lean_ctor_set(x_36, 2, x_16); -x_37 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_37, 0, x_1); -lean_ctor_set(x_37, 1, x_2); -lean_ctor_set(x_37, 2, x_3); -lean_ctor_set(x_37, 3, x_36); -lean_ctor_set_tag(x_22, 1); -lean_ctor_set(x_22, 0, x_37); -return x_22; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_22, 1); -lean_inc(x_38); -lean_dec(x_22); -x_39 = lean_ctor_get(x_38, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_38, 1); -lean_inc(x_40); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -lean_ctor_set(x_41, 2, x_16); -x_42 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_42, 0, x_1); -lean_ctor_set(x_42, 1, x_2); -lean_ctor_set(x_42, 2, x_3); -lean_ctor_set(x_42, 3, x_41); -x_43 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_43, 0, x_42); -lean_ctor_set(x_43, 1, x_38); -return x_43; -} -} -} -else -{ -uint8_t x_44; -lean_dec(x_16); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_44 = !lean_is_exclusive(x_22); -if (x_44 == 0) -{ -return x_22; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_22, 0); -x_46 = lean_ctor_get(x_22, 1); -lean_inc(x_46); -lean_inc(x_45); -lean_dec(x_22); -x_47 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_47, 0, x_45); -lean_ctor_set(x_47, 1, x_46); -return x_47; -} -} -} -else -{ -lean_object* x_48; uint8_t x_49; uint8_t x_50; uint8_t x_51; uint8_t x_52; uint8_t x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; lean_object* x_57; -x_48 = lean_ctor_get(x_15, 0); -x_49 = lean_ctor_get_uint8(x_15, sizeof(void*)*1); -x_50 = lean_ctor_get_uint8(x_15, sizeof(void*)*1 + 1); -x_51 = lean_ctor_get_uint8(x_15, sizeof(void*)*1 + 2); -x_52 = lean_ctor_get_uint8(x_15, sizeof(void*)*1 + 3); -lean_inc(x_48); -lean_dec(x_15); -x_53 = 1; -x_54 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_54, 0, x_48); -lean_ctor_set_uint8(x_54, sizeof(void*)*1, x_49); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 1, x_50); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 2, x_51); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 3, x_52); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 4, x_53); -lean_inc(x_16); -x_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_16); -lean_ctor_set(x_55, 2, x_17); -x_56 = 0; -lean_inc(x_6); -x_57 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_56, x_6, x_6, x_55, x_8); -lean_dec(x_6); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -if (lean_obj_tag(x_58) == 7) -{ -lean_object* x_59; lean_object* x_60; uint8_t x_61; -lean_dec(x_16); -x_59 = lean_ctor_get(x_57, 1); -lean_inc(x_59); -lean_dec(x_57); -x_60 = lean_ctor_get(x_58, 2); -lean_inc(x_60); -lean_dec(x_58); -x_61 = l_Lean_Expr_hasLooseBVars(x_60); -if (x_61 == 0) -{ -lean_dec(x_14); -x_5 = x_12; -x_6 = x_60; -x_8 = x_59; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; -lean_inc(x_3); -lean_inc(x_1); -x_63 = l_Lean_mkProj(x_1, x_14, x_3); -x_64 = lean_expr_instantiate1(x_60, x_63); -lean_dec(x_63); -lean_dec(x_60); -x_5 = x_12; -x_6 = x_64; -x_8 = x_59; -goto _start; -} -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -lean_dec(x_58); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -x_66 = lean_ctor_get(x_57, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_57)) { - lean_ctor_release(x_57, 0); - lean_ctor_release(x_57, 1); - x_67 = x_57; -} else { - lean_dec_ref(x_57); - x_67 = lean_box(0); -} -x_68 = lean_ctor_get(x_66, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_66, 1); -lean_inc(x_69); -x_70 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -lean_ctor_set(x_70, 2, x_16); -x_71 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_71, 0, x_1); -lean_ctor_set(x_71, 1, x_2); -lean_ctor_set(x_71, 2, x_3); -lean_ctor_set(x_71, 3, x_70); -if (lean_is_scalar(x_67)) { - x_72 = lean_alloc_ctor(1, 2, 0); -} else { - x_72 = x_67; - lean_ctor_set_tag(x_72, 1); -} -lean_ctor_set(x_72, 0, x_71); -lean_ctor_set(x_72, 1, x_66); -return x_72; -} -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -lean_dec(x_16); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_73 = lean_ctor_get(x_57, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_57, 1); -lean_inc(x_74); -if (lean_is_exclusive(x_57)) { - lean_ctor_release(x_57, 0); - lean_ctor_release(x_57, 1); - x_75 = x_57; -} else { - lean_dec_ref(x_57); - x_75 = lean_box(0); -} -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(1, 2, 0); -} else { - x_76 = x_75; -} -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -return x_76; -} -} -} -else -{ -lean_object* x_77; -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_6); -lean_ctor_set(x_77, 1, x_8); -return x_77; -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__51(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -lean_inc(x_4); -lean_inc(x_3); -x_6 = l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(x_3, x_4, x_5); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_7 = lean_ctor_get(x_4, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_6, 1); -lean_inc(x_9); -lean_dec(x_6); -x_10 = lean_ctor_get(x_4, 1); -lean_inc(x_10); -x_11 = lean_ctor_get(x_4, 2); -lean_inc(x_11); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -uint8_t x_13; lean_object* x_14; uint8_t x_15; lean_object* x_16; -x_13 = 1; -lean_ctor_set_uint8(x_7, sizeof(void*)*1 + 4, x_13); -lean_inc(x_10); -x_14 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_14, 0, x_7); -lean_ctor_set(x_14, 1, x_10); -lean_ctor_set(x_14, 2, x_11); -x_15 = 0; -lean_inc(x_14); -lean_inc(x_8); -x_16 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_15, x_8, x_8, x_14, x_9); -lean_dec(x_8); -if (lean_obj_tag(x_16) == 0) -{ -uint8_t x_17; -x_17 = !lean_is_exclusive(x_16); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_16, 1); -x_19 = lean_ctor_get(x_16, 0); -x_20 = lean_ctor_get(x_18, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -x_22 = l_Lean_Expr_getAppFn___main(x_19); -if (lean_obj_tag(x_22) == 4) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -lean_inc(x_20); -x_25 = lean_environment_find(x_20, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; lean_object* x_27; -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_26 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_26, 0, x_20); -lean_ctor_set(x_26, 1, x_21); -lean_ctor_set(x_26, 2, x_10); -x_27 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_27, 0, x_1); -lean_ctor_set(x_27, 1, x_2); -lean_ctor_set(x_27, 2, x_3); -lean_ctor_set(x_27, 3, x_26); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_27); -return x_16; -} -else -{ -lean_object* x_28; -x_28 = lean_ctor_get(x_25, 0); -lean_inc(x_28); -lean_dec(x_25); -if (lean_obj_tag(x_28) == 5) -{ -lean_object* x_29; lean_object* x_30; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -lean_dec(x_28); -x_30 = lean_ctor_get(x_29, 4); -lean_inc(x_30); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; -lean_dec(x_29); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_31 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_31, 0, x_20); -lean_ctor_set(x_31, 1, x_21); -lean_ctor_set(x_31, 2, x_10); -x_32 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_32, 0, x_1); -lean_ctor_set(x_32, 1, x_2); -lean_ctor_set(x_32, 2, x_3); -lean_ctor_set(x_32, 3, x_31); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_32); -return x_16; -} -else -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_30, 1); -lean_inc(x_33); -if (lean_obj_tag(x_33) == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_34 = lean_ctor_get(x_29, 1); -lean_inc(x_34); -lean_dec(x_29); -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -lean_dec(x_30); -x_36 = lean_unsigned_to_nat(0u); -x_37 = l_Lean_Expr_getAppNumArgsAux___main(x_19, x_36); -x_38 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_37); -x_39 = lean_mk_array(x_37, x_38); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_sub(x_37, x_40); -lean_dec(x_37); -x_42 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_19, x_39, x_41); -x_43 = lean_array_get_size(x_42); -x_44 = lean_nat_dec_eq(x_34, x_43); -lean_dec(x_43); -lean_dec(x_34); -if (x_44 == 0) -{ -lean_object* x_45; lean_object* x_46; -lean_dec(x_42); -lean_dec(x_35); -lean_dec(x_24); -lean_dec(x_14); -lean_dec(x_4); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_20); -lean_ctor_set(x_45, 1, x_21); -lean_ctor_set(x_45, 2, x_10); -x_46 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_46, 0, x_1); -lean_ctor_set(x_46, 1, x_2); -lean_ctor_set(x_46, 2, x_3); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_46); -return x_16; -} -else -{ -lean_object* x_47; -lean_inc(x_35); -lean_inc(x_20); -x_47 = lean_environment_find(x_20, x_35); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; -lean_dec(x_42); -lean_dec(x_35); -lean_dec(x_24); -lean_dec(x_14); -lean_dec(x_4); -x_48 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_48, 0, x_20); -lean_ctor_set(x_48, 1, x_21); -lean_ctor_set(x_48, 2, x_10); -x_49 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_49, 0, x_1); -lean_ctor_set(x_49, 1, x_2); -lean_ctor_set(x_49, 2, x_3); -lean_ctor_set(x_49, 3, x_48); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_49); -return x_16; -} -else -{ -lean_object* x_50; lean_object* x_51; -lean_dec(x_47); -lean_dec(x_21); -lean_dec(x_20); -lean_free_object(x_16); -x_50 = l_Lean_mkConst(x_35, x_24); -lean_inc(x_4); -x_51 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__42(x_50, x_42, x_4, x_18); -if (lean_obj_tag(x_51) == 0) -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -lean_dec(x_51); -lean_inc(x_3); -lean_inc_n(x_2, 2); -lean_inc(x_1); -x_54 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52(x_1, x_2, x_3, x_2, x_2, x_52, x_4, x_53); -if (lean_obj_tag(x_54) == 0) -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_54, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_54, 1); -lean_inc(x_56); -lean_dec(x_54); -lean_inc(x_55); -x_57 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_15, x_55, x_55, x_14, x_56); -lean_dec(x_55); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -if (lean_obj_tag(x_58) == 7) -{ -uint8_t x_59; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_59 = !lean_is_exclusive(x_57); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; -x_60 = lean_ctor_get(x_57, 0); -lean_dec(x_60); -x_61 = lean_ctor_get(x_58, 1); -lean_inc(x_61); -lean_dec(x_58); -lean_ctor_set(x_57, 0, x_61); -return x_57; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_62 = lean_ctor_get(x_57, 1); -lean_inc(x_62); -lean_dec(x_57); -x_63 = lean_ctor_get(x_58, 1); -lean_inc(x_63); -lean_dec(x_58); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_63); -lean_ctor_set(x_64, 1, x_62); -return x_64; -} -} -else -{ -uint8_t x_65; -lean_dec(x_58); -x_65 = !lean_is_exclusive(x_57); -if (x_65 == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_57, 1); -x_67 = lean_ctor_get(x_57, 0); -lean_dec(x_67); -x_68 = lean_ctor_get(x_66, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_66, 1); -lean_inc(x_69); -x_70 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -lean_ctor_set(x_70, 2, x_10); -x_71 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_71, 0, x_1); -lean_ctor_set(x_71, 1, x_2); -lean_ctor_set(x_71, 2, x_3); -lean_ctor_set(x_71, 3, x_70); -lean_ctor_set_tag(x_57, 1); -lean_ctor_set(x_57, 0, x_71); -return x_57; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_72 = lean_ctor_get(x_57, 1); -lean_inc(x_72); -lean_dec(x_57); -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_72, 1); -lean_inc(x_74); -x_75 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -lean_ctor_set(x_75, 2, x_10); -x_76 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_76, 0, x_1); -lean_ctor_set(x_76, 1, x_2); -lean_ctor_set(x_76, 2, x_3); -lean_ctor_set(x_76, 3, x_75); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_72); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_78 = !lean_is_exclusive(x_57); -if (x_78 == 0) -{ -return x_57; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_57, 0); -x_80 = lean_ctor_get(x_57, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_57); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -else -{ -uint8_t x_82; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_82 = !lean_is_exclusive(x_54); -if (x_82 == 0) -{ -return x_54; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_54, 0); -x_84 = lean_ctor_get(x_54, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_54); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; -} -} -} -else -{ -uint8_t x_86; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_86 = !lean_is_exclusive(x_51); -if (x_86 == 0) -{ -return x_51; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_51, 0); -x_88 = lean_ctor_get(x_51, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_51); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} -} -} -} -} -else -{ -lean_object* x_90; lean_object* x_91; -lean_dec(x_33); -lean_dec(x_30); -lean_dec(x_29); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_90 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_90, 0, x_20); -lean_ctor_set(x_90, 1, x_21); -lean_ctor_set(x_90, 2, x_10); -x_91 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_91, 0, x_1); -lean_ctor_set(x_91, 1, x_2); -lean_ctor_set(x_91, 2, x_3); -lean_ctor_set(x_91, 3, x_90); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_91); -return x_16; -} -} -} -else -{ -lean_object* x_92; lean_object* x_93; -lean_dec(x_28); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_92 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_92, 0, x_20); -lean_ctor_set(x_92, 1, x_21); -lean_ctor_set(x_92, 2, x_10); -x_93 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_93, 0, x_1); -lean_ctor_set(x_93, 1, x_2); -lean_ctor_set(x_93, 2, x_3); -lean_ctor_set(x_93, 3, x_92); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_93); -return x_16; -} -} -} -else -{ -lean_object* x_94; lean_object* x_95; -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_94 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_94, 0, x_20); -lean_ctor_set(x_94, 1, x_21); -lean_ctor_set(x_94, 2, x_10); -x_95 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_95, 0, x_1); -lean_ctor_set(x_95, 1, x_2); -lean_ctor_set(x_95, 2, x_3); -lean_ctor_set(x_95, 3, x_94); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_95); -return x_16; -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_96 = lean_ctor_get(x_16, 1); -x_97 = lean_ctor_get(x_16, 0); -lean_inc(x_96); -lean_inc(x_97); -lean_dec(x_16); -x_98 = lean_ctor_get(x_96, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_96, 1); -lean_inc(x_99); -x_100 = l_Lean_Expr_getAppFn___main(x_97); -if (lean_obj_tag(x_100) == 4) -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -lean_inc(x_98); -x_103 = lean_environment_find(x_98, x_101); -if (lean_obj_tag(x_103) == 0) -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_104 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_104, 0, x_98); -lean_ctor_set(x_104, 1, x_99); -lean_ctor_set(x_104, 2, x_10); -x_105 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_105, 0, x_1); -lean_ctor_set(x_105, 1, x_2); -lean_ctor_set(x_105, 2, x_3); -lean_ctor_set(x_105, 3, x_104); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_105); -lean_ctor_set(x_106, 1, x_96); -return x_106; -} -else -{ -lean_object* x_107; -x_107 = lean_ctor_get(x_103, 0); -lean_inc(x_107); -lean_dec(x_103); -if (lean_obj_tag(x_107) == 5) -{ -lean_object* x_108; lean_object* x_109; -x_108 = lean_ctor_get(x_107, 0); -lean_inc(x_108); -lean_dec(x_107); -x_109 = lean_ctor_get(x_108, 4); -lean_inc(x_109); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -lean_dec(x_108); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_110 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_110, 0, x_98); -lean_ctor_set(x_110, 1, x_99); -lean_ctor_set(x_110, 2, x_10); -x_111 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_111, 0, x_1); -lean_ctor_set(x_111, 1, x_2); -lean_ctor_set(x_111, 2, x_3); -lean_ctor_set(x_111, 3, x_110); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_111); -lean_ctor_set(x_112, 1, x_96); -return x_112; -} -else -{ -lean_object* x_113; -x_113 = lean_ctor_get(x_109, 1); -lean_inc(x_113); -if (lean_obj_tag(x_113) == 0) -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; uint8_t x_124; -x_114 = lean_ctor_get(x_108, 1); -lean_inc(x_114); -lean_dec(x_108); -x_115 = lean_ctor_get(x_109, 0); -lean_inc(x_115); -lean_dec(x_109); -x_116 = lean_unsigned_to_nat(0u); -x_117 = l_Lean_Expr_getAppNumArgsAux___main(x_97, x_116); -x_118 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_117); -x_119 = lean_mk_array(x_117, x_118); -x_120 = lean_unsigned_to_nat(1u); -x_121 = lean_nat_sub(x_117, x_120); -lean_dec(x_117); -x_122 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_97, x_119, x_121); -x_123 = lean_array_get_size(x_122); -x_124 = lean_nat_dec_eq(x_114, x_123); -lean_dec(x_123); -lean_dec(x_114); -if (x_124 == 0) -{ -lean_object* x_125; lean_object* x_126; lean_object* x_127; -lean_dec(x_122); -lean_dec(x_115); -lean_dec(x_102); -lean_dec(x_14); -lean_dec(x_4); -x_125 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_125, 0, x_98); -lean_ctor_set(x_125, 1, x_99); -lean_ctor_set(x_125, 2, x_10); -x_126 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_126, 0, x_1); -lean_ctor_set(x_126, 1, x_2); -lean_ctor_set(x_126, 2, x_3); -lean_ctor_set(x_126, 3, x_125); -x_127 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_127, 0, x_126); -lean_ctor_set(x_127, 1, x_96); -return x_127; -} -else -{ -lean_object* x_128; -lean_inc(x_115); -lean_inc(x_98); -x_128 = lean_environment_find(x_98, x_115); -if (lean_obj_tag(x_128) == 0) -{ -lean_object* x_129; lean_object* x_130; lean_object* x_131; -lean_dec(x_122); -lean_dec(x_115); -lean_dec(x_102); -lean_dec(x_14); -lean_dec(x_4); -x_129 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_129, 0, x_98); -lean_ctor_set(x_129, 1, x_99); -lean_ctor_set(x_129, 2, x_10); -x_130 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_130, 0, x_1); -lean_ctor_set(x_130, 1, x_2); -lean_ctor_set(x_130, 2, x_3); -lean_ctor_set(x_130, 3, x_129); -x_131 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_131, 0, x_130); -lean_ctor_set(x_131, 1, x_96); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; -lean_dec(x_128); -lean_dec(x_99); -lean_dec(x_98); -x_132 = l_Lean_mkConst(x_115, x_102); -lean_inc(x_4); -x_133 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__42(x_132, x_122, x_4, x_96); -if (lean_obj_tag(x_133) == 0) -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_134 = lean_ctor_get(x_133, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_133, 1); -lean_inc(x_135); -lean_dec(x_133); -lean_inc(x_3); -lean_inc_n(x_2, 2); -lean_inc(x_1); -x_136 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52(x_1, x_2, x_3, x_2, x_2, x_134, x_4, x_135); -if (lean_obj_tag(x_136) == 0) -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_137 = lean_ctor_get(x_136, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_136, 1); -lean_inc(x_138); -lean_dec(x_136); -lean_inc(x_137); -x_139 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_15, x_137, x_137, x_14, x_138); -lean_dec(x_137); -if (lean_obj_tag(x_139) == 0) -{ -lean_object* x_140; -x_140 = lean_ctor_get(x_139, 0); -lean_inc(x_140); -if (lean_obj_tag(x_140) == 7) -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_141 = lean_ctor_get(x_139, 1); -lean_inc(x_141); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_142 = x_139; -} else { - lean_dec_ref(x_139); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_140, 1); -lean_inc(x_143); -lean_dec(x_140); -if (lean_is_scalar(x_142)) { - x_144 = lean_alloc_ctor(0, 2, 0); -} else { - x_144 = x_142; -} -lean_ctor_set(x_144, 0, x_143); -lean_ctor_set(x_144, 1, x_141); -return x_144; -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -lean_dec(x_140); -x_145 = lean_ctor_get(x_139, 1); -lean_inc(x_145); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_146 = x_139; -} else { - lean_dec_ref(x_139); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_145, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_145, 1); -lean_inc(x_148); -x_149 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_149, 0, x_147); -lean_ctor_set(x_149, 1, x_148); -lean_ctor_set(x_149, 2, x_10); -x_150 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_150, 0, x_1); -lean_ctor_set(x_150, 1, x_2); -lean_ctor_set(x_150, 2, x_3); -lean_ctor_set(x_150, 3, x_149); -if (lean_is_scalar(x_146)) { - x_151 = lean_alloc_ctor(1, 2, 0); -} else { - x_151 = x_146; - lean_ctor_set_tag(x_151, 1); -} -lean_ctor_set(x_151, 0, x_150); -lean_ctor_set(x_151, 1, x_145); -return x_151; -} -} -else -{ -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_152 = lean_ctor_get(x_139, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_139, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_154 = x_139; -} else { - lean_dec_ref(x_139); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -return x_155; -} -} -else -{ -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_156 = lean_ctor_get(x_136, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_136, 1); -lean_inc(x_157); -if (lean_is_exclusive(x_136)) { - lean_ctor_release(x_136, 0); - lean_ctor_release(x_136, 1); - x_158 = x_136; -} else { - lean_dec_ref(x_136); - x_158 = lean_box(0); -} -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(1, 2, 0); -} else { - x_159 = x_158; -} -lean_ctor_set(x_159, 0, x_156); -lean_ctor_set(x_159, 1, x_157); -return x_159; -} -} -else -{ -lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_160 = lean_ctor_get(x_133, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_133, 1); -lean_inc(x_161); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - x_162 = x_133; -} else { - lean_dec_ref(x_133); - x_162 = lean_box(0); -} -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(1, 2, 0); -} else { - x_163 = x_162; -} -lean_ctor_set(x_163, 0, x_160); -lean_ctor_set(x_163, 1, x_161); -return x_163; -} -} -} -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_113); -lean_dec(x_109); -lean_dec(x_108); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_164 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_164, 0, x_98); -lean_ctor_set(x_164, 1, x_99); -lean_ctor_set(x_164, 2, x_10); -x_165 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_165, 0, x_1); -lean_ctor_set(x_165, 1, x_2); -lean_ctor_set(x_165, 2, x_3); -lean_ctor_set(x_165, 3, x_164); -x_166 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_166, 0, x_165); -lean_ctor_set(x_166, 1, x_96); -return x_166; -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -lean_dec(x_107); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_167 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_167, 0, x_98); -lean_ctor_set(x_167, 1, x_99); -lean_ctor_set(x_167, 2, x_10); -x_168 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_168, 0, x_1); -lean_ctor_set(x_168, 1, x_2); -lean_ctor_set(x_168, 2, x_3); -lean_ctor_set(x_168, 3, x_167); -x_169 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_169, 0, x_168); -lean_ctor_set(x_169, 1, x_96); -return x_169; -} -} -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -lean_dec(x_100); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_170 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_170, 0, x_98); -lean_ctor_set(x_170, 1, x_99); -lean_ctor_set(x_170, 2, x_10); -x_171 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_171, 0, x_1); -lean_ctor_set(x_171, 1, x_2); -lean_ctor_set(x_171, 2, x_3); -lean_ctor_set(x_171, 3, x_170); -x_172 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_172, 0, x_171); -lean_ctor_set(x_172, 1, x_96); -return x_172; -} -} -} -else -{ -uint8_t x_173; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_173 = !lean_is_exclusive(x_16); -if (x_173 == 0) -{ -return x_16; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_16, 0); -x_175 = lean_ctor_get(x_16, 1); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_16); -x_176 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_176, 0, x_174); -lean_ctor_set(x_176, 1, x_175); -return x_176; -} -} -} -else -{ -lean_object* x_177; uint8_t x_178; uint8_t x_179; uint8_t x_180; uint8_t x_181; uint8_t x_182; lean_object* x_183; lean_object* x_184; uint8_t x_185; lean_object* x_186; -x_177 = lean_ctor_get(x_7, 0); -x_178 = lean_ctor_get_uint8(x_7, sizeof(void*)*1); -x_179 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 1); -x_180 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 2); -x_181 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 3); -lean_inc(x_177); -lean_dec(x_7); -x_182 = 1; -x_183 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_183, 0, x_177); -lean_ctor_set_uint8(x_183, sizeof(void*)*1, x_178); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 1, x_179); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 2, x_180); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 3, x_181); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 4, x_182); -lean_inc(x_10); -x_184 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_184, 0, x_183); -lean_ctor_set(x_184, 1, x_10); -lean_ctor_set(x_184, 2, x_11); -x_185 = 0; -lean_inc(x_184); -lean_inc(x_8); -x_186 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_185, x_8, x_8, x_184, x_9); -lean_dec(x_8); -if (lean_obj_tag(x_186) == 0) -{ -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; -x_187 = lean_ctor_get(x_186, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_186, 0); -lean_inc(x_188); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - x_189 = x_186; -} else { - lean_dec_ref(x_186); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_187, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_187, 1); -lean_inc(x_191); -x_192 = l_Lean_Expr_getAppFn___main(x_188); -if (lean_obj_tag(x_192) == 4) -{ -lean_object* x_193; lean_object* x_194; lean_object* x_195; -x_193 = lean_ctor_get(x_192, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_192, 1); -lean_inc(x_194); -lean_dec(x_192); -lean_inc(x_190); -x_195 = lean_environment_find(x_190, x_193); -if (lean_obj_tag(x_195) == 0) -{ -lean_object* x_196; lean_object* x_197; lean_object* x_198; -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_196 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_196, 0, x_190); -lean_ctor_set(x_196, 1, x_191); -lean_ctor_set(x_196, 2, x_10); -x_197 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_197, 0, x_1); -lean_ctor_set(x_197, 1, x_2); -lean_ctor_set(x_197, 2, x_3); -lean_ctor_set(x_197, 3, x_196); -if (lean_is_scalar(x_189)) { - x_198 = lean_alloc_ctor(1, 2, 0); -} else { - x_198 = x_189; - lean_ctor_set_tag(x_198, 1); -} -lean_ctor_set(x_198, 0, x_197); -lean_ctor_set(x_198, 1, x_187); -return x_198; -} -else -{ -lean_object* x_199; -x_199 = lean_ctor_get(x_195, 0); -lean_inc(x_199); -lean_dec(x_195); -if (lean_obj_tag(x_199) == 5) -{ -lean_object* x_200; lean_object* x_201; -x_200 = lean_ctor_get(x_199, 0); -lean_inc(x_200); -lean_dec(x_199); -x_201 = lean_ctor_get(x_200, 4); -lean_inc(x_201); -if (lean_obj_tag(x_201) == 0) -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; -lean_dec(x_200); -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_202 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_202, 0, x_190); -lean_ctor_set(x_202, 1, x_191); -lean_ctor_set(x_202, 2, x_10); -x_203 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_203, 0, x_1); -lean_ctor_set(x_203, 1, x_2); -lean_ctor_set(x_203, 2, x_3); -lean_ctor_set(x_203, 3, x_202); -if (lean_is_scalar(x_189)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_189; - lean_ctor_set_tag(x_204, 1); -} -lean_ctor_set(x_204, 0, x_203); -lean_ctor_set(x_204, 1, x_187); -return x_204; -} -else -{ -lean_object* x_205; -x_205 = lean_ctor_get(x_201, 1); -lean_inc(x_205); -if (lean_obj_tag(x_205) == 0) -{ -lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; uint8_t x_216; -x_206 = lean_ctor_get(x_200, 1); -lean_inc(x_206); -lean_dec(x_200); -x_207 = lean_ctor_get(x_201, 0); -lean_inc(x_207); -lean_dec(x_201); -x_208 = lean_unsigned_to_nat(0u); -x_209 = l_Lean_Expr_getAppNumArgsAux___main(x_188, x_208); -x_210 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_209); -x_211 = lean_mk_array(x_209, x_210); -x_212 = lean_unsigned_to_nat(1u); -x_213 = lean_nat_sub(x_209, x_212); -lean_dec(x_209); -x_214 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_188, x_211, x_213); -x_215 = lean_array_get_size(x_214); -x_216 = lean_nat_dec_eq(x_206, x_215); -lean_dec(x_215); -lean_dec(x_206); -if (x_216 == 0) -{ -lean_object* x_217; lean_object* x_218; lean_object* x_219; -lean_dec(x_214); -lean_dec(x_207); -lean_dec(x_194); -lean_dec(x_184); -lean_dec(x_4); -x_217 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_217, 0, x_190); -lean_ctor_set(x_217, 1, x_191); -lean_ctor_set(x_217, 2, x_10); -x_218 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_218, 0, x_1); -lean_ctor_set(x_218, 1, x_2); -lean_ctor_set(x_218, 2, x_3); -lean_ctor_set(x_218, 3, x_217); -if (lean_is_scalar(x_189)) { - x_219 = lean_alloc_ctor(1, 2, 0); -} else { - x_219 = x_189; - lean_ctor_set_tag(x_219, 1); -} -lean_ctor_set(x_219, 0, x_218); -lean_ctor_set(x_219, 1, x_187); -return x_219; -} -else -{ -lean_object* x_220; -lean_inc(x_207); -lean_inc(x_190); -x_220 = lean_environment_find(x_190, x_207); -if (lean_obj_tag(x_220) == 0) -{ -lean_object* x_221; lean_object* x_222; lean_object* x_223; -lean_dec(x_214); -lean_dec(x_207); -lean_dec(x_194); -lean_dec(x_184); -lean_dec(x_4); -x_221 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_221, 0, x_190); -lean_ctor_set(x_221, 1, x_191); -lean_ctor_set(x_221, 2, x_10); -x_222 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_222, 0, x_1); -lean_ctor_set(x_222, 1, x_2); -lean_ctor_set(x_222, 2, x_3); -lean_ctor_set(x_222, 3, x_221); -if (lean_is_scalar(x_189)) { - x_223 = lean_alloc_ctor(1, 2, 0); -} else { - x_223 = x_189; - lean_ctor_set_tag(x_223, 1); -} -lean_ctor_set(x_223, 0, x_222); -lean_ctor_set(x_223, 1, x_187); -return x_223; -} -else -{ -lean_object* x_224; lean_object* x_225; -lean_dec(x_220); -lean_dec(x_191); -lean_dec(x_190); -lean_dec(x_189); -x_224 = l_Lean_mkConst(x_207, x_194); -lean_inc(x_4); -x_225 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__42(x_224, x_214, x_4, x_187); -if (lean_obj_tag(x_225) == 0) -{ -lean_object* x_226; lean_object* x_227; lean_object* x_228; -x_226 = lean_ctor_get(x_225, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_225, 1); -lean_inc(x_227); -lean_dec(x_225); -lean_inc(x_3); -lean_inc_n(x_2, 2); -lean_inc(x_1); -x_228 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52(x_1, x_2, x_3, x_2, x_2, x_226, x_4, x_227); -if (lean_obj_tag(x_228) == 0) -{ -lean_object* x_229; lean_object* x_230; lean_object* x_231; -x_229 = lean_ctor_get(x_228, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_228, 1); -lean_inc(x_230); -lean_dec(x_228); -lean_inc(x_229); -x_231 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_185, x_229, x_229, x_184, x_230); -lean_dec(x_229); -if (lean_obj_tag(x_231) == 0) -{ -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 7) -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_234 = x_231; -} else { - lean_dec_ref(x_231); - x_234 = lean_box(0); -} -x_235 = lean_ctor_get(x_232, 1); -lean_inc(x_235); -lean_dec(x_232); -if (lean_is_scalar(x_234)) { - x_236 = lean_alloc_ctor(0, 2, 0); -} else { - x_236 = x_234; -} -lean_ctor_set(x_236, 0, x_235); -lean_ctor_set(x_236, 1, x_233); -return x_236; -} -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; -lean_dec(x_232); -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; -} else { - lean_dec_ref(x_231); - x_238 = lean_box(0); -} -x_239 = lean_ctor_get(x_237, 0); -lean_inc(x_239); -x_240 = lean_ctor_get(x_237, 1); -lean_inc(x_240); -x_241 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_241, 0, x_239); -lean_ctor_set(x_241, 1, x_240); -lean_ctor_set(x_241, 2, x_10); -x_242 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_242, 0, x_1); -lean_ctor_set(x_242, 1, x_2); -lean_ctor_set(x_242, 2, x_3); -lean_ctor_set(x_242, 3, x_241); -if (lean_is_scalar(x_238)) { - x_243 = lean_alloc_ctor(1, 2, 0); -} else { - x_243 = x_238; - lean_ctor_set_tag(x_243, 1); -} -lean_ctor_set(x_243, 0, x_242); -lean_ctor_set(x_243, 1, x_237); -return x_243; -} -} -else -{ -lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_244 = lean_ctor_get(x_231, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_231, 1); -lean_inc(x_245); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_246 = x_231; -} else { - lean_dec_ref(x_231); - x_246 = lean_box(0); -} -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(1, 2, 0); -} else { - x_247 = x_246; -} -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -return x_247; -} -} -else -{ -lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; -lean_dec(x_184); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_248 = lean_ctor_get(x_228, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_228, 1); -lean_inc(x_249); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - x_250 = x_228; -} else { - lean_dec_ref(x_228); - x_250 = lean_box(0); -} -if (lean_is_scalar(x_250)) { - x_251 = lean_alloc_ctor(1, 2, 0); -} else { - x_251 = x_250; -} -lean_ctor_set(x_251, 0, x_248); -lean_ctor_set(x_251, 1, x_249); -return x_251; -} -} -else -{ -lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; -lean_dec(x_184); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_252 = lean_ctor_get(x_225, 0); -lean_inc(x_252); -x_253 = lean_ctor_get(x_225, 1); -lean_inc(x_253); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_254 = x_225; -} else { - lean_dec_ref(x_225); - x_254 = lean_box(0); -} -if (lean_is_scalar(x_254)) { - x_255 = lean_alloc_ctor(1, 2, 0); -} else { - x_255 = x_254; -} -lean_ctor_set(x_255, 0, x_252); -lean_ctor_set(x_255, 1, x_253); -return x_255; -} -} -} -} -else -{ -lean_object* x_256; lean_object* x_257; lean_object* x_258; -lean_dec(x_205); -lean_dec(x_201); -lean_dec(x_200); -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_256 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_256, 0, x_190); -lean_ctor_set(x_256, 1, x_191); -lean_ctor_set(x_256, 2, x_10); -x_257 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_257, 0, x_1); -lean_ctor_set(x_257, 1, x_2); -lean_ctor_set(x_257, 2, x_3); -lean_ctor_set(x_257, 3, x_256); -if (lean_is_scalar(x_189)) { - x_258 = lean_alloc_ctor(1, 2, 0); -} else { - x_258 = x_189; - lean_ctor_set_tag(x_258, 1); -} -lean_ctor_set(x_258, 0, x_257); -lean_ctor_set(x_258, 1, x_187); -return x_258; -} -} -} -else -{ -lean_object* x_259; lean_object* x_260; lean_object* x_261; -lean_dec(x_199); -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_259 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_259, 0, x_190); -lean_ctor_set(x_259, 1, x_191); -lean_ctor_set(x_259, 2, x_10); -x_260 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_260, 0, x_1); -lean_ctor_set(x_260, 1, x_2); -lean_ctor_set(x_260, 2, x_3); -lean_ctor_set(x_260, 3, x_259); -if (lean_is_scalar(x_189)) { - x_261 = lean_alloc_ctor(1, 2, 0); -} else { - x_261 = x_189; - lean_ctor_set_tag(x_261, 1); -} -lean_ctor_set(x_261, 0, x_260); -lean_ctor_set(x_261, 1, x_187); -return x_261; -} -} -} -else -{ -lean_object* x_262; lean_object* x_263; lean_object* x_264; -lean_dec(x_192); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_262 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_262, 0, x_190); -lean_ctor_set(x_262, 1, x_191); -lean_ctor_set(x_262, 2, x_10); -x_263 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_263, 0, x_1); -lean_ctor_set(x_263, 1, x_2); -lean_ctor_set(x_263, 2, x_3); -lean_ctor_set(x_263, 3, x_262); -if (lean_is_scalar(x_189)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_189; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_263); -lean_ctor_set(x_264, 1, x_187); -return x_264; -} -} -else -{ -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; -lean_dec(x_184); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_265 = lean_ctor_get(x_186, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_186, 1); -lean_inc(x_266); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - x_267 = x_186; -} else { - lean_dec_ref(x_186); - x_267 = lean_box(0); -} -if (lean_is_scalar(x_267)) { - x_268 = lean_alloc_ctor(1, 2, 0); -} else { - x_268 = x_267; -} -lean_ctor_set(x_268, 0, x_265); -lean_ctor_set(x_268, 1, x_266); -return x_268; -} -} -} -else -{ -uint8_t x_269; -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_269 = !lean_is_exclusive(x_6); -if (x_269 == 0) -{ -return x_6; -} -else -{ -lean_object* x_270; lean_object* x_271; lean_object* x_272; -x_270 = lean_ctor_get(x_6, 0); -x_271 = lean_ctor_get(x_6, 1); -lean_inc(x_271); -lean_inc(x_270); -lean_dec(x_6); -x_272 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_272, 0, x_270); -lean_ctor_set(x_272, 1, x_271); -return x_272; -} -} -} -} -lean_object* l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -switch (lean_obj_tag(x_1)) { -case 0: -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -lean_dec(x_2); -x_55 = lean_ctor_get(x_1, 0); -lean_inc(x_55); -lean_dec(x_1); -x_56 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_56, 0, x_55); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_56); -lean_ctor_set(x_57, 1, x_3); -return x_57; -} -case 1: -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_1, 0); -lean_inc(x_58); -lean_dec(x_1); -x_59 = l___private_Init_Lean_Meta_InferType_8__inferFVarType(x_58, x_2, x_3); -return x_59; -} -case 2: -{ -lean_object* x_60; lean_object* x_61; -x_60 = lean_ctor_get(x_1, 0); -lean_inc(x_60); -lean_dec(x_1); -x_61 = l___private_Init_Lean_Meta_InferType_7__inferMVarType(x_60, x_2, x_3); -lean_dec(x_2); -return x_61; -} -case 3: -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -lean_dec(x_2); -x_62 = lean_ctor_get(x_1, 0); -lean_inc(x_62); -lean_dec(x_1); -x_63 = l_Lean_mkLevelSucc(x_62); -x_64 = l_Lean_mkSort(x_63); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_64); -lean_ctor_set(x_65, 1, x_3); -return x_65; -} -case 4: -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_1, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_1, 1); -lean_inc(x_67); -lean_dec(x_1); -x_68 = l___private_Init_Lean_Meta_InferType_2__inferConstType(x_66, x_67, x_2, x_3); -lean_dec(x_2); -return x_68; -} -case 5: -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_69 = lean_ctor_get(x_1, 0); -lean_inc(x_69); -x_70 = l_Lean_Expr_getAppFn___main(x_69); -lean_dec(x_69); -x_71 = lean_unsigned_to_nat(0u); -x_72 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_71); -x_73 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_72); -x_74 = lean_mk_array(x_72, x_73); -x_75 = lean_unsigned_to_nat(1u); -x_76 = lean_nat_sub(x_72, x_75); -lean_dec(x_72); -lean_inc(x_1); -x_77 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_74, x_76); -x_78 = lean_ctor_get(x_3, 2); -lean_inc(x_78); -x_79 = lean_ctor_get(x_78, 0); -lean_inc(x_79); -lean_dec(x_78); -x_80 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_79, x_1); -lean_dec(x_79); -if (lean_obj_tag(x_80) == 0) -{ -lean_object* x_81; -x_81 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__42(x_70, x_77, x_2, x_3); -if (lean_obj_tag(x_81) == 0) -{ -lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_82 = lean_ctor_get(x_81, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_82, 2); -lean_inc(x_83); -x_84 = !lean_is_exclusive(x_81); -if (x_84 == 0) -{ -lean_object* x_85; lean_object* x_86; uint8_t x_87; -x_85 = lean_ctor_get(x_81, 0); -x_86 = lean_ctor_get(x_81, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_82); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; -x_88 = lean_ctor_get(x_82, 2); -lean_dec(x_88); -x_89 = !lean_is_exclusive(x_83); -if (x_89 == 0) -{ -lean_object* x_90; lean_object* x_91; -x_90 = lean_ctor_get(x_83, 0); -lean_inc(x_85); -x_91 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_90, x_1, x_85); -lean_ctor_set(x_83, 0, x_91); -return x_81; -} -else -{ -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_92 = lean_ctor_get(x_83, 0); -x_93 = lean_ctor_get(x_83, 1); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_83); -lean_inc(x_85); -x_94 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_92, x_1, x_85); -x_95 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_95, 0, x_94); -lean_ctor_set(x_95, 1, x_93); -lean_ctor_set(x_82, 2, x_95); -return x_81; -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_96 = lean_ctor_get(x_82, 0); -x_97 = lean_ctor_get(x_82, 1); -x_98 = lean_ctor_get(x_82, 3); -x_99 = lean_ctor_get(x_82, 4); -x_100 = lean_ctor_get(x_82, 5); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_82); -x_101 = lean_ctor_get(x_83, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_83, 1); -lean_inc(x_102); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - x_103 = x_83; -} else { - lean_dec_ref(x_83); - x_103 = lean_box(0); -} -lean_inc(x_85); -x_104 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_101, x_1, x_85); -if (lean_is_scalar(x_103)) { - x_105 = lean_alloc_ctor(0, 2, 0); -} else { - x_105 = x_103; -} -lean_ctor_set(x_105, 0, x_104); -lean_ctor_set(x_105, 1, x_102); -x_106 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_106, 0, x_96); -lean_ctor_set(x_106, 1, x_97); -lean_ctor_set(x_106, 2, x_105); -lean_ctor_set(x_106, 3, x_98); -lean_ctor_set(x_106, 4, x_99); -lean_ctor_set(x_106, 5, x_100); -lean_ctor_set(x_81, 1, x_106); -return x_81; -} -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_107 = lean_ctor_get(x_81, 0); -lean_inc(x_107); -lean_dec(x_81); -x_108 = lean_ctor_get(x_82, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_82, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_82, 3); -lean_inc(x_110); -x_111 = lean_ctor_get(x_82, 4); -lean_inc(x_111); -x_112 = lean_ctor_get(x_82, 5); -lean_inc(x_112); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - lean_ctor_release(x_82, 2); - lean_ctor_release(x_82, 3); - lean_ctor_release(x_82, 4); - lean_ctor_release(x_82, 5); - x_113 = x_82; -} else { - lean_dec_ref(x_82); - x_113 = lean_box(0); -} -x_114 = lean_ctor_get(x_83, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_83, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - x_116 = x_83; -} else { - lean_dec_ref(x_83); - x_116 = lean_box(0); -} -lean_inc(x_107); -x_117 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_114, x_1, x_107); -if (lean_is_scalar(x_116)) { - x_118 = lean_alloc_ctor(0, 2, 0); -} else { - x_118 = x_116; -} -lean_ctor_set(x_118, 0, x_117); -lean_ctor_set(x_118, 1, x_115); -if (lean_is_scalar(x_113)) { - x_119 = lean_alloc_ctor(0, 6, 0); -} else { - x_119 = x_113; -} -lean_ctor_set(x_119, 0, x_108); -lean_ctor_set(x_119, 1, x_109); -lean_ctor_set(x_119, 2, x_118); -lean_ctor_set(x_119, 3, x_110); -lean_ctor_set(x_119, 4, x_111); -lean_ctor_set(x_119, 5, x_112); -x_120 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_120, 0, x_107); -lean_ctor_set(x_120, 1, x_119); -return x_120; -} -} -else -{ -uint8_t x_121; -lean_dec(x_1); -x_121 = !lean_is_exclusive(x_81); -if (x_121 == 0) -{ -return x_81; -} -else -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_81, 0); -x_123 = lean_ctor_get(x_81, 1); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_81); -x_124 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_124, 0, x_122); -lean_ctor_set(x_124, 1, x_123); -return x_124; -} -} -} -else -{ -lean_object* x_125; lean_object* x_126; -lean_dec(x_77); -lean_dec(x_70); -lean_dec(x_2); -lean_dec(x_1); -x_125 = lean_ctor_get(x_80, 0); -lean_inc(x_125); -lean_dec(x_80); -x_126 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_3); -return x_126; -} -} -case 7: -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; -x_127 = lean_ctor_get(x_3, 2); -lean_inc(x_127); -x_128 = lean_ctor_get(x_127, 0); -lean_inc(x_128); -lean_dec(x_127); -x_129 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_128, x_1); -lean_dec(x_128); -if (lean_obj_tag(x_129) == 0) -{ -lean_object* x_130; -lean_inc(x_1); -x_130 = l___private_Init_Lean_Meta_InferType_4__inferForallType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__44(x_1, x_2, x_3); -if (lean_obj_tag(x_130) == 0) -{ -lean_object* x_131; lean_object* x_132; uint8_t x_133; -x_131 = lean_ctor_get(x_130, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_131, 2); -lean_inc(x_132); -x_133 = !lean_is_exclusive(x_130); -if (x_133 == 0) -{ -lean_object* x_134; lean_object* x_135; uint8_t x_136; -x_134 = lean_ctor_get(x_130, 0); -x_135 = lean_ctor_get(x_130, 1); -lean_dec(x_135); -x_136 = !lean_is_exclusive(x_131); -if (x_136 == 0) -{ -lean_object* x_137; uint8_t x_138; -x_137 = lean_ctor_get(x_131, 2); -lean_dec(x_137); -x_138 = !lean_is_exclusive(x_132); -if (x_138 == 0) -{ -lean_object* x_139; lean_object* x_140; -x_139 = lean_ctor_get(x_132, 0); -lean_inc(x_134); -x_140 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_139, x_1, x_134); -lean_ctor_set(x_132, 0, x_140); -return x_130; -} -else -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; -x_141 = lean_ctor_get(x_132, 0); -x_142 = lean_ctor_get(x_132, 1); -lean_inc(x_142); -lean_inc(x_141); -lean_dec(x_132); -lean_inc(x_134); -x_143 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_141, x_1, x_134); -x_144 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_144, 0, x_143); -lean_ctor_set(x_144, 1, x_142); -lean_ctor_set(x_131, 2, x_144); -return x_130; -} -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -x_145 = lean_ctor_get(x_131, 0); -x_146 = lean_ctor_get(x_131, 1); -x_147 = lean_ctor_get(x_131, 3); -x_148 = lean_ctor_get(x_131, 4); -x_149 = lean_ctor_get(x_131, 5); -lean_inc(x_149); -lean_inc(x_148); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); -lean_dec(x_131); -x_150 = lean_ctor_get(x_132, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_132, 1); -lean_inc(x_151); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_152 = x_132; -} else { - lean_dec_ref(x_132); - x_152 = lean_box(0); -} -lean_inc(x_134); -x_153 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_150, x_1, x_134); -if (lean_is_scalar(x_152)) { - x_154 = lean_alloc_ctor(0, 2, 0); -} else { - x_154 = x_152; -} -lean_ctor_set(x_154, 0, x_153); -lean_ctor_set(x_154, 1, x_151); -x_155 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_155, 0, x_145); -lean_ctor_set(x_155, 1, x_146); -lean_ctor_set(x_155, 2, x_154); -lean_ctor_set(x_155, 3, x_147); -lean_ctor_set(x_155, 4, x_148); -lean_ctor_set(x_155, 5, x_149); -lean_ctor_set(x_130, 1, x_155); -return x_130; -} -} -else -{ -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; -x_156 = lean_ctor_get(x_130, 0); -lean_inc(x_156); -lean_dec(x_130); -x_157 = lean_ctor_get(x_131, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_131, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_131, 3); -lean_inc(x_159); -x_160 = lean_ctor_get(x_131, 4); -lean_inc(x_160); -x_161 = lean_ctor_get(x_131, 5); -lean_inc(x_161); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - lean_ctor_release(x_131, 3); - lean_ctor_release(x_131, 4); - lean_ctor_release(x_131, 5); - x_162 = x_131; -} else { - lean_dec_ref(x_131); - x_162 = lean_box(0); -} -x_163 = lean_ctor_get(x_132, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_132, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_165 = x_132; -} else { - lean_dec_ref(x_132); - x_165 = lean_box(0); -} -lean_inc(x_156); -x_166 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_163, x_1, x_156); -if (lean_is_scalar(x_165)) { - x_167 = lean_alloc_ctor(0, 2, 0); -} else { - x_167 = x_165; -} -lean_ctor_set(x_167, 0, x_166); -lean_ctor_set(x_167, 1, x_164); -if (lean_is_scalar(x_162)) { - x_168 = lean_alloc_ctor(0, 6, 0); -} else { - x_168 = x_162; -} -lean_ctor_set(x_168, 0, x_157); -lean_ctor_set(x_168, 1, x_158); -lean_ctor_set(x_168, 2, x_167); -lean_ctor_set(x_168, 3, x_159); -lean_ctor_set(x_168, 4, x_160); -lean_ctor_set(x_168, 5, x_161); -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_156); -lean_ctor_set(x_169, 1, x_168); -return x_169; -} -} -else -{ -uint8_t x_170; -lean_dec(x_1); -x_170 = !lean_is_exclusive(x_130); -if (x_170 == 0) -{ -return x_130; -} -else -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_130, 0); -x_172 = lean_ctor_get(x_130, 1); -lean_inc(x_172); -lean_inc(x_171); -lean_dec(x_130); -x_173 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_173, 0, x_171); -lean_ctor_set(x_173, 1, x_172); -return x_173; -} -} -} -else -{ -lean_object* x_174; lean_object* x_175; -lean_dec(x_2); -lean_dec(x_1); -x_174 = lean_ctor_get(x_129, 0); -lean_inc(x_174); -lean_dec(x_129); -x_175 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_175, 0, x_174); -lean_ctor_set(x_175, 1, x_3); -return x_175; -} -} -case 9: -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; -lean_dec(x_2); -x_176 = lean_ctor_get(x_1, 0); -lean_inc(x_176); -lean_dec(x_1); -x_177 = l_Lean_Literal_type(x_176); -lean_dec(x_176); -x_178 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_178, 0, x_177); -lean_ctor_set(x_178, 1, x_3); -return x_178; -} -case 10: -{ -lean_object* x_179; -x_179 = lean_ctor_get(x_1, 1); -lean_inc(x_179); -lean_dec(x_1); -x_1 = x_179; -goto _start; -} -case 11: -{ -lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; -x_181 = lean_ctor_get(x_1, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_1, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_1, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_3, 2); -lean_inc(x_184); -x_185 = lean_ctor_get(x_184, 0); -lean_inc(x_185); -lean_dec(x_184); -x_186 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_185, x_1); -lean_dec(x_185); -if (lean_obj_tag(x_186) == 0) -{ -lean_object* x_187; -x_187 = l___private_Init_Lean_Meta_InferType_3__inferProjType___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__51(x_181, x_182, x_183, x_2, x_3); -if (lean_obj_tag(x_187) == 0) -{ -lean_object* x_188; lean_object* x_189; uint8_t x_190; -x_188 = lean_ctor_get(x_187, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_188, 2); -lean_inc(x_189); -x_190 = !lean_is_exclusive(x_187); -if (x_190 == 0) -{ -lean_object* x_191; lean_object* x_192; uint8_t x_193; -x_191 = lean_ctor_get(x_187, 0); -x_192 = lean_ctor_get(x_187, 1); -lean_dec(x_192); -x_193 = !lean_is_exclusive(x_188); -if (x_193 == 0) -{ -lean_object* x_194; uint8_t x_195; -x_194 = lean_ctor_get(x_188, 2); -lean_dec(x_194); -x_195 = !lean_is_exclusive(x_189); -if (x_195 == 0) -{ -lean_object* x_196; lean_object* x_197; -x_196 = lean_ctor_get(x_189, 0); -lean_inc(x_191); -x_197 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_196, x_1, x_191); -lean_ctor_set(x_189, 0, x_197); -return x_187; -} -else -{ -lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; -x_198 = lean_ctor_get(x_189, 0); -x_199 = lean_ctor_get(x_189, 1); -lean_inc(x_199); -lean_inc(x_198); -lean_dec(x_189); -lean_inc(x_191); -x_200 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_198, x_1, x_191); -x_201 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_201, 0, x_200); -lean_ctor_set(x_201, 1, x_199); -lean_ctor_set(x_188, 2, x_201); -return x_187; -} -} -else -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; -x_202 = lean_ctor_get(x_188, 0); -x_203 = lean_ctor_get(x_188, 1); -x_204 = lean_ctor_get(x_188, 3); -x_205 = lean_ctor_get(x_188, 4); -x_206 = lean_ctor_get(x_188, 5); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_202); -lean_dec(x_188); -x_207 = lean_ctor_get(x_189, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_189, 1); -lean_inc(x_208); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - x_209 = x_189; -} else { - lean_dec_ref(x_189); - x_209 = lean_box(0); -} -lean_inc(x_191); -x_210 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_207, x_1, x_191); -if (lean_is_scalar(x_209)) { - x_211 = lean_alloc_ctor(0, 2, 0); -} else { - x_211 = x_209; -} -lean_ctor_set(x_211, 0, x_210); -lean_ctor_set(x_211, 1, x_208); -x_212 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_212, 0, x_202); -lean_ctor_set(x_212, 1, x_203); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_204); -lean_ctor_set(x_212, 4, x_205); -lean_ctor_set(x_212, 5, x_206); -lean_ctor_set(x_187, 1, x_212); -return x_187; -} -} -else -{ -lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_213 = lean_ctor_get(x_187, 0); -lean_inc(x_213); -lean_dec(x_187); -x_214 = lean_ctor_get(x_188, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_188, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_188, 3); -lean_inc(x_216); -x_217 = lean_ctor_get(x_188, 4); -lean_inc(x_217); -x_218 = lean_ctor_get(x_188, 5); -lean_inc(x_218); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - lean_ctor_release(x_188, 3); - lean_ctor_release(x_188, 4); - lean_ctor_release(x_188, 5); - x_219 = x_188; -} else { - lean_dec_ref(x_188); - x_219 = lean_box(0); -} -x_220 = lean_ctor_get(x_189, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_189, 1); -lean_inc(x_221); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - x_222 = x_189; -} else { - lean_dec_ref(x_189); - x_222 = lean_box(0); -} -lean_inc(x_213); -x_223 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_220, x_1, x_213); -if (lean_is_scalar(x_222)) { - x_224 = lean_alloc_ctor(0, 2, 0); -} else { - x_224 = x_222; -} -lean_ctor_set(x_224, 0, x_223); -lean_ctor_set(x_224, 1, x_221); -if (lean_is_scalar(x_219)) { - x_225 = lean_alloc_ctor(0, 6, 0); -} else { - x_225 = x_219; -} -lean_ctor_set(x_225, 0, x_214); -lean_ctor_set(x_225, 1, x_215); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_216); -lean_ctor_set(x_225, 4, x_217); -lean_ctor_set(x_225, 5, x_218); -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_213); -lean_ctor_set(x_226, 1, x_225); -return x_226; -} -} -else -{ -uint8_t x_227; -lean_dec(x_1); -x_227 = !lean_is_exclusive(x_187); -if (x_227 == 0) -{ -return x_187; -} -else -{ -lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_228 = lean_ctor_get(x_187, 0); -x_229 = lean_ctor_get(x_187, 1); -lean_inc(x_229); -lean_inc(x_228); -lean_dec(x_187); -x_230 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_230, 0, x_228); -lean_ctor_set(x_230, 1, x_229); -return x_230; -} -} -} -else -{ -lean_object* x_231; lean_object* x_232; -lean_dec(x_183); -lean_dec(x_182); -lean_dec(x_181); -lean_dec(x_2); -lean_dec(x_1); -x_231 = lean_ctor_get(x_186, 0); -lean_inc(x_231); -lean_dec(x_186); -x_232 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_232, 0, x_231); -lean_ctor_set(x_232, 1, x_3); -return x_232; -} -} -case 12: -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -lean_dec(x_1); -x_233 = l_Lean_Meta_isClassQuick___main___closed__1; -x_234 = l_unreachable_x21___rarg(x_233); -x_235 = lean_apply_2(x_234, x_2, x_3); -return x_235; -} -default: -{ -lean_object* x_236; -x_236 = lean_box(0); -x_4 = x_236; -goto block_54; -} -} -block_54: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; -lean_dec(x_4); -x_5 = lean_ctor_get(x_3, 2); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 0); -lean_inc(x_6); -lean_dec(x_5); -x_7 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_6, x_1); -lean_dec(x_6); -if (lean_obj_tag(x_7) == 0) -{ -lean_object* x_8; -lean_inc(x_1); -x_8 = l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__32(x_1, x_2, x_3); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 1); -lean_inc(x_9); -x_10 = lean_ctor_get(x_9, 2); -lean_inc(x_10); -x_11 = !lean_is_exclusive(x_8); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_12 = lean_ctor_get(x_8, 0); -x_13 = lean_ctor_get(x_8, 1); -lean_dec(x_13); -x_14 = !lean_is_exclusive(x_9); -if (x_14 == 0) -{ -lean_object* x_15; uint8_t x_16; -x_15 = lean_ctor_get(x_9, 2); -lean_dec(x_15); -x_16 = !lean_is_exclusive(x_10); -if (x_16 == 0) -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_ctor_get(x_10, 0); -lean_inc(x_12); -x_18 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_17, x_1, x_12); -lean_ctor_set(x_10, 0, x_18); -return x_8; -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_10, 0); -x_20 = lean_ctor_get(x_10, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_10); -lean_inc(x_12); -x_21 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_19, x_1, x_12); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_20); -lean_ctor_set(x_9, 2, x_22); -return x_8; -} -} -else -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_23 = lean_ctor_get(x_9, 0); -x_24 = lean_ctor_get(x_9, 1); -x_25 = lean_ctor_get(x_9, 3); -x_26 = lean_ctor_get(x_9, 4); -x_27 = lean_ctor_get(x_9, 5); -lean_inc(x_27); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_9); -x_28 = lean_ctor_get(x_10, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_10, 1); -lean_inc(x_29); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_30 = x_10; -} else { - lean_dec_ref(x_10); - x_30 = lean_box(0); -} -lean_inc(x_12); -x_31 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_28, x_1, x_12); -if (lean_is_scalar(x_30)) { - x_32 = lean_alloc_ctor(0, 2, 0); -} else { - x_32 = x_30; -} -lean_ctor_set(x_32, 0, x_31); -lean_ctor_set(x_32, 1, x_29); -x_33 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_33, 0, x_23); -lean_ctor_set(x_33, 1, x_24); -lean_ctor_set(x_33, 2, x_32); -lean_ctor_set(x_33, 3, x_25); -lean_ctor_set(x_33, 4, x_26); -lean_ctor_set(x_33, 5, x_27); -lean_ctor_set(x_8, 1, x_33); -return x_8; -} -} -else -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_34 = lean_ctor_get(x_8, 0); -lean_inc(x_34); -lean_dec(x_8); -x_35 = lean_ctor_get(x_9, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_9, 1); -lean_inc(x_36); -x_37 = lean_ctor_get(x_9, 3); -lean_inc(x_37); -x_38 = lean_ctor_get(x_9, 4); -lean_inc(x_38); -x_39 = lean_ctor_get(x_9, 5); -lean_inc(x_39); -if (lean_is_exclusive(x_9)) { - lean_ctor_release(x_9, 0); - lean_ctor_release(x_9, 1); - lean_ctor_release(x_9, 2); - lean_ctor_release(x_9, 3); - lean_ctor_release(x_9, 4); - lean_ctor_release(x_9, 5); - x_40 = x_9; -} else { - lean_dec_ref(x_9); - x_40 = lean_box(0); -} -x_41 = lean_ctor_get(x_10, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_10, 1); -lean_inc(x_42); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_43 = x_10; -} else { - lean_dec_ref(x_10); - x_43 = lean_box(0); -} -lean_inc(x_34); -x_44 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_41, x_1, x_34); -if (lean_is_scalar(x_43)) { - x_45 = lean_alloc_ctor(0, 2, 0); -} else { - x_45 = x_43; -} -lean_ctor_set(x_45, 0, x_44); -lean_ctor_set(x_45, 1, x_42); -if (lean_is_scalar(x_40)) { - x_46 = lean_alloc_ctor(0, 6, 0); -} else { - x_46 = x_40; -} -lean_ctor_set(x_46, 0, x_35); -lean_ctor_set(x_46, 1, x_36); -lean_ctor_set(x_46, 2, x_45); -lean_ctor_set(x_46, 3, x_37); -lean_ctor_set(x_46, 4, x_38); -lean_ctor_set(x_46, 5, x_39); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_34); -lean_ctor_set(x_47, 1, x_46); -return x_47; -} -} -else -{ -uint8_t x_48; -lean_dec(x_1); -x_48 = !lean_is_exclusive(x_8); -if (x_48 == 0) -{ -return x_8; -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_8, 0); -x_50 = lean_ctor_get(x_8, 1); -lean_inc(x_50); -lean_inc(x_49); -lean_dec(x_8); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_49); -lean_ctor_set(x_51, 1, x_50); -return x_51; -} -} -} -else -{ -lean_object* x_52; lean_object* x_53; -lean_dec(x_2); -lean_dec(x_1); -x_52 = lean_ctor_get(x_7, 0); -lean_inc(x_52); -lean_dec(x_7); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_3); -return x_53; -} -} -} -} -lean_object* _init_l___private_Init_Lean_Meta_3__auxFixpoint___main___closed__1() { -_start: -{ -uint8_t x_1; lean_object* x_2; -x_1 = 0; -x_2 = l___private_Init_Lean_Meta_2__boolToExpr(x_1); -return x_2; -} -} -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint___main(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = lean_box(x_1); -switch (lean_obj_tag(x_6)) { -case 0: -{ -lean_object* x_7; -x_7 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__29(x_2, x_4, x_5); -return x_7; -} -case 1: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_inferTypeAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__30(x_2, x_4, x_5); -return x_8; -} -default: -{ -lean_object* x_9; lean_object* x_10; -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_2); -x_9 = l___private_Init_Lean_Meta_3__auxFixpoint___main___closed__1; -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_5); -return x_10; -} -} -} -} -lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_3); -lean_dec(x_2); -return x_9; -} -} -lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -return x_9; -} -} -lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__7(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_3); -return x_6; -} -} -lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__9___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -uint8_t x_5; lean_object* x_6; -x_5 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__9(x_1, x_2, x_3, x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_6 = lean_box(x_5); -return x_6; -} -} -lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__10___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -uint8_t x_6; lean_object* x_7; -x_6 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__10(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_7 = lean_box(x_6); -return x_7; -} -} -lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_reduceRec___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -return x_9; -} -} -lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__11___lambda__1(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_3); -return x_6; -} -} -lean_object* l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_ReaderT_pure___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__12___rarg(x_1, x_2, x_3); -lean_dec(x_2); -return x_4; -} -} -lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__20___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__20(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__21___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_isRecStuck___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__21(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__38___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__38(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_2); -lean_dec(x_2); -x_11 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___lambda__2(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_1); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_1); -lean_dec(x_1); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -return x_14; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__40___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__40(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -uint8_t x_9; lean_object* x_10; -x_9 = lean_unbox(x_1); -lean_dec(x_1); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__37(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__41___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__41(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -return x_7; -} -} -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__43___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__43(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_3); -return x_8; -} -} -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__46(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_2); -lean_dec(x_1); -return x_8; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__48___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__48(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); -lean_dec(x_1); -return x_8; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_4); -lean_dec(x_4); -x_11 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___lambda__1(x_1, x_2, x_3, x_10, x_5, x_6, x_7, x_8, x_9); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_1); -lean_dec(x_1); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__49(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -return x_14; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__50___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__50(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); -lean_dec(x_1); -return x_8; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__47___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -uint8_t x_9; lean_object* x_10; -x_9 = lean_unbox(x_1); -lean_dec(x_1); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__47(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__52(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -return x_9; -} -} -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -uint8_t x_6; lean_object* x_7; -x_6 = lean_unbox(x_1); -lean_dec(x_1); -x_7 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_6, x_2, x_3, x_4, x_5); -lean_dec(x_3); -return x_7; -} -} -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_1, x_2, x_3, x_4, x_5); -return x_6; -} -} -lean_object* l___private_Init_Lean_Meta_3__auxFixpoint___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -uint8_t x_6; lean_object* x_7; -x_6 = lean_unbox(x_1); -lean_dec(x_1); -x_7 = l___private_Init_Lean_Meta_3__auxFixpoint(x_6, x_2, x_3, x_4, x_5); -lean_dec(x_3); -return x_7; -} -} -lean_object* l_Lean_Meta_whnf(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -uint8_t x_4; lean_object* x_5; -x_4 = 0; -lean_inc(x_1); -x_5 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_4, x_1, x_1, x_2, x_3); -lean_dec(x_1); -return x_5; -} -} -lean_object* l_Lean_Meta_inferType(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -uint8_t x_4; lean_object* x_5; -x_4 = 1; -lean_inc(x_1); -x_5 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_4, x_1, x_1, x_2, x_3); -lean_dec(x_1); -return x_5; -} -} -lean_object* l_Lean_Meta_isDefEq(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -uint8_t x_5; lean_object* x_6; -x_5 = 2; -x_6 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_1, x_2, x_3, x_4); -if (lean_obj_tag(x_6) == 0) -{ -uint8_t x_7; -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -lean_object* x_8; uint8_t x_9; lean_object* x_10; -x_8 = lean_ctor_get(x_6, 0); -x_9 = l___private_Init_Lean_Meta_1__exprToBool(x_8); -lean_dec(x_8); -x_10 = lean_box(x_9); -lean_ctor_set(x_6, 0, x_10); -return x_6; -} -else -{ -lean_object* x_11; lean_object* x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; -x_11 = lean_ctor_get(x_6, 0); -x_12 = lean_ctor_get(x_6, 1); -lean_inc(x_12); -lean_inc(x_11); -lean_dec(x_6); -x_13 = l___private_Init_Lean_Meta_1__exprToBool(x_11); -lean_dec(x_11); -x_14 = lean_box(x_13); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_12); -return x_15; -} -} -else -{ -uint8_t x_16; -x_16 = !lean_is_exclusive(x_6); -if (x_16 == 0) -{ -return x_6; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_6, 0); -x_18 = lean_ctor_get(x_6, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_6); -x_19 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_18); -return x_19; -} -} -} -} -lean_object* l_Lean_Meta_isDefEq___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Meta_isDefEq(x_1, x_2, x_3, x_4); -lean_dec(x_2); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__10(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_array_get_size(x_2); -x_7 = lean_nat_dec_lt(x_3, x_6); -lean_dec(x_6); -if (x_7 == 0) -{ -lean_object* x_8; -lean_dec(x_4); -lean_dec(x_3); -x_8 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_8) == 4) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -lean_dec(x_8); -x_10 = lean_ctor_get(x_5, 0); -lean_inc(x_10); -lean_inc(x_9); -x_11 = lean_is_class(x_10, x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -lean_dec(x_9); -x_12 = lean_box(0); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_5); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_14, 0, x_9); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_5); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_8); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_5); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_array_fget(x_2, x_3); -lean_inc(x_4); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_LocalDecl_type(x_20); -lean_dec(x_20); -lean_inc(x_4); -lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -switch (lean_obj_tag(x_24)) { -case 0: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_18); -x_25 = lean_ctor_get(x_23, 1); -lean_inc(x_25); -lean_dec(x_23); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_3, x_26); -lean_dec(x_3); -x_3 = x_27; -x_5 = x_25; -goto _start; -} -case 1: -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); -lean_dec(x_3); -x_33 = !lean_is_exclusive(x_4); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_4, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_18); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_4, 2, x_36); -x_3 = x_32; -x_5 = x_29; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_4, 0); -x_39 = lean_ctor_get(x_4, 1); -x_40 = lean_ctor_get(x_4, 2); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_dec(x_4); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_30); -lean_ctor_set(x_41, 1, x_18); -x_42 = lean_array_push(x_40, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_39); -lean_ctor_set(x_43, 2, x_42); -x_3 = x_32; -x_4 = x_43; -x_5 = x_29; -goto _start; -} -} -default: -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_ctor_get(x_23, 1); -lean_inc(x_45); -lean_dec(x_23); -lean_inc(x_4); -x_46 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_22, x_4, x_45); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_18); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_3, x_49); -lean_dec(x_3); -x_3 = x_50; -x_5 = x_48; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_ctor_get(x_47, 0); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_3, x_54); -lean_dec(x_3); -x_56 = !lean_is_exclusive(x_4); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_4, 2); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_18); -x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_4, 2, x_59); -x_3 = x_55; -x_5 = x_52; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_4, 0); -x_62 = lean_ctor_get(x_4, 1); -x_63 = lean_ctor_get(x_4, 2); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_4); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_53); -lean_ctor_set(x_64, 1, x_18); -x_65 = lean_array_push(x_63, x_64); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_62); -lean_ctor_set(x_66, 2, x_65); -x_3 = x_55; -x_4 = x_66; -x_5 = x_52; -goto _start; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_68 = !lean_is_exclusive(x_46); -if (x_68 == 0) -{ -return x_46; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_46, 0); -x_70 = lean_ctor_get(x_46, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_46); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_72 = !lean_is_exclusive(x_23); -if (x_72 == 0) -{ -return x_23; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_23, 0); -x_74 = lean_ctor_get(x_23, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_23); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -uint8_t x_76; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_76 = !lean_is_exclusive(x_19); -if (x_76 == 0) -{ -return x_19; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_19, 0); -x_78 = lean_ctor_get(x_19, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_19); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___lambda__1(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; -x_10 = l_Lean_Expr_isForall(x_7); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -x_11 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_11) == 4) -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -lean_dec(x_11); -x_13 = lean_ctor_get(x_9, 0); -lean_inc(x_13); -lean_inc(x_12); -x_14 = lean_is_class(x_13, x_12); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; -lean_dec(x_12); -x_15 = lean_box(0); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_9); -return x_16; -} -else -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_17, 0, x_12); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_9); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; -lean_dec(x_11); -x_19 = lean_box(0); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_19); -lean_ctor_set(x_20, 1, x_9); -return x_20; -} -} -else -{ -lean_object* x_21; -x_21 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9(x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_21; -} -} -} -lean_object* _init_l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1() { -_start: -{ -lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 0); -return x_1; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_13 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1; -lean_inc(x_8); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_13); -lean_closure_set(x_14, 1, x_8); -x_15 = lean_box(x_1); -lean_inc(x_7); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_8); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___lambda__1___boxed), 9, 6); -lean_closure_set(x_16, 0, x_8); -lean_closure_set(x_16, 1, x_15); -lean_closure_set(x_16, 2, x_2); -lean_closure_set(x_16, 3, x_3); -lean_closure_set(x_16, 4, x_4); -lean_closure_set(x_16, 5, x_7); -x_17 = lean_array_get_size(x_9); -x_18 = lean_nat_dec_lt(x_10, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_11, x_12); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_9, x_10); -lean_inc(x_11); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_11, x_12); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_11); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_11, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_10, x_28); -lean_dec(x_10); -x_10 = x_29; -x_12 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_10, x_33); -lean_dec(x_10); -x_35 = !lean_is_exclusive(x_11); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_11, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_11, 2, x_38); -x_10 = x_34; -x_12 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_11, 0); -x_41 = lean_ctor_get(x_11, 1); -x_42 = lean_ctor_get(x_11, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_11); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_10 = x_34; -x_11 = x_45; -x_12 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_11); -x_48 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_24, x_11, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_10, x_51); -lean_dec(x_10); -x_10 = x_52; -x_12 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_10, x_56); -lean_dec(x_10); -x_58 = !lean_is_exclusive(x_11); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_11, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_11, 2, x_61); -x_10 = x_57; -x_12 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_11, 0); -x_64 = lean_ctor_get(x_11, 1); -x_65 = lean_ctor_get(x_11, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_11); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_10 = x_57; -x_11 = x_68; -x_12 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__12(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_array_get_size(x_2); -x_7 = lean_nat_dec_lt(x_3, x_6); -lean_dec(x_6); -if (x_7 == 0) -{ -lean_object* x_8; -lean_dec(x_4); -lean_dec(x_3); -x_8 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_8) == 4) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -lean_dec(x_8); -x_10 = lean_ctor_get(x_5, 0); -lean_inc(x_10); -lean_inc(x_9); -x_11 = lean_is_class(x_10, x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -lean_dec(x_9); -x_12 = lean_box(0); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_5); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_14, 0, x_9); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_5); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_8); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_5); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_array_fget(x_2, x_3); -lean_inc(x_4); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_LocalDecl_type(x_20); -lean_dec(x_20); -lean_inc(x_4); -lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -switch (lean_obj_tag(x_24)) { -case 0: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_18); -x_25 = lean_ctor_get(x_23, 1); -lean_inc(x_25); -lean_dec(x_23); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_3, x_26); -lean_dec(x_3); -x_3 = x_27; -x_5 = x_25; -goto _start; -} -case 1: -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); -lean_dec(x_3); -x_33 = !lean_is_exclusive(x_4); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_4, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_18); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_4, 2, x_36); -x_3 = x_32; -x_5 = x_29; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_4, 0); -x_39 = lean_ctor_get(x_4, 1); -x_40 = lean_ctor_get(x_4, 2); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_dec(x_4); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_30); -lean_ctor_set(x_41, 1, x_18); -x_42 = lean_array_push(x_40, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_39); -lean_ctor_set(x_43, 2, x_42); -x_3 = x_32; -x_4 = x_43; -x_5 = x_29; -goto _start; -} -} -default: -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_ctor_get(x_23, 1); -lean_inc(x_45); -lean_dec(x_23); -lean_inc(x_4); -x_46 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_22, x_4, x_45); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_18); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_3, x_49); -lean_dec(x_3); -x_3 = x_50; -x_5 = x_48; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_ctor_get(x_47, 0); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_3, x_54); -lean_dec(x_3); -x_56 = !lean_is_exclusive(x_4); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_4, 2); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_18); -x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_4, 2, x_59); -x_3 = x_55; -x_5 = x_52; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_4, 0); -x_62 = lean_ctor_get(x_4, 1); -x_63 = lean_ctor_get(x_4, 2); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_4); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_53); -lean_ctor_set(x_64, 1, x_18); -x_65 = lean_array_push(x_63, x_64); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_62); -lean_ctor_set(x_66, 2, x_65); -x_3 = x_55; -x_4 = x_66; -x_5 = x_52; -goto _start; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_68 = !lean_is_exclusive(x_46); -if (x_68 == 0) -{ -return x_46; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_46, 0); -x_70 = lean_ctor_get(x_46, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_46); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_72 = !lean_is_exclusive(x_23); -if (x_72 == 0) -{ -return x_23; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_23, 0); -x_74 = lean_ctor_get(x_23, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_23); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -uint8_t x_76; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_76 = !lean_is_exclusive(x_19); -if (x_76 == 0) -{ -return x_19; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_19, 0); -x_78 = lean_ctor_get(x_19, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_19); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_22 = lean_ctor_get(x_6, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_6, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 2); -lean_inc(x_24); -x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); -lean_dec(x_6); -x_26 = lean_array_get_size(x_4); -lean_inc(x_4); -x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); -lean_dec(x_26); -lean_dec(x_23); -x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = (uint8_t)((x_25 << 24) >> 61); -lean_inc(x_29); -x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); -x_33 = l_Lean_mkFVar(x_29); -x_34 = lean_array_push(x_4, x_33); -if (lean_obj_tag(x_2) == 0) -{ -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -else -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_2, 0); -lean_inc(x_36); -x_37 = lean_array_get_size(x_34); -x_38 = lean_nat_dec_lt(x_37, x_36); -lean_dec(x_36); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -lean_dec(x_2); -lean_inc(x_34); -x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); -lean_dec(x_37); -lean_dec(x_24); -x_40 = !lean_is_exclusive(x_7); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_7, 1); -lean_dec(x_41); -lean_ctor_set(x_7, 1, x_32); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__12(x_39, x_34, x_5, x_7, x_30); -lean_dec(x_34); -lean_dec(x_39); -return x_42; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_7, 0); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_32); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__12(x_39, x_34, x_5, x_45, x_30); -lean_dec(x_34); -lean_dec(x_39); -return x_46; -} -} -else -{ -lean_dec(x_37); -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -} -} -else -{ -lean_object* x_48; -x_48 = lean_box(0); -x_9 = x_48; -goto block_21; -} -block_21: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_7, 1); -lean_dec(x_13); -lean_inc(x_3); -lean_ctor_set(x_7, 1, x_3); -if (x_1 == 0) -{ -lean_object* x_14; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__10(x_11, x_4, x_5, x_7, x_8); -lean_dec(x_4); -lean_dec(x_11); -return x_14; -} -else -{ -lean_object* x_15; -lean_inc(x_5); -lean_inc(x_4); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_7, 0); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_7); -lean_inc(x_3); -x_18 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_3); -lean_ctor_set(x_18, 2, x_17); -if (x_1 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__10(x_11, x_4, x_5, x_18, x_8); -lean_dec(x_4); -lean_dec(x_11); -return x_19; -} -else -{ -lean_object* x_20; -lean_inc(x_5); -lean_inc(x_4); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_20; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isProp___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; -x_5 = lean_ctor_get(x_3, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_3, 1); -lean_inc(x_6); -x_7 = lean_ctor_get(x_3, 2); -lean_inc(x_7); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -uint8_t x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; -x_9 = 1; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 4, x_9); -lean_inc(x_6); -x_10 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_10, 0, x_5); -lean_ctor_set(x_10, 1, x_6); -lean_ctor_set(x_10, 2, x_7); -x_11 = 0; -lean_inc(x_1); -x_12 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_11, x_1, x_1, x_10, x_4); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; uint8_t x_16; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_ctor_get(x_12, 1); -x_16 = l_Lean_Expr_isForall(x_14); -if (x_16 == 0) -{ -lean_object* x_17; -lean_dec(x_14); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_17 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_17) == 4) -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -lean_dec(x_17); -x_19 = lean_ctor_get(x_15, 0); -lean_inc(x_19); -lean_inc(x_18); -x_20 = lean_is_class(x_19, x_18); -if (x_20 == 0) -{ -lean_object* x_21; -lean_dec(x_18); -x_21 = lean_box(0); -lean_ctor_set(x_12, 0, x_21); -return x_12; -} -else -{ -lean_object* x_22; -x_22 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_22, 0, x_18); -lean_ctor_set(x_12, 0, x_22); -return x_12; -} -} -else -{ -lean_object* x_23; -lean_dec(x_17); -x_23 = lean_box(0); -lean_ctor_set(x_12, 0, x_23); -return x_12; -} -} -else -{ -lean_object* x_24; uint8_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_free_object(x_12); -lean_dec(x_1); -x_24 = lean_ctor_get(x_15, 2); -lean_inc(x_24); -x_25 = 1; -x_26 = l_Array_empty___closed__1; -x_27 = lean_unsigned_to_nat(0u); -x_28 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9(x_25, x_2, x_6, x_26, x_27, x_14, x_3, x_15); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_28); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_28, 1); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = lean_ctor_get(x_30, 2); -lean_dec(x_32); -lean_ctor_set(x_30, 2, x_24); -return x_28; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_33 = lean_ctor_get(x_30, 0); -x_34 = lean_ctor_get(x_30, 1); -x_35 = lean_ctor_get(x_30, 3); -x_36 = lean_ctor_get(x_30, 4); -x_37 = lean_ctor_get(x_30, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_30); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_34); -lean_ctor_set(x_38, 2, x_24); -lean_ctor_set(x_38, 3, x_35); -lean_ctor_set(x_38, 4, x_36); -lean_ctor_set(x_38, 5, x_37); -lean_ctor_set(x_28, 1, x_38); -return x_28; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_39 = lean_ctor_get(x_28, 1); -x_40 = lean_ctor_get(x_28, 0); -lean_inc(x_39); -lean_inc(x_40); -lean_dec(x_28); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_39, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_39, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_46 = x_39; -} else { - lean_dec_ref(x_39); - x_46 = lean_box(0); -} -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_46; -} -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); -lean_ctor_set(x_47, 2, x_24); -lean_ctor_set(x_47, 3, x_43); -lean_ctor_set(x_47, 4, x_44); -lean_ctor_set(x_47, 5, x_45); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_40); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -else -{ -uint8_t x_49; -x_49 = !lean_is_exclusive(x_28); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_28, 1); -x_51 = !lean_is_exclusive(x_50); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_50, 2); -lean_dec(x_52); -lean_ctor_set(x_50, 2, x_24); -return x_28; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_53 = lean_ctor_get(x_50, 0); -x_54 = lean_ctor_get(x_50, 1); -x_55 = lean_ctor_get(x_50, 3); -x_56 = lean_ctor_get(x_50, 4); -x_57 = lean_ctor_get(x_50, 5); -lean_inc(x_57); -lean_inc(x_56); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_50); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_54); -lean_ctor_set(x_58, 2, x_24); -lean_ctor_set(x_58, 3, x_55); -lean_ctor_set(x_58, 4, x_56); -lean_ctor_set(x_58, 5, x_57); -lean_ctor_set(x_28, 1, x_58); -return x_28; -} -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_59 = lean_ctor_get(x_28, 1); -x_60 = lean_ctor_get(x_28, 0); -lean_inc(x_59); -lean_inc(x_60); -lean_dec(x_28); -x_61 = lean_ctor_get(x_59, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_59, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_59, 3); -lean_inc(x_63); -x_64 = lean_ctor_get(x_59, 4); -lean_inc(x_64); -x_65 = lean_ctor_get(x_59, 5); -lean_inc(x_65); -if (lean_is_exclusive(x_59)) { - lean_ctor_release(x_59, 0); - lean_ctor_release(x_59, 1); - lean_ctor_release(x_59, 2); - lean_ctor_release(x_59, 3); - lean_ctor_release(x_59, 4); - lean_ctor_release(x_59, 5); - x_66 = x_59; -} else { - lean_dec_ref(x_59); - x_66 = lean_box(0); -} -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 6, 0); -} else { - x_67 = x_66; -} -lean_ctor_set(x_67, 0, x_61); -lean_ctor_set(x_67, 1, x_62); -lean_ctor_set(x_67, 2, x_24); -lean_ctor_set(x_67, 3, x_63); -lean_ctor_set(x_67, 4, x_64); -lean_ctor_set(x_67, 5, x_65); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_60); -lean_ctor_set(x_68, 1, x_67); -return x_68; -} -} -} -} -else -{ -lean_object* x_69; lean_object* x_70; uint8_t x_71; -x_69 = lean_ctor_get(x_12, 0); -x_70 = lean_ctor_get(x_12, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_12); -x_71 = l_Lean_Expr_isForall(x_69); -if (x_71 == 0) -{ -lean_object* x_72; -lean_dec(x_69); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_72 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_72) == 4) -{ -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -lean_dec(x_72); -x_74 = lean_ctor_get(x_70, 0); -lean_inc(x_74); -lean_inc(x_73); -x_75 = lean_is_class(x_74, x_73); -if (x_75 == 0) -{ -lean_object* x_76; lean_object* x_77; -lean_dec(x_73); -x_76 = lean_box(0); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_70); -return x_77; -} -else -{ -lean_object* x_78; lean_object* x_79; -x_78 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_78, 0, x_73); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_70); -return x_79; -} -} -else -{ -lean_object* x_80; lean_object* x_81; -lean_dec(x_72); -x_80 = lean_box(0); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_70); -return x_81; -} -} -else -{ -lean_object* x_82; uint8_t x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_1); -x_82 = lean_ctor_get(x_70, 2); -lean_inc(x_82); -x_83 = 1; -x_84 = l_Array_empty___closed__1; -x_85 = lean_unsigned_to_nat(0u); -x_86 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9(x_83, x_2, x_6, x_84, x_85, x_69, x_3, x_70); -if (lean_obj_tag(x_86) == 0) -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_87 = lean_ctor_get(x_86, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_86, 0); -lean_inc(x_88); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_89 = x_86; -} else { - lean_dec_ref(x_86); - x_89 = lean_box(0); -} -x_90 = lean_ctor_get(x_87, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_87, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_87, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_87, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_87, 5); -lean_inc(x_94); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - lean_ctor_release(x_87, 4); - lean_ctor_release(x_87, 5); - x_95 = x_87; -} else { - lean_dec_ref(x_87); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 6, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_90); -lean_ctor_set(x_96, 1, x_91); -lean_ctor_set(x_96, 2, x_82); -lean_ctor_set(x_96, 3, x_92); -lean_ctor_set(x_96, 4, x_93); -lean_ctor_set(x_96, 5, x_94); -if (lean_is_scalar(x_89)) { - x_97 = lean_alloc_ctor(0, 2, 0); -} else { - x_97 = x_89; -} -lean_ctor_set(x_97, 0, x_88); -lean_ctor_set(x_97, 1, x_96); -return x_97; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_86, 0); -lean_inc(x_99); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_100 = x_86; -} else { - lean_dec_ref(x_86); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_98, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_98, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_98, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_98, 5); -lean_inc(x_105); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - lean_ctor_release(x_98, 2); - lean_ctor_release(x_98, 3); - lean_ctor_release(x_98, 4); - lean_ctor_release(x_98, 5); - x_106 = x_98; -} else { - lean_dec_ref(x_98); - x_106 = lean_box(0); -} -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 6, 0); -} else { - x_107 = x_106; -} -lean_ctor_set(x_107, 0, x_101); -lean_ctor_set(x_107, 1, x_102); -lean_ctor_set(x_107, 2, x_82); -lean_ctor_set(x_107, 3, x_103); -lean_ctor_set(x_107, 4, x_104); -lean_ctor_set(x_107, 5, x_105); -if (lean_is_scalar(x_100)) { - x_108 = lean_alloc_ctor(1, 2, 0); -} else { - x_108 = x_100; -} -lean_ctor_set(x_108, 0, x_99); -lean_ctor_set(x_108, 1, x_107); -return x_108; -} -} -} -} -else -{ -uint8_t x_109; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_109 = !lean_is_exclusive(x_12); -if (x_109 == 0) -{ -return x_12; -} -else -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_12, 0); -x_111 = lean_ctor_get(x_12, 1); -lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_12); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_110); -lean_ctor_set(x_112, 1, x_111); -return x_112; -} -} -} -else -{ -lean_object* x_113; uint8_t x_114; uint8_t x_115; uint8_t x_116; uint8_t x_117; uint8_t x_118; lean_object* x_119; lean_object* x_120; uint8_t x_121; lean_object* x_122; -x_113 = lean_ctor_get(x_5, 0); -x_114 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_115 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_116 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_117 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -lean_inc(x_113); -lean_dec(x_5); -x_118 = 1; -x_119 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_119, 0, x_113); -lean_ctor_set_uint8(x_119, sizeof(void*)*1, x_114); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 1, x_115); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 2, x_116); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 3, x_117); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 4, x_118); -lean_inc(x_6); -x_120 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_6); -lean_ctor_set(x_120, 2, x_7); -x_121 = 0; -lean_inc(x_1); -x_122 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_121, x_1, x_1, x_120, x_4); -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; uint8_t x_126; -x_123 = lean_ctor_get(x_122, 0); -lean_inc(x_123); -x_124 = lean_ctor_get(x_122, 1); -lean_inc(x_124); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_125 = x_122; -} else { - lean_dec_ref(x_122); - x_125 = lean_box(0); -} -x_126 = l_Lean_Expr_isForall(x_123); -if (x_126 == 0) -{ -lean_object* x_127; -lean_dec(x_123); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_127 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_127) == 4) -{ -lean_object* x_128; lean_object* x_129; uint8_t x_130; -x_128 = lean_ctor_get(x_127, 0); -lean_inc(x_128); -lean_dec(x_127); -x_129 = lean_ctor_get(x_124, 0); -lean_inc(x_129); -lean_inc(x_128); -x_130 = lean_is_class(x_129, x_128); -if (x_130 == 0) -{ -lean_object* x_131; lean_object* x_132; -lean_dec(x_128); -x_131 = lean_box(0); -if (lean_is_scalar(x_125)) { - x_132 = lean_alloc_ctor(0, 2, 0); -} else { - x_132 = x_125; -} -lean_ctor_set(x_132, 0, x_131); -lean_ctor_set(x_132, 1, x_124); -return x_132; -} -else -{ -lean_object* x_133; lean_object* x_134; -x_133 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_133, 0, x_128); -if (lean_is_scalar(x_125)) { - x_134 = lean_alloc_ctor(0, 2, 0); -} else { - x_134 = x_125; -} -lean_ctor_set(x_134, 0, x_133); -lean_ctor_set(x_134, 1, x_124); -return x_134; -} -} -else -{ -lean_object* x_135; lean_object* x_136; -lean_dec(x_127); -x_135 = lean_box(0); -if (lean_is_scalar(x_125)) { - x_136 = lean_alloc_ctor(0, 2, 0); -} else { - x_136 = x_125; -} -lean_ctor_set(x_136, 0, x_135); -lean_ctor_set(x_136, 1, x_124); -return x_136; -} -} -else -{ -lean_object* x_137; uint8_t x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; -lean_dec(x_125); -lean_dec(x_1); -x_137 = lean_ctor_get(x_124, 2); -lean_inc(x_137); -x_138 = 1; -x_139 = l_Array_empty___closed__1; -x_140 = lean_unsigned_to_nat(0u); -x_141 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9(x_138, x_2, x_6, x_139, x_140, x_123, x_3, x_124); -if (lean_obj_tag(x_141) == 0) -{ -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; -x_142 = lean_ctor_get(x_141, 1); -lean_inc(x_142); -x_143 = lean_ctor_get(x_141, 0); -lean_inc(x_143); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - x_144 = x_141; -} else { - lean_dec_ref(x_141); - x_144 = lean_box(0); -} -x_145 = lean_ctor_get(x_142, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_142, 1); -lean_inc(x_146); -x_147 = lean_ctor_get(x_142, 3); -lean_inc(x_147); -x_148 = lean_ctor_get(x_142, 4); -lean_inc(x_148); -x_149 = lean_ctor_get(x_142, 5); -lean_inc(x_149); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - lean_ctor_release(x_142, 2); - lean_ctor_release(x_142, 3); - lean_ctor_release(x_142, 4); - lean_ctor_release(x_142, 5); - x_150 = x_142; -} else { - lean_dec_ref(x_142); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(0, 6, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_145); -lean_ctor_set(x_151, 1, x_146); -lean_ctor_set(x_151, 2, x_137); -lean_ctor_set(x_151, 3, x_147); -lean_ctor_set(x_151, 4, x_148); -lean_ctor_set(x_151, 5, x_149); -if (lean_is_scalar(x_144)) { - x_152 = lean_alloc_ctor(0, 2, 0); -} else { - x_152 = x_144; -} -lean_ctor_set(x_152, 0, x_143); -lean_ctor_set(x_152, 1, x_151); -return x_152; -} -else -{ -lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; -x_153 = lean_ctor_get(x_141, 1); -lean_inc(x_153); -x_154 = lean_ctor_get(x_141, 0); -lean_inc(x_154); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - x_155 = x_141; -} else { - lean_dec_ref(x_141); - x_155 = lean_box(0); -} -x_156 = lean_ctor_get(x_153, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_153, 1); -lean_inc(x_157); -x_158 = lean_ctor_get(x_153, 3); -lean_inc(x_158); -x_159 = lean_ctor_get(x_153, 4); -lean_inc(x_159); -x_160 = lean_ctor_get(x_153, 5); -lean_inc(x_160); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - lean_ctor_release(x_153, 1); - lean_ctor_release(x_153, 2); - lean_ctor_release(x_153, 3); - lean_ctor_release(x_153, 4); - lean_ctor_release(x_153, 5); - x_161 = x_153; -} else { - lean_dec_ref(x_153); - x_161 = lean_box(0); -} -if (lean_is_scalar(x_161)) { - x_162 = lean_alloc_ctor(0, 6, 0); -} else { - x_162 = x_161; -} -lean_ctor_set(x_162, 0, x_156); -lean_ctor_set(x_162, 1, x_157); -lean_ctor_set(x_162, 2, x_137); -lean_ctor_set(x_162, 3, x_158); -lean_ctor_set(x_162, 4, x_159); -lean_ctor_set(x_162, 5, x_160); -if (lean_is_scalar(x_155)) { - x_163 = lean_alloc_ctor(1, 2, 0); -} else { - x_163 = x_155; -} -lean_ctor_set(x_163, 0, x_154); -lean_ctor_set(x_163, 1, x_162); -return x_163; -} -} -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_164 = lean_ctor_get(x_122, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_122, 1); -lean_inc(x_165); -if (lean_is_exclusive(x_122)) { - lean_ctor_release(x_122, 0); - lean_ctor_release(x_122, 1); - x_166 = x_122; -} else { - lean_dec_ref(x_122); - x_166 = lean_box(0); -} -if (lean_is_scalar(x_166)) { - x_167 = lean_alloc_ctor(1, 2, 0); -} else { - x_167 = x_166; -} -lean_ctor_set(x_167, 0, x_164); -lean_ctor_set(x_167, 1, x_165); -return x_167; -} -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; uint8_t x_5; -x_4 = lean_box(0); -x_5 = !lean_is_exclusive(x_2); -if (x_5 == 0) -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_ctor_get(x_2, 0); -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -uint8_t x_8; lean_object* x_9; -x_8 = 2; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_8); -x_9 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isProp___spec__8(x_1, x_4, x_2, x_3); -return x_9; -} -else -{ -lean_object* x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; -x_10 = lean_ctor_get(x_6, 0); -x_11 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_12 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_13 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_14 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_10); -lean_dec(x_6); -x_15 = 2; -x_16 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_16, 0, x_10); -lean_ctor_set_uint8(x_16, sizeof(void*)*1, x_11); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 1, x_12); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 2, x_13); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 3, x_14); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_15); -lean_ctor_set(x_2, 0, x_16); -x_17 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isProp___spec__8(x_1, x_4, x_2, x_3); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_18 = lean_ctor_get(x_2, 0); -x_19 = lean_ctor_get(x_2, 1); -x_20 = lean_ctor_get(x_2, 2); -lean_inc(x_20); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_2); -x_21 = lean_ctor_get(x_18, 0); -lean_inc(x_21); -x_22 = lean_ctor_get_uint8(x_18, sizeof(void*)*1); -x_23 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 1); -x_24 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 2); -x_25 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - x_26 = x_18; -} else { - lean_dec_ref(x_18); - x_26 = lean_box(0); -} -x_27 = 2; -if (lean_is_scalar(x_26)) { - x_28 = lean_alloc_ctor(0, 1, 5); -} else { - x_28 = x_26; -} -lean_ctor_set(x_28, 0, x_21); -lean_ctor_set_uint8(x_28, sizeof(void*)*1, x_22); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 1, x_23); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 2, x_24); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 3, x_25); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 4, x_27); -x_29 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_29, 0, x_28); -lean_ctor_set(x_29, 1, x_19); -lean_ctor_set(x_29, 2, x_20); -x_30 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isProp___spec__8(x_1, x_4, x_29, x_3); -return x_30; -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_isProp___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__13(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -lean_dec(x_4); -lean_inc(x_5); -x_9 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_2, x_5, x_6); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_9, 1); -lean_inc(x_11); -lean_dec(x_9); -x_12 = l_Lean_Meta_mkForall(x_1, x_10, x_5, x_11); -return x_12; -} -else -{ -uint8_t x_13; -lean_dec(x_5); -lean_dec(x_1); -x_13 = !lean_is_exclusive(x_9); -if (x_13 == 0) -{ -return x_9; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_9, 0); -x_15 = lean_ctor_get(x_9, 1); -lean_inc(x_15); -lean_inc(x_14); -lean_dec(x_9); -x_16 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_16, 0, x_14); -lean_ctor_set(x_16, 1, x_15); -return x_16; -} -} -} -else -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_5, x_6); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_18, 1); -lean_inc(x_20); -lean_dec(x_18); -x_21 = l_Lean_LocalDecl_type(x_19); -lean_dec(x_19); -lean_inc(x_5); -lean_inc(x_21); -x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_5, x_20); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -switch (lean_obj_tag(x_23)) { -case 0: -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -lean_dec(x_21); -lean_dec(x_17); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_unsigned_to_nat(1u); -x_26 = lean_nat_add(x_4, x_25); -lean_dec(x_4); -x_4 = x_26; -x_6 = x_24; -goto _start; -} -case 1: -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; -lean_dec(x_21); -x_28 = lean_ctor_get(x_22, 1); -lean_inc(x_28); -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 0); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_unsigned_to_nat(1u); -x_31 = lean_nat_add(x_4, x_30); -lean_dec(x_4); -x_32 = !lean_is_exclusive(x_5); -if (x_32 == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_5, 2); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_29); -lean_ctor_set(x_34, 1, x_17); -x_35 = lean_array_push(x_33, x_34); -lean_ctor_set(x_5, 2, x_35); -x_4 = x_31; -x_6 = x_28; -goto _start; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_5, 0); -x_38 = lean_ctor_get(x_5, 1); -x_39 = lean_ctor_get(x_5, 2); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_5); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_29); -lean_ctor_set(x_40, 1, x_17); -x_41 = lean_array_push(x_39, x_40); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_37); -lean_ctor_set(x_42, 1, x_38); -lean_ctor_set(x_42, 2, x_41); -x_4 = x_31; -x_5 = x_42; -x_6 = x_28; -goto _start; -} -} -default: -{ -lean_object* x_44; lean_object* x_45; -x_44 = lean_ctor_get(x_22, 1); -lean_inc(x_44); -lean_dec(x_22); -lean_inc(x_5); -x_45 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_21, x_5, x_44); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_45, 0); -lean_inc(x_46); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -lean_dec(x_17); -x_47 = lean_ctor_get(x_45, 1); -lean_inc(x_47); -lean_dec(x_45); -x_48 = lean_unsigned_to_nat(1u); -x_49 = lean_nat_add(x_4, x_48); -lean_dec(x_4); -x_4 = x_49; -x_6 = x_47; -goto _start; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; -x_51 = lean_ctor_get(x_45, 1); -lean_inc(x_51); -lean_dec(x_45); -x_52 = lean_ctor_get(x_46, 0); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_unsigned_to_nat(1u); -x_54 = lean_nat_add(x_4, x_53); -lean_dec(x_4); -x_55 = !lean_is_exclusive(x_5); -if (x_55 == 0) -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_5, 2); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_52); -lean_ctor_set(x_57, 1, x_17); -x_58 = lean_array_push(x_56, x_57); -lean_ctor_set(x_5, 2, x_58); -x_4 = x_54; -x_6 = x_51; -goto _start; -} -else -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_60 = lean_ctor_get(x_5, 0); -x_61 = lean_ctor_get(x_5, 1); -x_62 = lean_ctor_get(x_5, 2); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_dec(x_5); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_52); -lean_ctor_set(x_63, 1, x_17); -x_64 = lean_array_push(x_62, x_63); -x_65 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_65, 0, x_60); -lean_ctor_set(x_65, 1, x_61); -lean_ctor_set(x_65, 2, x_64); -x_4 = x_54; -x_5 = x_65; -x_6 = x_51; -goto _start; -} -} -} -else -{ -uint8_t x_67; -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_67 = !lean_is_exclusive(x_45); -if (x_67 == 0) -{ -return x_45; -} -else -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_68 = lean_ctor_get(x_45, 0); -x_69 = lean_ctor_get(x_45, 1); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_45); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -return x_70; -} -} -} -} -} -else -{ -uint8_t x_71; -lean_dec(x_21); -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_71 = !lean_is_exclusive(x_22); -if (x_71 == 0) -{ -return x_22; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_22, 0); -x_73 = lean_ctor_get(x_22, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_22); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_75 = !lean_is_exclusive(x_18); -if (x_75 == 0) -{ -return x_18; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_18, 0); -x_77 = lean_ctor_get(x_18, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_18); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_isProp___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -switch (lean_obj_tag(x_4)) { -case 6: -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; uint64_t x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_18 = lean_ctor_get(x_4, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_4, 1); -lean_inc(x_19); -x_20 = lean_ctor_get(x_4, 2); -lean_inc(x_20); -x_21 = lean_ctor_get_uint64(x_4, sizeof(void*)*3); -lean_dec(x_4); -x_22 = lean_array_get_size(x_2); -lean_inc(x_2); -x_23 = lean_expr_instantiate_rev_range(x_19, x_3, x_22, x_2); -lean_dec(x_22); -lean_dec(x_19); -x_24 = l_Lean_Meta_mkFreshId___rarg(x_6); -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = (uint8_t)((x_21 << 24) >> 61); -lean_inc(x_25); -x_28 = lean_local_ctx_mk_local_decl(x_1, x_25, x_18, x_23, x_27); -x_29 = l_Lean_mkFVar(x_25); -x_30 = lean_array_push(x_2, x_29); -x_1 = x_28; -x_2 = x_30; -x_4 = x_20; -x_6 = x_26; -goto _start; -} -case 8: -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_32 = lean_ctor_get(x_4, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_4, 1); -lean_inc(x_33); -x_34 = lean_ctor_get(x_4, 2); -lean_inc(x_34); -x_35 = lean_ctor_get(x_4, 3); -lean_inc(x_35); -lean_dec(x_4); -x_36 = lean_array_get_size(x_2); -lean_inc(x_2); -x_37 = lean_expr_instantiate_rev_range(x_33, x_3, x_36, x_2); -lean_dec(x_33); -lean_inc(x_2); -x_38 = lean_expr_instantiate_rev_range(x_34, x_3, x_36, x_2); -lean_dec(x_36); -lean_dec(x_34); -x_39 = l_Lean_Meta_mkFreshId___rarg(x_6); -x_40 = lean_ctor_get(x_39, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_39, 1); -lean_inc(x_41); -lean_dec(x_39); -lean_inc(x_40); -x_42 = lean_local_ctx_mk_let_decl(x_1, x_40, x_32, x_37, x_38); -x_43 = l_Lean_mkFVar(x_40); -x_44 = lean_array_push(x_2, x_43); -x_1 = x_42; -x_2 = x_44; -x_4 = x_35; -x_6 = x_41; -goto _start; -} -default: -{ -lean_object* x_46; -x_46 = lean_box(0); -x_7 = x_46; -goto block_17; -} -} -block_17: -{ -lean_object* x_8; lean_object* x_9; uint8_t x_10; -lean_dec(x_7); -x_8 = lean_array_get_size(x_2); -lean_inc(x_2); -x_9 = lean_expr_instantiate_rev_range(x_4, x_3, x_8, x_2); -lean_dec(x_8); -lean_dec(x_4); -x_10 = !lean_is_exclusive(x_5); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; -x_11 = lean_ctor_get(x_5, 1); -lean_dec(x_11); -lean_ctor_set(x_5, 1, x_1); -lean_inc(x_2); -x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__13(x_2, x_9, x_2, x_3, x_5, x_6); -lean_dec(x_2); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_5, 0); -x_14 = lean_ctor_get(x_5, 2); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_5); -x_15 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_15, 0, x_13); -lean_ctor_set(x_15, 1, x_1); -lean_ctor_set(x_15, 2, x_14); -lean_inc(x_2); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__13(x_2, x_9, x_2, x_3, x_15, x_6); -lean_dec(x_2); -return x_16; -} -} -} -} -lean_object* l_Lean_Meta_lambdaTelescope___at_Lean_Meta_isProp___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; -x_4 = lean_ctor_get(x_3, 2); -lean_inc(x_4); -x_5 = lean_ctor_get(x_2, 1); -lean_inc(x_5); -x_6 = l_Array_empty___closed__1; -x_7 = lean_unsigned_to_nat(0u); -x_8 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_isProp___spec__5(x_5, x_6, x_7, x_1, x_2, x_3); -if (lean_obj_tag(x_8) == 0) -{ -uint8_t x_9; -x_9 = !lean_is_exclusive(x_8); -if (x_9 == 0) -{ -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_8, 1); -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) -{ -lean_object* x_12; -x_12 = lean_ctor_get(x_10, 2); -lean_dec(x_12); -lean_ctor_set(x_10, 2, x_4); -return x_8; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_13 = lean_ctor_get(x_10, 0); -x_14 = lean_ctor_get(x_10, 1); -x_15 = lean_ctor_get(x_10, 3); -x_16 = lean_ctor_get(x_10, 4); -x_17 = lean_ctor_get(x_10, 5); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_10); -x_18 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_18, 0, x_13); -lean_ctor_set(x_18, 1, x_14); -lean_ctor_set(x_18, 2, x_4); -lean_ctor_set(x_18, 3, x_15); -lean_ctor_set(x_18, 4, x_16); -lean_ctor_set(x_18, 5, x_17); -lean_ctor_set(x_8, 1, x_18); -return x_8; -} -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_19 = lean_ctor_get(x_8, 1); -x_20 = lean_ctor_get(x_8, 0); -lean_inc(x_19); -lean_inc(x_20); -lean_dec(x_8); -x_21 = lean_ctor_get(x_19, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_19, 1); -lean_inc(x_22); -x_23 = lean_ctor_get(x_19, 3); -lean_inc(x_23); -x_24 = lean_ctor_get(x_19, 4); -lean_inc(x_24); -x_25 = lean_ctor_get(x_19, 5); -lean_inc(x_25); -if (lean_is_exclusive(x_19)) { - lean_ctor_release(x_19, 0); - lean_ctor_release(x_19, 1); - lean_ctor_release(x_19, 2); - lean_ctor_release(x_19, 3); - lean_ctor_release(x_19, 4); - lean_ctor_release(x_19, 5); - x_26 = x_19; -} else { - lean_dec_ref(x_19); - x_26 = lean_box(0); -} -if (lean_is_scalar(x_26)) { - x_27 = lean_alloc_ctor(0, 6, 0); -} else { - x_27 = x_26; -} -lean_ctor_set(x_27, 0, x_21); -lean_ctor_set(x_27, 1, x_22); -lean_ctor_set(x_27, 2, x_4); -lean_ctor_set(x_27, 3, x_23); -lean_ctor_set(x_27, 4, x_24); -lean_ctor_set(x_27, 5, x_25); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_20); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -else -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_8); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_8, 1); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = lean_ctor_get(x_30, 2); -lean_dec(x_32); -lean_ctor_set(x_30, 2, x_4); -return x_8; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_33 = lean_ctor_get(x_30, 0); -x_34 = lean_ctor_get(x_30, 1); -x_35 = lean_ctor_get(x_30, 3); -x_36 = lean_ctor_get(x_30, 4); -x_37 = lean_ctor_get(x_30, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_30); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_34); -lean_ctor_set(x_38, 2, x_4); -lean_ctor_set(x_38, 3, x_35); -lean_ctor_set(x_38, 4, x_36); -lean_ctor_set(x_38, 5, x_37); -lean_ctor_set(x_8, 1, x_38); -return x_8; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_39 = lean_ctor_get(x_8, 1); -x_40 = lean_ctor_get(x_8, 0); -lean_inc(x_39); -lean_inc(x_40); -lean_dec(x_8); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_39, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_39, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_46 = x_39; -} else { - lean_dec_ref(x_39); - x_46 = lean_box(0); -} -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_46; -} -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); -lean_ctor_set(x_47, 2, x_4); -lean_ctor_set(x_47, 3, x_43); -lean_ctor_set(x_47, 4, x_44); -lean_ctor_set(x_47, 5, x_45); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_40); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___at_Lean_Meta_isProp___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_lambdaTelescope___at_Lean_Meta_isProp___spec__4(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__15(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_nat_dec_eq(x_4, x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_sub(x_4, x_10); -lean_dec(x_4); -x_21 = lean_nat_sub(x_3, x_11); -x_22 = lean_nat_sub(x_21, x_10); -lean_dec(x_21); -x_23 = lean_ctor_get(x_5, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_5, 1); -lean_inc(x_24); -if (lean_is_exclusive(x_5)) { - lean_ctor_release(x_5, 0); - lean_ctor_release(x_5, 1); - x_25 = x_5; -} else { - lean_dec_ref(x_5); - x_25 = lean_box(0); -} -if (lean_obj_tag(x_24) == 7) -{ -lean_object* x_89; lean_object* x_90; lean_object* x_91; -lean_dec(x_25); -lean_dec(x_22); -x_89 = lean_ctor_get(x_24, 2); -lean_inc(x_89); -lean_dec(x_24); -x_90 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_90, 0, x_23); -lean_ctor_set(x_90, 1, x_89); -x_91 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_91, 0, x_90); -lean_ctor_set(x_91, 1, x_7); -x_12 = x_91; -goto block_20; -} -else -{ -lean_object* x_92; -x_92 = lean_box(0); -x_26 = x_92; -goto block_88; -} -block_20: -{ -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -x_4 = x_11; -x_5 = x_13; -x_7 = x_14; -goto _start; -} -else -{ -uint8_t x_16; -lean_dec(x_11); -lean_dec(x_6); -lean_dec(x_2); -lean_dec(x_1); -x_16 = !lean_is_exclusive(x_12); -if (x_16 == 0) -{ -return x_12; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_12, 0); -x_18 = lean_ctor_get(x_12, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_12); -x_19 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_18); -return x_19; -} -} -} -block_88: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; -lean_dec(x_26); -lean_inc(x_2); -x_27 = lean_expr_instantiate_rev_range(x_24, x_23, x_22, x_2); -lean_dec(x_23); -lean_dec(x_24); -x_28 = lean_ctor_get(x_6, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_6, 1); -lean_inc(x_29); -x_30 = lean_ctor_get(x_6, 2); -lean_inc(x_30); -x_31 = !lean_is_exclusive(x_28); -if (x_31 == 0) -{ -uint8_t x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; -x_32 = 1; -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 4, x_32); -lean_inc(x_29); -x_33 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_33, 0, x_28); -lean_ctor_set(x_33, 1, x_29); -lean_ctor_set(x_33, 2, x_30); -x_34 = 0; -lean_inc(x_27); -x_35 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_34, x_27, x_27, x_33, x_7); -lean_dec(x_27); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_35, 1); -lean_inc(x_37); -if (lean_is_exclusive(x_35)) { - lean_ctor_release(x_35, 0); - lean_ctor_release(x_35, 1); - x_38 = x_35; -} else { - lean_dec_ref(x_35); - x_38 = lean_box(0); -} -if (lean_obj_tag(x_36) == 7) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_38); -lean_dec(x_29); -x_49 = lean_ctor_get(x_36, 2); -lean_inc(x_49); -lean_dec(x_36); -if (lean_is_scalar(x_25)) { - x_50 = lean_alloc_ctor(0, 2, 0); -} else { - x_50 = x_25; -} -lean_ctor_set(x_50, 0, x_22); -lean_ctor_set(x_50, 1, x_49); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_37); -x_12 = x_51; -goto block_20; -} -else -{ -lean_object* x_52; -lean_dec(x_36); -lean_dec(x_25); -x_52 = lean_box(0); -x_39 = x_52; -goto block_48; -} -block_48: -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -lean_dec(x_39); -x_40 = lean_ctor_get(x_37, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_37, 1); -lean_inc(x_41); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_40); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set(x_42, 2, x_29); -lean_inc(x_1); -x_43 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_22, x_2, x_8, x_1); -x_44 = l_Lean_Expr_Inhabited; -x_45 = lean_array_get(x_44, x_2, x_22); -lean_dec(x_22); -x_46 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_42); -if (lean_is_scalar(x_38)) { - x_47 = lean_alloc_ctor(1, 2, 0); -} else { - x_47 = x_38; - lean_ctor_set_tag(x_47, 1); -} -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_37); -x_12 = x_47; -goto block_20; -} -} -else -{ -uint8_t x_53; -lean_dec(x_29); -lean_dec(x_25); -lean_dec(x_22); -x_53 = !lean_is_exclusive(x_35); -if (x_53 == 0) -{ -x_12 = x_35; -goto block_20; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_35, 0); -x_55 = lean_ctor_get(x_35, 1); -lean_inc(x_55); -lean_inc(x_54); -lean_dec(x_35); -x_56 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_56, 0, x_54); -lean_ctor_set(x_56, 1, x_55); -x_12 = x_56; -goto block_20; -} -} -} -else -{ -lean_object* x_57; uint8_t x_58; uint8_t x_59; uint8_t x_60; uint8_t x_61; uint8_t x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; lean_object* x_66; -x_57 = lean_ctor_get(x_28, 0); -x_58 = lean_ctor_get_uint8(x_28, sizeof(void*)*1); -x_59 = lean_ctor_get_uint8(x_28, sizeof(void*)*1 + 1); -x_60 = lean_ctor_get_uint8(x_28, sizeof(void*)*1 + 2); -x_61 = lean_ctor_get_uint8(x_28, sizeof(void*)*1 + 3); -lean_inc(x_57); -lean_dec(x_28); -x_62 = 1; -x_63 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_63, 0, x_57); -lean_ctor_set_uint8(x_63, sizeof(void*)*1, x_58); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 1, x_59); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 2, x_60); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 3, x_61); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 4, x_62); -lean_inc(x_29); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_63); -lean_ctor_set(x_64, 1, x_29); -lean_ctor_set(x_64, 2, x_30); -x_65 = 0; -lean_inc(x_27); -x_66 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_65, x_27, x_27, x_64, x_7); -lean_dec(x_27); -if (lean_obj_tag(x_66) == 0) -{ -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_66, 1); -lean_inc(x_68); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - x_69 = x_66; -} else { - lean_dec_ref(x_66); - x_69 = lean_box(0); -} -if (lean_obj_tag(x_67) == 7) -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -lean_dec(x_69); -lean_dec(x_29); -x_80 = lean_ctor_get(x_67, 2); -lean_inc(x_80); -lean_dec(x_67); -if (lean_is_scalar(x_25)) { - x_81 = lean_alloc_ctor(0, 2, 0); -} else { - x_81 = x_25; -} -lean_ctor_set(x_81, 0, x_22); -lean_ctor_set(x_81, 1, x_80); -x_82 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_82, 0, x_81); -lean_ctor_set(x_82, 1, x_68); -x_12 = x_82; -goto block_20; -} -else -{ -lean_object* x_83; -lean_dec(x_67); -lean_dec(x_25); -x_83 = lean_box(0); -x_70 = x_83; -goto block_79; -} -block_79: -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -lean_dec(x_70); -x_71 = lean_ctor_get(x_68, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_68, 1); -lean_inc(x_72); -x_73 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -lean_ctor_set(x_73, 2, x_29); -lean_inc(x_1); -x_74 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_22, x_2, x_8, x_1); -x_75 = l_Lean_Expr_Inhabited; -x_76 = lean_array_get(x_75, x_2, x_22); -lean_dec(x_22); -x_77 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_77, 0, x_74); -lean_ctor_set(x_77, 1, x_76); -lean_ctor_set(x_77, 2, x_73); -if (lean_is_scalar(x_69)) { - x_78 = lean_alloc_ctor(1, 2, 0); -} else { - x_78 = x_69; - lean_ctor_set_tag(x_78, 1); -} -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_68); -x_12 = x_78; -goto block_20; -} -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -lean_dec(x_29); -lean_dec(x_25); -lean_dec(x_22); -x_84 = lean_ctor_get(x_66, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_66, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_66)) { - lean_ctor_release(x_66, 0); - lean_ctor_release(x_66, 1); - x_86 = x_66; -} else { - lean_dec_ref(x_66); - x_86 = lean_box(0); -} -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(1, 2, 0); -} else { - x_87 = x_86; -} -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -x_12 = x_87; -goto block_20; -} -} -} -} -else -{ -lean_object* x_93; -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_93 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_93, 0, x_5); -lean_ctor_set(x_93, 1, x_7); -return x_93; -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_isProp___spec__14(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -lean_inc(x_3); -lean_inc(x_1); -x_5 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_1, x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_6 = lean_ctor_get(x_5, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_5, 1); -lean_inc(x_7); -lean_dec(x_5); -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_9, 0, x_8); -lean_ctor_set(x_9, 1, x_6); -x_10 = lean_array_get_size(x_2); -lean_inc(x_10); -lean_inc(x_2); -x_11 = l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__15(x_1, x_2, x_10, x_10, x_9, x_3, x_7); -if (lean_obj_tag(x_11) == 0) -{ -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_11, 0); -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -x_16 = lean_expr_instantiate_rev_range(x_15, x_14, x_10, x_2); -lean_dec(x_10); -lean_dec(x_14); -lean_dec(x_15); -lean_ctor_set(x_11, 0, x_16); -return x_11; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_17 = lean_ctor_get(x_11, 0); -x_18 = lean_ctor_get(x_11, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_11); -x_19 = lean_ctor_get(x_17, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_17, 1); -lean_inc(x_20); -lean_dec(x_17); -x_21 = lean_expr_instantiate_rev_range(x_20, x_19, x_10, x_2); -lean_dec(x_10); -lean_dec(x_19); -lean_dec(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_18); -return x_22; -} -} -else -{ -uint8_t x_23; -lean_dec(x_10); -lean_dec(x_2); -x_23 = !lean_is_exclusive(x_11); -if (x_23 == 0) -{ -return x_11; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_11, 0); -x_25 = lean_ctor_get(x_11, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_11); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -uint8_t x_27; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_27 = !lean_is_exclusive(x_5); -if (x_27 == 0) -{ -return x_5; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_5, 0); -x_29 = lean_ctor_get(x_5, 1); -lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_5); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -} -} -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_isProp___spec__17(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -lean_inc(x_1); -x_4 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_1, x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; -x_5 = lean_ctor_get(x_2, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_4, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -lean_dec(x_4); -x_8 = lean_ctor_get(x_2, 1); -lean_inc(x_8); -x_9 = lean_ctor_get(x_2, 2); -lean_inc(x_9); -x_10 = !lean_is_exclusive(x_5); -if (x_10 == 0) -{ -uint8_t x_11; lean_object* x_12; uint8_t x_13; lean_object* x_14; -x_11 = 1; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 4, x_11); -lean_inc(x_8); -x_12 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_12, 0, x_5); -lean_ctor_set(x_12, 1, x_8); -lean_ctor_set(x_12, 2, x_9); -x_13 = 0; -lean_inc(x_6); -x_14 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_13, x_6, x_6, x_12, x_7); -lean_dec(x_6); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -switch (lean_obj_tag(x_15)) { -case 2: -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -x_17 = lean_ctor_get(x_15, 0); -lean_inc(x_17); -lean_dec(x_15); -lean_inc(x_17); -x_18 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_17, x_2, x_16); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; uint8_t x_20; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_unbox(x_19); -lean_dec(x_19); -if (x_20 == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_8); -lean_dec(x_1); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -lean_dec(x_18); -x_22 = l_Lean_Meta_mkFreshId___rarg(x_21); -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = l_Lean_mkLevelMVar(x_23); -lean_inc(x_25); -x_26 = l_Lean_mkSort(x_25); -x_27 = l_Lean_Meta_assignExprMVar(x_17, x_26, x_2, x_24); -lean_dec(x_2); -if (lean_obj_tag(x_27) == 0) -{ -uint8_t x_28; -x_28 = !lean_is_exclusive(x_27); -if (x_28 == 0) -{ -lean_object* x_29; -x_29 = lean_ctor_get(x_27, 0); -lean_dec(x_29); -lean_ctor_set(x_27, 0, x_25); -return x_27; -} -else -{ -lean_object* x_30; lean_object* x_31; -x_30 = lean_ctor_get(x_27, 1); -lean_inc(x_30); -lean_dec(x_27); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_25); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -else -{ -uint8_t x_32; -lean_dec(x_25); -x_32 = !lean_is_exclusive(x_27); -if (x_32 == 0) -{ -return x_27; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_27, 0); -x_34 = lean_ctor_get(x_27, 1); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_27); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_33); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -} -else -{ -uint8_t x_36; -lean_dec(x_17); -lean_dec(x_2); -x_36 = !lean_is_exclusive(x_18); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_18, 1); -x_38 = lean_ctor_get(x_18, 0); -lean_dec(x_38); -x_39 = lean_ctor_get(x_37, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_37, 1); -lean_inc(x_40); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -lean_ctor_set(x_41, 2, x_8); -x_42 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_42, 0, x_1); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set_tag(x_18, 1); -lean_ctor_set(x_18, 0, x_42); -return x_18; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_43 = lean_ctor_get(x_18, 1); -lean_inc(x_43); -lean_dec(x_18); -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_8); -x_47 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_47, 0, x_1); -lean_ctor_set(x_47, 1, x_46); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_47); -lean_ctor_set(x_48, 1, x_43); -return x_48; -} -} -} -else -{ -uint8_t x_49; -lean_dec(x_17); -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_49 = !lean_is_exclusive(x_18); -if (x_49 == 0) -{ -return x_18; -} -else -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_18, 0); -x_51 = lean_ctor_get(x_18, 1); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_18); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); -return x_52; -} -} -} -case 3: -{ -uint8_t x_53; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_53 = !lean_is_exclusive(x_14); -if (x_53 == 0) -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_14, 0); -lean_dec(x_54); -x_55 = lean_ctor_get(x_15, 0); -lean_inc(x_55); -lean_dec(x_15); -lean_ctor_set(x_14, 0, x_55); -return x_14; -} -else -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_14, 1); -lean_inc(x_56); -lean_dec(x_14); -x_57 = lean_ctor_get(x_15, 0); -lean_inc(x_57); -lean_dec(x_15); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_56); -return x_58; -} -} -default: -{ -uint8_t x_59; -lean_dec(x_15); -lean_dec(x_2); -x_59 = !lean_is_exclusive(x_14); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_60 = lean_ctor_get(x_14, 1); -x_61 = lean_ctor_get(x_14, 0); -lean_dec(x_61); -x_62 = lean_ctor_get(x_60, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_60, 1); -lean_inc(x_63); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_62); -lean_ctor_set(x_64, 1, x_63); -lean_ctor_set(x_64, 2, x_8); -x_65 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_65, 0, x_1); -lean_ctor_set(x_65, 1, x_64); -lean_ctor_set_tag(x_14, 1); -lean_ctor_set(x_14, 0, x_65); -return x_14; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_14, 1); -lean_inc(x_66); -lean_dec(x_14); -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_66, 1); -lean_inc(x_68); -x_69 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_69, 0, x_67); -lean_ctor_set(x_69, 1, x_68); -lean_ctor_set(x_69, 2, x_8); -x_70 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_70, 0, x_1); -lean_ctor_set(x_70, 1, x_69); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_66); -return x_71; -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_72 = !lean_is_exclusive(x_14); -if (x_72 == 0) -{ -return x_14; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_14, 0); -x_74 = lean_ctor_get(x_14, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_14); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -lean_object* x_76; uint8_t x_77; uint8_t x_78; uint8_t x_79; uint8_t x_80; uint8_t x_81; lean_object* x_82; lean_object* x_83; uint8_t x_84; lean_object* x_85; -x_76 = lean_ctor_get(x_5, 0); -x_77 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_78 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_79 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_80 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -lean_inc(x_76); -lean_dec(x_5); -x_81 = 1; -x_82 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_82, 0, x_76); -lean_ctor_set_uint8(x_82, sizeof(void*)*1, x_77); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 1, x_78); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 2, x_79); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 3, x_80); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 4, x_81); -lean_inc(x_8); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_8); -lean_ctor_set(x_83, 2, x_9); -x_84 = 0; -lean_inc(x_6); -x_85 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_84, x_6, x_6, x_83, x_7); -lean_dec(x_6); -if (lean_obj_tag(x_85) == 0) -{ -lean_object* x_86; -x_86 = lean_ctor_get(x_85, 0); -lean_inc(x_86); -switch (lean_obj_tag(x_86)) { -case 2: -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_85, 1); -lean_inc(x_87); -lean_dec(x_85); -x_88 = lean_ctor_get(x_86, 0); -lean_inc(x_88); -lean_dec(x_86); -lean_inc(x_88); -x_89 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_88, x_2, x_87); -if (lean_obj_tag(x_89) == 0) -{ -lean_object* x_90; uint8_t x_91; -x_90 = lean_ctor_get(x_89, 0); -lean_inc(x_90); -x_91 = lean_unbox(x_90); -lean_dec(x_90); -if (x_91 == 0) -{ -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -lean_dec(x_8); -lean_dec(x_1); -x_92 = lean_ctor_get(x_89, 1); -lean_inc(x_92); -lean_dec(x_89); -x_93 = l_Lean_Meta_mkFreshId___rarg(x_92); -x_94 = lean_ctor_get(x_93, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_93, 1); -lean_inc(x_95); -lean_dec(x_93); -x_96 = l_Lean_mkLevelMVar(x_94); -lean_inc(x_96); -x_97 = l_Lean_mkSort(x_96); -x_98 = l_Lean_Meta_assignExprMVar(x_88, x_97, x_2, x_95); -lean_dec(x_2); -if (lean_obj_tag(x_98) == 0) -{ -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_98, 1); -lean_inc(x_99); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_100 = x_98; -} else { - lean_dec_ref(x_98); - x_100 = lean_box(0); -} -if (lean_is_scalar(x_100)) { - x_101 = lean_alloc_ctor(0, 2, 0); -} else { - x_101 = x_100; -} -lean_ctor_set(x_101, 0, x_96); -lean_ctor_set(x_101, 1, x_99); -return x_101; -} -else -{ -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -lean_dec(x_96); -x_102 = lean_ctor_get(x_98, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 1); -lean_inc(x_103); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_104 = x_98; -} else { - lean_dec_ref(x_98); - x_104 = lean_box(0); -} -if (lean_is_scalar(x_104)) { - x_105 = lean_alloc_ctor(1, 2, 0); -} else { - x_105 = x_104; -} -lean_ctor_set(x_105, 0, x_102); -lean_ctor_set(x_105, 1, x_103); -return x_105; -} -} -else -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; -lean_dec(x_88); -lean_dec(x_2); -x_106 = lean_ctor_get(x_89, 1); -lean_inc(x_106); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - x_107 = x_89; -} else { - lean_dec_ref(x_89); - x_107 = lean_box(0); -} -x_108 = lean_ctor_get(x_106, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_106, 1); -lean_inc(x_109); -x_110 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_110, 0, x_108); -lean_ctor_set(x_110, 1, x_109); -lean_ctor_set(x_110, 2, x_8); -x_111 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_111, 0, x_1); -lean_ctor_set(x_111, 1, x_110); -if (lean_is_scalar(x_107)) { - x_112 = lean_alloc_ctor(1, 2, 0); -} else { - x_112 = x_107; - lean_ctor_set_tag(x_112, 1); -} -lean_ctor_set(x_112, 0, x_111); -lean_ctor_set(x_112, 1, x_106); -return x_112; -} -} -else -{ -lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; -lean_dec(x_88); -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_113 = lean_ctor_get(x_89, 0); -lean_inc(x_113); -x_114 = lean_ctor_get(x_89, 1); -lean_inc(x_114); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - x_115 = x_89; -} else { - lean_dec_ref(x_89); - x_115 = lean_box(0); -} -if (lean_is_scalar(x_115)) { - x_116 = lean_alloc_ctor(1, 2, 0); -} else { - x_116 = x_115; -} -lean_ctor_set(x_116, 0, x_113); -lean_ctor_set(x_116, 1, x_114); -return x_116; -} -} -case 3: -{ -lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_117 = lean_ctor_get(x_85, 1); -lean_inc(x_117); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_118 = x_85; -} else { - lean_dec_ref(x_85); - x_118 = lean_box(0); -} -x_119 = lean_ctor_get(x_86, 0); -lean_inc(x_119); -lean_dec(x_86); -if (lean_is_scalar(x_118)) { - x_120 = lean_alloc_ctor(0, 2, 0); -} else { - x_120 = x_118; -} -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_117); -return x_120; -} -default: -{ -lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; -lean_dec(x_86); -lean_dec(x_2); -x_121 = lean_ctor_get(x_85, 1); -lean_inc(x_121); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_122 = x_85; -} else { - lean_dec_ref(x_85); - x_122 = lean_box(0); -} -x_123 = lean_ctor_get(x_121, 0); -lean_inc(x_123); -x_124 = lean_ctor_get(x_121, 1); -lean_inc(x_124); -x_125 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_125, 0, x_123); -lean_ctor_set(x_125, 1, x_124); -lean_ctor_set(x_125, 2, x_8); -x_126 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_126, 0, x_1); -lean_ctor_set(x_126, 1, x_125); -if (lean_is_scalar(x_122)) { - x_127 = lean_alloc_ctor(1, 2, 0); -} else { - x_127 = x_122; - lean_ctor_set_tag(x_127, 1); -} -lean_ctor_set(x_127, 0, x_126); -lean_ctor_set(x_127, 1, x_121); -return x_127; -} -} -} -else -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; -lean_dec(x_8); -lean_dec(x_2); -lean_dec(x_1); -x_128 = lean_ctor_get(x_85, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_85, 1); -lean_inc(x_129); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - lean_ctor_release(x_85, 1); - x_130 = x_85; -} else { - lean_dec_ref(x_85); - x_130 = lean_box(0); -} -if (lean_is_scalar(x_130)) { - x_131 = lean_alloc_ctor(1, 2, 0); -} else { - x_131 = x_130; -} -lean_ctor_set(x_131, 0, x_128); -lean_ctor_set(x_131, 1, x_129); -return x_131; -} -} -} -else -{ -uint8_t x_132; -lean_dec(x_2); -lean_dec(x_1); -x_132 = !lean_is_exclusive(x_4); -if (x_132 == 0) -{ -return x_4; -} -else -{ -lean_object* x_133; lean_object* x_134; lean_object* x_135; -x_133 = lean_ctor_get(x_4, 0); -x_134 = lean_ctor_get(x_4, 1); -lean_inc(x_134); -lean_inc(x_133); -lean_dec(x_4); -x_135 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_135, 0, x_133); -lean_ctor_set(x_135, 1, x_134); -return x_135; -} -} -} -} -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_nat_dec_eq(x_3, x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_sub(x_3, x_10); -lean_dec(x_3); -x_12 = lean_array_fget(x_2, x_11); -lean_inc(x_6); -x_13 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_12, x_6, x_7); -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -lean_inc(x_6); -x_16 = l_Lean_Meta_getLevelAux___at_Lean_Meta_isProp___spec__17(x_14, x_6, x_15); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -x_19 = l_Lean_mkLevelIMax(x_17, x_5); -x_3 = x_11; -x_4 = lean_box(0); -x_5 = x_19; -x_7 = x_18; -goto _start; -} -else -{ -uint8_t x_21; -lean_dec(x_11); -lean_dec(x_6); -lean_dec(x_5); -x_21 = !lean_is_exclusive(x_16); -if (x_21 == 0) -{ -return x_16; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_16, 0); -x_23 = lean_ctor_get(x_16, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_16); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -else -{ -uint8_t x_25; -lean_dec(x_11); -lean_dec(x_6); -lean_dec(x_5); -x_25 = !lean_is_exclusive(x_13); -if (x_25 == 0) -{ -return x_13; -} -else -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_13, 0); -x_27 = lean_ctor_get(x_13, 1); -lean_inc(x_27); -lean_inc(x_26); -lean_dec(x_13); -x_28 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_28, 0, x_26); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -} -else -{ -lean_object* x_29; -lean_dec(x_6); -lean_dec(x_3); -x_29 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_29, 0, x_5); -lean_ctor_set(x_29, 1, x_7); -return x_29; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__20(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_4); -x_9 = lean_nat_dec_lt(x_5, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; -lean_dec(x_5); -lean_inc(x_6); -x_10 = l_Lean_Meta_getLevelAux___at_Lean_Meta_isProp___spec__17(x_3, x_6, x_7); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); -lean_inc(x_12); -lean_dec(x_10); -x_13 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18(x_1, x_1, x_2, lean_box(0), x_11, x_6, x_12); -if (lean_obj_tag(x_13) == 0) -{ -uint8_t x_14; -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_13, 0); -x_16 = l_Lean_Level_normalize___main(x_15); -lean_dec(x_15); -x_17 = l_Lean_mkSort(x_16); -lean_ctor_set(x_13, 0, x_17); -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_13, 0); -x_19 = lean_ctor_get(x_13, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_13); -x_20 = l_Lean_Level_normalize___main(x_18); -lean_dec(x_18); -x_21 = l_Lean_mkSort(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_19); -return x_22; -} -} -else -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_13); -if (x_23 == 0) -{ -return x_13; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_13, 0); -x_25 = lean_ctor_get(x_13, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_13); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -uint8_t x_27; -lean_dec(x_6); -lean_dec(x_2); -x_27 = !lean_is_exclusive(x_10); -if (x_27 == 0) -{ -return x_10; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_10, 0); -x_29 = lean_ctor_get(x_10, 1); -lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_10); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -} -else -{ -lean_object* x_31; lean_object* x_32; -x_31 = lean_array_fget(x_4, x_5); -lean_inc(x_6); -x_32 = l_Lean_Meta_getFVarLocalDecl(x_31, x_6, x_7); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = l_Lean_LocalDecl_type(x_33); -lean_dec(x_33); -lean_inc(x_6); -lean_inc(x_35); -x_36 = l_Lean_Meta_isClassQuick___main(x_35, x_6, x_34); -if (lean_obj_tag(x_36) == 0) -{ -lean_object* x_37; -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -switch (lean_obj_tag(x_37)) { -case 0: -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; -lean_dec(x_35); -lean_dec(x_31); -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -x_39 = lean_unsigned_to_nat(1u); -x_40 = lean_nat_add(x_5, x_39); -lean_dec(x_5); -x_5 = x_40; -x_7 = x_38; -goto _start; -} -case 1: -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; -lean_dec(x_35); -x_42 = lean_ctor_get(x_36, 1); -lean_inc(x_42); -lean_dec(x_36); -x_43 = lean_ctor_get(x_37, 0); -lean_inc(x_43); -lean_dec(x_37); -x_44 = lean_unsigned_to_nat(1u); -x_45 = lean_nat_add(x_5, x_44); -lean_dec(x_5); -x_46 = !lean_is_exclusive(x_6); -if (x_46 == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_47 = lean_ctor_get(x_6, 2); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_43); -lean_ctor_set(x_48, 1, x_31); -x_49 = lean_array_push(x_47, x_48); -lean_ctor_set(x_6, 2, x_49); -x_5 = x_45; -x_7 = x_42; -goto _start; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_51 = lean_ctor_get(x_6, 0); -x_52 = lean_ctor_get(x_6, 1); -x_53 = lean_ctor_get(x_6, 2); -lean_inc(x_53); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_6); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_43); -lean_ctor_set(x_54, 1, x_31); -x_55 = lean_array_push(x_53, x_54); -x_56 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_56, 0, x_51); -lean_ctor_set(x_56, 1, x_52); -lean_ctor_set(x_56, 2, x_55); -x_5 = x_45; -x_6 = x_56; -x_7 = x_42; -goto _start; -} -} -default: -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_36, 1); -lean_inc(x_58); -lean_dec(x_36); -lean_inc(x_6); -x_59 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_35, x_6, x_58); -if (lean_obj_tag(x_59) == 0) -{ -lean_object* x_60; -x_60 = lean_ctor_get(x_59, 0); -lean_inc(x_60); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -lean_dec(x_31); -x_61 = lean_ctor_get(x_59, 1); -lean_inc(x_61); -lean_dec(x_59); -x_62 = lean_unsigned_to_nat(1u); -x_63 = lean_nat_add(x_5, x_62); -lean_dec(x_5); -x_5 = x_63; -x_7 = x_61; -goto _start; -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; -x_65 = lean_ctor_get(x_59, 1); -lean_inc(x_65); -lean_dec(x_59); -x_66 = lean_ctor_get(x_60, 0); -lean_inc(x_66); -lean_dec(x_60); -x_67 = lean_unsigned_to_nat(1u); -x_68 = lean_nat_add(x_5, x_67); -lean_dec(x_5); -x_69 = !lean_is_exclusive(x_6); -if (x_69 == 0) -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_6, 2); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_31); -x_72 = lean_array_push(x_70, x_71); -lean_ctor_set(x_6, 2, x_72); -x_5 = x_68; -x_7 = x_65; -goto _start; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_74 = lean_ctor_get(x_6, 0); -x_75 = lean_ctor_get(x_6, 1); -x_76 = lean_ctor_get(x_6, 2); -lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_6); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_66); -lean_ctor_set(x_77, 1, x_31); -x_78 = lean_array_push(x_76, x_77); -x_79 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_79, 0, x_74); -lean_ctor_set(x_79, 1, x_75); -lean_ctor_set(x_79, 2, x_78); -x_5 = x_68; -x_6 = x_79; -x_7 = x_65; -goto _start; -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_59); -if (x_81 == 0) -{ -return x_59; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_59, 0); -x_83 = lean_ctor_get(x_59, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_59); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -} -} -else -{ -uint8_t x_85; -lean_dec(x_35); -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_85 = !lean_is_exclusive(x_36); -if (x_85 == 0) -{ -return x_36; -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_36, 0); -x_87 = lean_ctor_get(x_36, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_36); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} -} -} -else -{ -uint8_t x_89; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_89 = !lean_is_exclusive(x_32); -if (x_89 == 0) -{ -return x_32; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_32, 0); -x_91 = lean_ctor_get(x_32, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_32); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; -x_10 = l_Lean_Expr_isForall(x_7); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_inc(x_8); -x_11 = l_Lean_Meta_getLevelAux___at_Lean_Meta_isProp___spec__17(x_1, x_8, x_9); -if (lean_obj_tag(x_11) == 0) -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -x_13 = lean_ctor_get(x_11, 1); -lean_inc(x_13); -lean_dec(x_11); -x_14 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18(x_2, x_2, x_3, lean_box(0), x_12, x_8, x_13); -lean_dec(x_2); -if (lean_obj_tag(x_14) == 0) -{ -uint8_t x_15; -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 0); -x_17 = l_Lean_Level_normalize___main(x_16); -lean_dec(x_16); -x_18 = l_Lean_mkSort(x_17); -lean_ctor_set(x_14, 0, x_18); -return x_14; -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_19 = lean_ctor_get(x_14, 0); -x_20 = lean_ctor_get(x_14, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_14); -x_21 = l_Lean_Level_normalize___main(x_19); -lean_dec(x_19); -x_22 = l_Lean_mkSort(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_20); -return x_23; -} -} -else -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_14); -if (x_24 == 0) -{ -return x_14; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_14, 0); -x_26 = lean_ctor_get(x_14, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_14); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -uint8_t x_28; -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_28 = !lean_is_exclusive(x_11); -if (x_28 == 0) -{ -return x_11; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_11, 0); -x_30 = lean_ctor_get(x_11, 1); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_11); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -} -else -{ -lean_object* x_32; -lean_dec(x_1); -x_32 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__19(x_4, x_5, x_6, x_2, x_3, x_7, x_8, x_9); -return x_32; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_13 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1; -lean_inc(x_8); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_13); -lean_closure_set(x_14, 1, x_8); -x_15 = lean_box(x_1); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_7); -lean_inc(x_4); -lean_inc(x_8); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___lambda__1___boxed), 9, 6); -lean_closure_set(x_16, 0, x_8); -lean_closure_set(x_16, 1, x_4); -lean_closure_set(x_16, 2, x_7); -lean_closure_set(x_16, 3, x_15); -lean_closure_set(x_16, 4, x_2); -lean_closure_set(x_16, 5, x_3); -x_17 = lean_array_get_size(x_9); -x_18 = lean_nat_dec_lt(x_10, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_11, x_12); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_9, x_10); -lean_inc(x_11); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_11, x_12); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_11); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_11, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_10, x_28); -lean_dec(x_10); -x_10 = x_29; -x_12 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_10, x_33); -lean_dec(x_10); -x_35 = !lean_is_exclusive(x_11); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_11, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_11, 2, x_38); -x_10 = x_34; -x_12 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_11, 0); -x_41 = lean_ctor_get(x_11, 1); -x_42 = lean_ctor_get(x_11, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_11); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_10 = x_34; -x_11 = x_45; -x_12 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_11); -x_48 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_24, x_11, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_10, x_51); -lean_dec(x_10); -x_10 = x_52; -x_12 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_10, x_56); -lean_dec(x_10); -x_58 = !lean_is_exclusive(x_11); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_11, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_11, 2, x_61); -x_10 = x_57; -x_12 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_11, 0); -x_64 = lean_ctor_get(x_11, 1); -x_65 = lean_ctor_get(x_11, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_11); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_10 = x_57; -x_11 = x_68; -x_12 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__22(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_4); -x_9 = lean_nat_dec_lt(x_5, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; -lean_dec(x_5); -lean_inc(x_6); -x_10 = l_Lean_Meta_getLevelAux___at_Lean_Meta_isProp___spec__17(x_3, x_6, x_7); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); -lean_inc(x_12); -lean_dec(x_10); -x_13 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18(x_1, x_1, x_2, lean_box(0), x_11, x_6, x_12); -if (lean_obj_tag(x_13) == 0) -{ -uint8_t x_14; -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_13, 0); -x_16 = l_Lean_Level_normalize___main(x_15); -lean_dec(x_15); -x_17 = l_Lean_mkSort(x_16); -lean_ctor_set(x_13, 0, x_17); -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_13, 0); -x_19 = lean_ctor_get(x_13, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_13); -x_20 = l_Lean_Level_normalize___main(x_18); -lean_dec(x_18); -x_21 = l_Lean_mkSort(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_19); -return x_22; -} -} -else -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_13); -if (x_23 == 0) -{ -return x_13; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_13, 0); -x_25 = lean_ctor_get(x_13, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_13); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -uint8_t x_27; -lean_dec(x_6); -lean_dec(x_2); -x_27 = !lean_is_exclusive(x_10); -if (x_27 == 0) -{ -return x_10; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_10, 0); -x_29 = lean_ctor_get(x_10, 1); -lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_10); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -} -else -{ -lean_object* x_31; lean_object* x_32; -x_31 = lean_array_fget(x_4, x_5); -lean_inc(x_6); -x_32 = l_Lean_Meta_getFVarLocalDecl(x_31, x_6, x_7); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = l_Lean_LocalDecl_type(x_33); -lean_dec(x_33); -lean_inc(x_6); -lean_inc(x_35); -x_36 = l_Lean_Meta_isClassQuick___main(x_35, x_6, x_34); -if (lean_obj_tag(x_36) == 0) -{ -lean_object* x_37; -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -switch (lean_obj_tag(x_37)) { -case 0: -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; -lean_dec(x_35); -lean_dec(x_31); -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -x_39 = lean_unsigned_to_nat(1u); -x_40 = lean_nat_add(x_5, x_39); -lean_dec(x_5); -x_5 = x_40; -x_7 = x_38; -goto _start; -} -case 1: -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; -lean_dec(x_35); -x_42 = lean_ctor_get(x_36, 1); -lean_inc(x_42); -lean_dec(x_36); -x_43 = lean_ctor_get(x_37, 0); -lean_inc(x_43); -lean_dec(x_37); -x_44 = lean_unsigned_to_nat(1u); -x_45 = lean_nat_add(x_5, x_44); -lean_dec(x_5); -x_46 = !lean_is_exclusive(x_6); -if (x_46 == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_47 = lean_ctor_get(x_6, 2); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_43); -lean_ctor_set(x_48, 1, x_31); -x_49 = lean_array_push(x_47, x_48); -lean_ctor_set(x_6, 2, x_49); -x_5 = x_45; -x_7 = x_42; -goto _start; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_51 = lean_ctor_get(x_6, 0); -x_52 = lean_ctor_get(x_6, 1); -x_53 = lean_ctor_get(x_6, 2); -lean_inc(x_53); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_6); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_43); -lean_ctor_set(x_54, 1, x_31); -x_55 = lean_array_push(x_53, x_54); -x_56 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_56, 0, x_51); -lean_ctor_set(x_56, 1, x_52); -lean_ctor_set(x_56, 2, x_55); -x_5 = x_45; -x_6 = x_56; -x_7 = x_42; -goto _start; -} -} -default: -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_36, 1); -lean_inc(x_58); -lean_dec(x_36); -lean_inc(x_6); -x_59 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_35, x_6, x_58); -if (lean_obj_tag(x_59) == 0) -{ -lean_object* x_60; -x_60 = lean_ctor_get(x_59, 0); -lean_inc(x_60); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -lean_dec(x_31); -x_61 = lean_ctor_get(x_59, 1); -lean_inc(x_61); -lean_dec(x_59); -x_62 = lean_unsigned_to_nat(1u); -x_63 = lean_nat_add(x_5, x_62); -lean_dec(x_5); -x_5 = x_63; -x_7 = x_61; -goto _start; -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; -x_65 = lean_ctor_get(x_59, 1); -lean_inc(x_65); -lean_dec(x_59); -x_66 = lean_ctor_get(x_60, 0); -lean_inc(x_66); -lean_dec(x_60); -x_67 = lean_unsigned_to_nat(1u); -x_68 = lean_nat_add(x_5, x_67); -lean_dec(x_5); -x_69 = !lean_is_exclusive(x_6); -if (x_69 == 0) -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_6, 2); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_31); -x_72 = lean_array_push(x_70, x_71); -lean_ctor_set(x_6, 2, x_72); -x_5 = x_68; -x_7 = x_65; -goto _start; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_74 = lean_ctor_get(x_6, 0); -x_75 = lean_ctor_get(x_6, 1); -x_76 = lean_ctor_get(x_6, 2); -lean_inc(x_76); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_6); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_66); -lean_ctor_set(x_77, 1, x_31); -x_78 = lean_array_push(x_76, x_77); -x_79 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_79, 0, x_74); -lean_ctor_set(x_79, 1, x_75); -lean_ctor_set(x_79, 2, x_78); -x_5 = x_68; -x_6 = x_79; -x_7 = x_65; -goto _start; -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_59); -if (x_81 == 0) -{ -return x_59; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_59, 0); -x_83 = lean_ctor_get(x_59, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_59); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -} -} -else -{ -uint8_t x_85; -lean_dec(x_35); -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_85 = !lean_is_exclusive(x_36); -if (x_85 == 0) -{ -return x_36; -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_36, 0); -x_87 = lean_ctor_get(x_36, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_36); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} -} -} -else -{ -uint8_t x_89; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_89 = !lean_is_exclusive(x_32); -if (x_89 == 0) -{ -return x_32; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_32, 0); -x_91 = lean_ctor_get(x_32, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_32); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__19(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_22 = lean_ctor_get(x_6, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_6, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 2); -lean_inc(x_24); -x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); -lean_dec(x_6); -x_26 = lean_array_get_size(x_4); -lean_inc(x_4); -x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); -lean_dec(x_26); -lean_dec(x_23); -x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = (uint8_t)((x_25 << 24) >> 61); -lean_inc(x_29); -x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); -x_33 = l_Lean_mkFVar(x_29); -x_34 = lean_array_push(x_4, x_33); -if (lean_obj_tag(x_2) == 0) -{ -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -else -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_2, 0); -lean_inc(x_36); -x_37 = lean_array_get_size(x_34); -x_38 = lean_nat_dec_lt(x_37, x_36); -lean_dec(x_36); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -lean_dec(x_2); -lean_inc(x_34); -x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); -lean_dec(x_24); -x_40 = !lean_is_exclusive(x_7); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_7, 1); -lean_dec(x_41); -lean_ctor_set(x_7, 1, x_32); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__22(x_34, x_37, x_39, x_34, x_5, x_7, x_30); -lean_dec(x_34); -return x_42; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_7, 0); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_32); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__22(x_34, x_37, x_39, x_34, x_5, x_45, x_30); -lean_dec(x_34); -return x_46; -} -} -else -{ -lean_dec(x_37); -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -} -} -else -{ -lean_object* x_48; -x_48 = lean_box(0); -x_9 = x_48; -goto block_21; -} -block_21: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_7, 1); -lean_dec(x_13); -lean_inc(x_3); -lean_ctor_set(x_7, 1, x_3); -if (x_1 == 0) -{ -lean_object* x_14; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__20(x_4, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_4); -return x_14; -} -else -{ -lean_object* x_15; -lean_inc(x_5); -lean_inc(x_4); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_7, 0); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_7); -lean_inc(x_3); -x_18 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_3); -lean_ctor_set(x_18, 2, x_17); -if (x_1 == 0) -{ -lean_object* x_19; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__20(x_4, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_4); -return x_19; -} -else -{ -lean_object* x_20; -lean_inc(x_5); -lean_inc(x_4); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_20; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___at_Lean_Meta_isProp___spec__16(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_4 = lean_ctor_get(x_3, 2); -lean_inc(x_4); -x_5 = lean_ctor_get(x_2, 1); -lean_inc(x_5); -x_6 = lean_box(0); -x_7 = 0; -x_8 = l_Array_empty___closed__1; -x_9 = lean_unsigned_to_nat(0u); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__19(x_7, x_6, x_5, x_8, x_9, x_1, x_2, x_3); -if (lean_obj_tag(x_10) == 0) -{ -uint8_t x_11; -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) -{ -lean_object* x_12; uint8_t x_13; -x_12 = lean_ctor_get(x_10, 1); -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_12, 2); -lean_dec(x_14); -lean_ctor_set(x_12, 2, x_4); -return x_10; -} -else -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_15 = lean_ctor_get(x_12, 0); -x_16 = lean_ctor_get(x_12, 1); -x_17 = lean_ctor_get(x_12, 3); -x_18 = lean_ctor_get(x_12, 4); -x_19 = lean_ctor_get(x_12, 5); -lean_inc(x_19); -lean_inc(x_18); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_12); -x_20 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_20, 0, x_15); -lean_ctor_set(x_20, 1, x_16); -lean_ctor_set(x_20, 2, x_4); -lean_ctor_set(x_20, 3, x_17); -lean_ctor_set(x_20, 4, x_18); -lean_ctor_set(x_20, 5, x_19); -lean_ctor_set(x_10, 1, x_20); -return x_10; -} -} -else -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_21 = lean_ctor_get(x_10, 1); -x_22 = lean_ctor_get(x_10, 0); -lean_inc(x_21); -lean_inc(x_22); -lean_dec(x_10); -x_23 = lean_ctor_get(x_21, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_21, 1); -lean_inc(x_24); -x_25 = lean_ctor_get(x_21, 3); -lean_inc(x_25); -x_26 = lean_ctor_get(x_21, 4); -lean_inc(x_26); -x_27 = lean_ctor_get(x_21, 5); -lean_inc(x_27); -if (lean_is_exclusive(x_21)) { - lean_ctor_release(x_21, 0); - lean_ctor_release(x_21, 1); - lean_ctor_release(x_21, 2); - lean_ctor_release(x_21, 3); - lean_ctor_release(x_21, 4); - lean_ctor_release(x_21, 5); - x_28 = x_21; -} else { - lean_dec_ref(x_21); - x_28 = lean_box(0); -} -if (lean_is_scalar(x_28)) { - x_29 = lean_alloc_ctor(0, 6, 0); -} else { - x_29 = x_28; -} -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_4); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -lean_ctor_set(x_29, 5, x_27); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_22); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -else -{ -uint8_t x_31; -x_31 = !lean_is_exclusive(x_10); -if (x_31 == 0) -{ -lean_object* x_32; uint8_t x_33; -x_32 = lean_ctor_get(x_10, 1); -x_33 = !lean_is_exclusive(x_32); -if (x_33 == 0) -{ -lean_object* x_34; -x_34 = lean_ctor_get(x_32, 2); -lean_dec(x_34); -lean_ctor_set(x_32, 2, x_4); -return x_10; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_35 = lean_ctor_get(x_32, 0); -x_36 = lean_ctor_get(x_32, 1); -x_37 = lean_ctor_get(x_32, 3); -x_38 = lean_ctor_get(x_32, 4); -x_39 = lean_ctor_get(x_32, 5); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_dec(x_32); -x_40 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_36); -lean_ctor_set(x_40, 2, x_4); -lean_ctor_set(x_40, 3, x_37); -lean_ctor_set(x_40, 4, x_38); -lean_ctor_set(x_40, 5, x_39); -lean_ctor_set(x_10, 1, x_40); -return x_10; -} -} -else -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_41 = lean_ctor_get(x_10, 1); -x_42 = lean_ctor_get(x_10, 0); -lean_inc(x_41); -lean_inc(x_42); -lean_dec(x_10); -x_43 = lean_ctor_get(x_41, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_41, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_41, 3); -lean_inc(x_45); -x_46 = lean_ctor_get(x_41, 4); -lean_inc(x_46); -x_47 = lean_ctor_get(x_41, 5); -lean_inc(x_47); -if (lean_is_exclusive(x_41)) { - lean_ctor_release(x_41, 0); - lean_ctor_release(x_41, 1); - lean_ctor_release(x_41, 2); - lean_ctor_release(x_41, 3); - lean_ctor_release(x_41, 4); - lean_ctor_release(x_41, 5); - x_48 = x_41; -} else { - lean_dec_ref(x_41); - x_48 = lean_box(0); -} -if (lean_is_scalar(x_48)) { - x_49 = lean_alloc_ctor(0, 6, 0); -} else { - x_49 = x_48; -} -lean_ctor_set(x_49, 0, x_43); -lean_ctor_set(x_49, 1, x_44); -lean_ctor_set(x_49, 2, x_4); -lean_ctor_set(x_49, 3, x_45); -lean_ctor_set(x_49, 4, x_46); -lean_ctor_set(x_49, 5, x_47); -x_50 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_50, 0, x_42); -lean_ctor_set(x_50, 1, x_49); -return x_50; -} -} -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_nat_dec_eq(x_5, x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_sub(x_5, x_11); -lean_dec(x_5); -x_13 = lean_nat_sub(x_4, x_12); -x_14 = lean_nat_sub(x_13, x_11); -lean_dec(x_13); -x_15 = lean_ctor_get(x_7, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_7, 1); -lean_inc(x_16); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -x_18 = !lean_is_exclusive(x_15); -if (x_18 == 0) -{ -uint8_t x_19; lean_object* x_20; uint8_t x_21; lean_object* x_22; -x_19 = 1; -lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 4, x_19); -lean_inc(x_16); -x_20 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_20, 0, x_15); -lean_ctor_set(x_20, 1, x_16); -lean_ctor_set(x_20, 2, x_17); -x_21 = 0; -lean_inc(x_6); -x_22 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_21, x_6, x_6, x_20, x_8); -lean_dec(x_6); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -if (lean_obj_tag(x_23) == 7) -{ -lean_object* x_24; lean_object* x_25; uint8_t x_26; -lean_dec(x_16); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_ctor_get(x_23, 2); -lean_inc(x_25); -lean_dec(x_23); -x_26 = l_Lean_Expr_hasLooseBVars(x_25); -if (x_26 == 0) -{ -lean_dec(x_14); -x_5 = x_12; -x_6 = x_25; -x_8 = x_24; -goto _start; -} -else -{ -lean_object* x_28; lean_object* x_29; -lean_inc(x_3); -lean_inc(x_1); -x_28 = l_Lean_mkProj(x_1, x_14, x_3); -x_29 = lean_expr_instantiate1(x_25, x_28); -lean_dec(x_28); -lean_dec(x_25); -x_5 = x_12; -x_6 = x_29; -x_8 = x_24; -goto _start; -} -} -else -{ -uint8_t x_31; -lean_dec(x_23); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -x_31 = !lean_is_exclusive(x_22); -if (x_31 == 0) -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_32 = lean_ctor_get(x_22, 1); -x_33 = lean_ctor_get(x_22, 0); -lean_dec(x_33); -x_34 = lean_ctor_get(x_32, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_32, 1); -lean_inc(x_35); -x_36 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_36, 0, x_34); -lean_ctor_set(x_36, 1, x_35); -lean_ctor_set(x_36, 2, x_16); -x_37 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_37, 0, x_1); -lean_ctor_set(x_37, 1, x_2); -lean_ctor_set(x_37, 2, x_3); -lean_ctor_set(x_37, 3, x_36); -lean_ctor_set_tag(x_22, 1); -lean_ctor_set(x_22, 0, x_37); -return x_22; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_22, 1); -lean_inc(x_38); -lean_dec(x_22); -x_39 = lean_ctor_get(x_38, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_38, 1); -lean_inc(x_40); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -lean_ctor_set(x_41, 2, x_16); -x_42 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_42, 0, x_1); -lean_ctor_set(x_42, 1, x_2); -lean_ctor_set(x_42, 2, x_3); -lean_ctor_set(x_42, 3, x_41); -x_43 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_43, 0, x_42); -lean_ctor_set(x_43, 1, x_38); -return x_43; -} -} -} -else -{ -uint8_t x_44; -lean_dec(x_16); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_44 = !lean_is_exclusive(x_22); -if (x_44 == 0) -{ -return x_22; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_22, 0); -x_46 = lean_ctor_get(x_22, 1); -lean_inc(x_46); -lean_inc(x_45); -lean_dec(x_22); -x_47 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_47, 0, x_45); -lean_ctor_set(x_47, 1, x_46); -return x_47; -} -} -} -else -{ -lean_object* x_48; uint8_t x_49; uint8_t x_50; uint8_t x_51; uint8_t x_52; uint8_t x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; lean_object* x_57; -x_48 = lean_ctor_get(x_15, 0); -x_49 = lean_ctor_get_uint8(x_15, sizeof(void*)*1); -x_50 = lean_ctor_get_uint8(x_15, sizeof(void*)*1 + 1); -x_51 = lean_ctor_get_uint8(x_15, sizeof(void*)*1 + 2); -x_52 = lean_ctor_get_uint8(x_15, sizeof(void*)*1 + 3); -lean_inc(x_48); -lean_dec(x_15); -x_53 = 1; -x_54 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_54, 0, x_48); -lean_ctor_set_uint8(x_54, sizeof(void*)*1, x_49); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 1, x_50); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 2, x_51); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 3, x_52); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 4, x_53); -lean_inc(x_16); -x_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_16); -lean_ctor_set(x_55, 2, x_17); -x_56 = 0; -lean_inc(x_6); -x_57 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_56, x_6, x_6, x_55, x_8); -lean_dec(x_6); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -if (lean_obj_tag(x_58) == 7) -{ -lean_object* x_59; lean_object* x_60; uint8_t x_61; -lean_dec(x_16); -x_59 = lean_ctor_get(x_57, 1); -lean_inc(x_59); -lean_dec(x_57); -x_60 = lean_ctor_get(x_58, 2); -lean_inc(x_60); -lean_dec(x_58); -x_61 = l_Lean_Expr_hasLooseBVars(x_60); -if (x_61 == 0) -{ -lean_dec(x_14); -x_5 = x_12; -x_6 = x_60; -x_8 = x_59; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; -lean_inc(x_3); -lean_inc(x_1); -x_63 = l_Lean_mkProj(x_1, x_14, x_3); -x_64 = lean_expr_instantiate1(x_60, x_63); -lean_dec(x_63); -lean_dec(x_60); -x_5 = x_12; -x_6 = x_64; -x_8 = x_59; -goto _start; -} -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -lean_dec(x_58); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -x_66 = lean_ctor_get(x_57, 1); -lean_inc(x_66); -if (lean_is_exclusive(x_57)) { - lean_ctor_release(x_57, 0); - lean_ctor_release(x_57, 1); - x_67 = x_57; -} else { - lean_dec_ref(x_57); - x_67 = lean_box(0); -} -x_68 = lean_ctor_get(x_66, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_66, 1); -lean_inc(x_69); -x_70 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -lean_ctor_set(x_70, 2, x_16); -x_71 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_71, 0, x_1); -lean_ctor_set(x_71, 1, x_2); -lean_ctor_set(x_71, 2, x_3); -lean_ctor_set(x_71, 3, x_70); -if (lean_is_scalar(x_67)) { - x_72 = lean_alloc_ctor(1, 2, 0); -} else { - x_72 = x_67; - lean_ctor_set_tag(x_72, 1); -} -lean_ctor_set(x_72, 0, x_71); -lean_ctor_set(x_72, 1, x_66); -return x_72; -} -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -lean_dec(x_16); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_73 = lean_ctor_get(x_57, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_57, 1); -lean_inc(x_74); -if (lean_is_exclusive(x_57)) { - lean_ctor_release(x_57, 0); - lean_ctor_release(x_57, 1); - x_75 = x_57; -} else { - lean_dec_ref(x_57); - x_75 = lean_box(0); -} -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(1, 2, 0); -} else { - x_76 = x_75; -} -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -return x_76; -} -} -} -else -{ -lean_object* x_77; -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_6); -lean_ctor_set(x_77, 1, x_8); -return x_77; -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___at_Lean_Meta_isProp___spec__23(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -lean_inc(x_4); -lean_inc(x_3); -x_6 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_3, x_4, x_5); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_7 = lean_ctor_get(x_4, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_6, 1); -lean_inc(x_9); -lean_dec(x_6); -x_10 = lean_ctor_get(x_4, 1); -lean_inc(x_10); -x_11 = lean_ctor_get(x_4, 2); -lean_inc(x_11); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -uint8_t x_13; lean_object* x_14; uint8_t x_15; lean_object* x_16; -x_13 = 1; -lean_ctor_set_uint8(x_7, sizeof(void*)*1 + 4, x_13); -lean_inc(x_10); -x_14 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_14, 0, x_7); -lean_ctor_set(x_14, 1, x_10); -lean_ctor_set(x_14, 2, x_11); -x_15 = 0; -lean_inc(x_14); -lean_inc(x_8); -x_16 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_15, x_8, x_8, x_14, x_9); -lean_dec(x_8); -if (lean_obj_tag(x_16) == 0) -{ -uint8_t x_17; -x_17 = !lean_is_exclusive(x_16); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_16, 1); -x_19 = lean_ctor_get(x_16, 0); -x_20 = lean_ctor_get(x_18, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -x_22 = l_Lean_Expr_getAppFn___main(x_19); -if (lean_obj_tag(x_22) == 4) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -lean_inc(x_20); -x_25 = lean_environment_find(x_20, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; lean_object* x_27; -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_26 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_26, 0, x_20); -lean_ctor_set(x_26, 1, x_21); -lean_ctor_set(x_26, 2, x_10); -x_27 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_27, 0, x_1); -lean_ctor_set(x_27, 1, x_2); -lean_ctor_set(x_27, 2, x_3); -lean_ctor_set(x_27, 3, x_26); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_27); -return x_16; -} -else -{ -lean_object* x_28; -x_28 = lean_ctor_get(x_25, 0); -lean_inc(x_28); -lean_dec(x_25); -if (lean_obj_tag(x_28) == 5) -{ -lean_object* x_29; lean_object* x_30; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -lean_dec(x_28); -x_30 = lean_ctor_get(x_29, 4); -lean_inc(x_30); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; -lean_dec(x_29); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_31 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_31, 0, x_20); -lean_ctor_set(x_31, 1, x_21); -lean_ctor_set(x_31, 2, x_10); -x_32 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_32, 0, x_1); -lean_ctor_set(x_32, 1, x_2); -lean_ctor_set(x_32, 2, x_3); -lean_ctor_set(x_32, 3, x_31); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_32); -return x_16; -} -else -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_30, 1); -lean_inc(x_33); -if (lean_obj_tag(x_33) == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_34 = lean_ctor_get(x_29, 1); -lean_inc(x_34); -lean_dec(x_29); -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -lean_dec(x_30); -x_36 = lean_unsigned_to_nat(0u); -x_37 = l_Lean_Expr_getAppNumArgsAux___main(x_19, x_36); -x_38 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_37); -x_39 = lean_mk_array(x_37, x_38); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_sub(x_37, x_40); -lean_dec(x_37); -x_42 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_19, x_39, x_41); -x_43 = lean_array_get_size(x_42); -x_44 = lean_nat_dec_eq(x_34, x_43); -lean_dec(x_43); -lean_dec(x_34); -if (x_44 == 0) -{ -lean_object* x_45; lean_object* x_46; -lean_dec(x_42); -lean_dec(x_35); -lean_dec(x_24); -lean_dec(x_14); -lean_dec(x_4); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_20); -lean_ctor_set(x_45, 1, x_21); -lean_ctor_set(x_45, 2, x_10); -x_46 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_46, 0, x_1); -lean_ctor_set(x_46, 1, x_2); -lean_ctor_set(x_46, 2, x_3); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_46); -return x_16; -} -else -{ -lean_object* x_47; -lean_inc(x_35); -lean_inc(x_20); -x_47 = lean_environment_find(x_20, x_35); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; -lean_dec(x_42); -lean_dec(x_35); -lean_dec(x_24); -lean_dec(x_14); -lean_dec(x_4); -x_48 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_48, 0, x_20); -lean_ctor_set(x_48, 1, x_21); -lean_ctor_set(x_48, 2, x_10); -x_49 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_49, 0, x_1); -lean_ctor_set(x_49, 1, x_2); -lean_ctor_set(x_49, 2, x_3); -lean_ctor_set(x_49, 3, x_48); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_49); -return x_16; -} -else -{ -lean_object* x_50; lean_object* x_51; -lean_dec(x_47); -lean_dec(x_21); -lean_dec(x_20); -lean_free_object(x_16); -x_50 = l_Lean_mkConst(x_35, x_24); -lean_inc(x_4); -x_51 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_isProp___spec__14(x_50, x_42, x_4, x_18); -if (lean_obj_tag(x_51) == 0) -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -lean_dec(x_51); -lean_inc(x_3); -lean_inc_n(x_2, 2); -lean_inc(x_1); -x_54 = l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24(x_1, x_2, x_3, x_2, x_2, x_52, x_4, x_53); -if (lean_obj_tag(x_54) == 0) -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_54, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_54, 1); -lean_inc(x_56); -lean_dec(x_54); -lean_inc(x_55); -x_57 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_15, x_55, x_55, x_14, x_56); -lean_dec(x_55); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -if (lean_obj_tag(x_58) == 7) -{ -uint8_t x_59; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_59 = !lean_is_exclusive(x_57); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; -x_60 = lean_ctor_get(x_57, 0); -lean_dec(x_60); -x_61 = lean_ctor_get(x_58, 1); -lean_inc(x_61); -lean_dec(x_58); -lean_ctor_set(x_57, 0, x_61); -return x_57; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_62 = lean_ctor_get(x_57, 1); -lean_inc(x_62); -lean_dec(x_57); -x_63 = lean_ctor_get(x_58, 1); -lean_inc(x_63); -lean_dec(x_58); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_63); -lean_ctor_set(x_64, 1, x_62); -return x_64; -} -} -else -{ -uint8_t x_65; -lean_dec(x_58); -x_65 = !lean_is_exclusive(x_57); -if (x_65 == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_57, 1); -x_67 = lean_ctor_get(x_57, 0); -lean_dec(x_67); -x_68 = lean_ctor_get(x_66, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_66, 1); -lean_inc(x_69); -x_70 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -lean_ctor_set(x_70, 2, x_10); -x_71 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_71, 0, x_1); -lean_ctor_set(x_71, 1, x_2); -lean_ctor_set(x_71, 2, x_3); -lean_ctor_set(x_71, 3, x_70); -lean_ctor_set_tag(x_57, 1); -lean_ctor_set(x_57, 0, x_71); -return x_57; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_72 = lean_ctor_get(x_57, 1); -lean_inc(x_72); -lean_dec(x_57); -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_72, 1); -lean_inc(x_74); -x_75 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -lean_ctor_set(x_75, 2, x_10); -x_76 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_76, 0, x_1); -lean_ctor_set(x_76, 1, x_2); -lean_ctor_set(x_76, 2, x_3); -lean_ctor_set(x_76, 3, x_75); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_72); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_78 = !lean_is_exclusive(x_57); -if (x_78 == 0) -{ -return x_57; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_57, 0); -x_80 = lean_ctor_get(x_57, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_57); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -else -{ -uint8_t x_82; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_82 = !lean_is_exclusive(x_54); -if (x_82 == 0) -{ -return x_54; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_54, 0); -x_84 = lean_ctor_get(x_54, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_54); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; -} -} -} -else -{ -uint8_t x_86; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_86 = !lean_is_exclusive(x_51); -if (x_86 == 0) -{ -return x_51; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_51, 0); -x_88 = lean_ctor_get(x_51, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_51); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} -} -} -} -} -else -{ -lean_object* x_90; lean_object* x_91; -lean_dec(x_33); -lean_dec(x_30); -lean_dec(x_29); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_90 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_90, 0, x_20); -lean_ctor_set(x_90, 1, x_21); -lean_ctor_set(x_90, 2, x_10); -x_91 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_91, 0, x_1); -lean_ctor_set(x_91, 1, x_2); -lean_ctor_set(x_91, 2, x_3); -lean_ctor_set(x_91, 3, x_90); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_91); -return x_16; -} -} -} -else -{ -lean_object* x_92; lean_object* x_93; -lean_dec(x_28); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_92 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_92, 0, x_20); -lean_ctor_set(x_92, 1, x_21); -lean_ctor_set(x_92, 2, x_10); -x_93 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_93, 0, x_1); -lean_ctor_set(x_93, 1, x_2); -lean_ctor_set(x_93, 2, x_3); -lean_ctor_set(x_93, 3, x_92); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_93); -return x_16; -} -} -} -else -{ -lean_object* x_94; lean_object* x_95; -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_4); -x_94 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_94, 0, x_20); -lean_ctor_set(x_94, 1, x_21); -lean_ctor_set(x_94, 2, x_10); -x_95 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_95, 0, x_1); -lean_ctor_set(x_95, 1, x_2); -lean_ctor_set(x_95, 2, x_3); -lean_ctor_set(x_95, 3, x_94); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_95); -return x_16; -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_96 = lean_ctor_get(x_16, 1); -x_97 = lean_ctor_get(x_16, 0); -lean_inc(x_96); -lean_inc(x_97); -lean_dec(x_16); -x_98 = lean_ctor_get(x_96, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_96, 1); -lean_inc(x_99); -x_100 = l_Lean_Expr_getAppFn___main(x_97); -if (lean_obj_tag(x_100) == 4) -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -lean_inc(x_98); -x_103 = lean_environment_find(x_98, x_101); -if (lean_obj_tag(x_103) == 0) -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_104 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_104, 0, x_98); -lean_ctor_set(x_104, 1, x_99); -lean_ctor_set(x_104, 2, x_10); -x_105 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_105, 0, x_1); -lean_ctor_set(x_105, 1, x_2); -lean_ctor_set(x_105, 2, x_3); -lean_ctor_set(x_105, 3, x_104); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_105); -lean_ctor_set(x_106, 1, x_96); -return x_106; -} -else -{ -lean_object* x_107; -x_107 = lean_ctor_get(x_103, 0); -lean_inc(x_107); -lean_dec(x_103); -if (lean_obj_tag(x_107) == 5) -{ -lean_object* x_108; lean_object* x_109; -x_108 = lean_ctor_get(x_107, 0); -lean_inc(x_108); -lean_dec(x_107); -x_109 = lean_ctor_get(x_108, 4); -lean_inc(x_109); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -lean_dec(x_108); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_110 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_110, 0, x_98); -lean_ctor_set(x_110, 1, x_99); -lean_ctor_set(x_110, 2, x_10); -x_111 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_111, 0, x_1); -lean_ctor_set(x_111, 1, x_2); -lean_ctor_set(x_111, 2, x_3); -lean_ctor_set(x_111, 3, x_110); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_111); -lean_ctor_set(x_112, 1, x_96); -return x_112; -} -else -{ -lean_object* x_113; -x_113 = lean_ctor_get(x_109, 1); -lean_inc(x_113); -if (lean_obj_tag(x_113) == 0) -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; uint8_t x_124; -x_114 = lean_ctor_get(x_108, 1); -lean_inc(x_114); -lean_dec(x_108); -x_115 = lean_ctor_get(x_109, 0); -lean_inc(x_115); -lean_dec(x_109); -x_116 = lean_unsigned_to_nat(0u); -x_117 = l_Lean_Expr_getAppNumArgsAux___main(x_97, x_116); -x_118 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_117); -x_119 = lean_mk_array(x_117, x_118); -x_120 = lean_unsigned_to_nat(1u); -x_121 = lean_nat_sub(x_117, x_120); -lean_dec(x_117); -x_122 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_97, x_119, x_121); -x_123 = lean_array_get_size(x_122); -x_124 = lean_nat_dec_eq(x_114, x_123); -lean_dec(x_123); -lean_dec(x_114); -if (x_124 == 0) -{ -lean_object* x_125; lean_object* x_126; lean_object* x_127; -lean_dec(x_122); -lean_dec(x_115); -lean_dec(x_102); -lean_dec(x_14); -lean_dec(x_4); -x_125 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_125, 0, x_98); -lean_ctor_set(x_125, 1, x_99); -lean_ctor_set(x_125, 2, x_10); -x_126 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_126, 0, x_1); -lean_ctor_set(x_126, 1, x_2); -lean_ctor_set(x_126, 2, x_3); -lean_ctor_set(x_126, 3, x_125); -x_127 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_127, 0, x_126); -lean_ctor_set(x_127, 1, x_96); -return x_127; -} -else -{ -lean_object* x_128; -lean_inc(x_115); -lean_inc(x_98); -x_128 = lean_environment_find(x_98, x_115); -if (lean_obj_tag(x_128) == 0) -{ -lean_object* x_129; lean_object* x_130; lean_object* x_131; -lean_dec(x_122); -lean_dec(x_115); -lean_dec(x_102); -lean_dec(x_14); -lean_dec(x_4); -x_129 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_129, 0, x_98); -lean_ctor_set(x_129, 1, x_99); -lean_ctor_set(x_129, 2, x_10); -x_130 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_130, 0, x_1); -lean_ctor_set(x_130, 1, x_2); -lean_ctor_set(x_130, 2, x_3); -lean_ctor_set(x_130, 3, x_129); -x_131 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_131, 0, x_130); -lean_ctor_set(x_131, 1, x_96); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; -lean_dec(x_128); -lean_dec(x_99); -lean_dec(x_98); -x_132 = l_Lean_mkConst(x_115, x_102); -lean_inc(x_4); -x_133 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_isProp___spec__14(x_132, x_122, x_4, x_96); -if (lean_obj_tag(x_133) == 0) -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_134 = lean_ctor_get(x_133, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_133, 1); -lean_inc(x_135); -lean_dec(x_133); -lean_inc(x_3); -lean_inc_n(x_2, 2); -lean_inc(x_1); -x_136 = l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24(x_1, x_2, x_3, x_2, x_2, x_134, x_4, x_135); -if (lean_obj_tag(x_136) == 0) -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_137 = lean_ctor_get(x_136, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_136, 1); -lean_inc(x_138); -lean_dec(x_136); -lean_inc(x_137); -x_139 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_15, x_137, x_137, x_14, x_138); -lean_dec(x_137); -if (lean_obj_tag(x_139) == 0) -{ -lean_object* x_140; -x_140 = lean_ctor_get(x_139, 0); -lean_inc(x_140); -if (lean_obj_tag(x_140) == 7) -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_141 = lean_ctor_get(x_139, 1); -lean_inc(x_141); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_142 = x_139; -} else { - lean_dec_ref(x_139); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_140, 1); -lean_inc(x_143); -lean_dec(x_140); -if (lean_is_scalar(x_142)) { - x_144 = lean_alloc_ctor(0, 2, 0); -} else { - x_144 = x_142; -} -lean_ctor_set(x_144, 0, x_143); -lean_ctor_set(x_144, 1, x_141); -return x_144; -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -lean_dec(x_140); -x_145 = lean_ctor_get(x_139, 1); -lean_inc(x_145); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_146 = x_139; -} else { - lean_dec_ref(x_139); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_145, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_145, 1); -lean_inc(x_148); -x_149 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_149, 0, x_147); -lean_ctor_set(x_149, 1, x_148); -lean_ctor_set(x_149, 2, x_10); -x_150 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_150, 0, x_1); -lean_ctor_set(x_150, 1, x_2); -lean_ctor_set(x_150, 2, x_3); -lean_ctor_set(x_150, 3, x_149); -if (lean_is_scalar(x_146)) { - x_151 = lean_alloc_ctor(1, 2, 0); -} else { - x_151 = x_146; - lean_ctor_set_tag(x_151, 1); -} -lean_ctor_set(x_151, 0, x_150); -lean_ctor_set(x_151, 1, x_145); -return x_151; -} -} -else -{ -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_152 = lean_ctor_get(x_139, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_139, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_154 = x_139; -} else { - lean_dec_ref(x_139); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -return x_155; -} -} -else -{ -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_156 = lean_ctor_get(x_136, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_136, 1); -lean_inc(x_157); -if (lean_is_exclusive(x_136)) { - lean_ctor_release(x_136, 0); - lean_ctor_release(x_136, 1); - x_158 = x_136; -} else { - lean_dec_ref(x_136); - x_158 = lean_box(0); -} -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(1, 2, 0); -} else { - x_159 = x_158; -} -lean_ctor_set(x_159, 0, x_156); -lean_ctor_set(x_159, 1, x_157); -return x_159; -} -} -else -{ -lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_160 = lean_ctor_get(x_133, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_133, 1); -lean_inc(x_161); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - x_162 = x_133; -} else { - lean_dec_ref(x_133); - x_162 = lean_box(0); -} -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(1, 2, 0); -} else { - x_163 = x_162; -} -lean_ctor_set(x_163, 0, x_160); -lean_ctor_set(x_163, 1, x_161); -return x_163; -} -} -} -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_113); -lean_dec(x_109); -lean_dec(x_108); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_164 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_164, 0, x_98); -lean_ctor_set(x_164, 1, x_99); -lean_ctor_set(x_164, 2, x_10); -x_165 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_165, 0, x_1); -lean_ctor_set(x_165, 1, x_2); -lean_ctor_set(x_165, 2, x_3); -lean_ctor_set(x_165, 3, x_164); -x_166 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_166, 0, x_165); -lean_ctor_set(x_166, 1, x_96); -return x_166; -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -lean_dec(x_107); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_167 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_167, 0, x_98); -lean_ctor_set(x_167, 1, x_99); -lean_ctor_set(x_167, 2, x_10); -x_168 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_168, 0, x_1); -lean_ctor_set(x_168, 1, x_2); -lean_ctor_set(x_168, 2, x_3); -lean_ctor_set(x_168, 3, x_167); -x_169 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_169, 0, x_168); -lean_ctor_set(x_169, 1, x_96); -return x_169; -} -} -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -lean_dec(x_100); -lean_dec(x_97); -lean_dec(x_14); -lean_dec(x_4); -x_170 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_170, 0, x_98); -lean_ctor_set(x_170, 1, x_99); -lean_ctor_set(x_170, 2, x_10); -x_171 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_171, 0, x_1); -lean_ctor_set(x_171, 1, x_2); -lean_ctor_set(x_171, 2, x_3); -lean_ctor_set(x_171, 3, x_170); -x_172 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_172, 0, x_171); -lean_ctor_set(x_172, 1, x_96); -return x_172; -} -} -} -else -{ -uint8_t x_173; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_173 = !lean_is_exclusive(x_16); -if (x_173 == 0) -{ -return x_16; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_16, 0); -x_175 = lean_ctor_get(x_16, 1); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_16); -x_176 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_176, 0, x_174); -lean_ctor_set(x_176, 1, x_175); -return x_176; -} -} -} -else -{ -lean_object* x_177; uint8_t x_178; uint8_t x_179; uint8_t x_180; uint8_t x_181; uint8_t x_182; lean_object* x_183; lean_object* x_184; uint8_t x_185; lean_object* x_186; -x_177 = lean_ctor_get(x_7, 0); -x_178 = lean_ctor_get_uint8(x_7, sizeof(void*)*1); -x_179 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 1); -x_180 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 2); -x_181 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 3); -lean_inc(x_177); -lean_dec(x_7); -x_182 = 1; -x_183 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_183, 0, x_177); -lean_ctor_set_uint8(x_183, sizeof(void*)*1, x_178); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 1, x_179); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 2, x_180); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 3, x_181); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 4, x_182); -lean_inc(x_10); -x_184 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_184, 0, x_183); -lean_ctor_set(x_184, 1, x_10); -lean_ctor_set(x_184, 2, x_11); -x_185 = 0; -lean_inc(x_184); -lean_inc(x_8); -x_186 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_185, x_8, x_8, x_184, x_9); -lean_dec(x_8); -if (lean_obj_tag(x_186) == 0) -{ -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; -x_187 = lean_ctor_get(x_186, 1); -lean_inc(x_187); -x_188 = lean_ctor_get(x_186, 0); -lean_inc(x_188); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - x_189 = x_186; -} else { - lean_dec_ref(x_186); - x_189 = lean_box(0); -} -x_190 = lean_ctor_get(x_187, 0); -lean_inc(x_190); -x_191 = lean_ctor_get(x_187, 1); -lean_inc(x_191); -x_192 = l_Lean_Expr_getAppFn___main(x_188); -if (lean_obj_tag(x_192) == 4) -{ -lean_object* x_193; lean_object* x_194; lean_object* x_195; -x_193 = lean_ctor_get(x_192, 0); -lean_inc(x_193); -x_194 = lean_ctor_get(x_192, 1); -lean_inc(x_194); -lean_dec(x_192); -lean_inc(x_190); -x_195 = lean_environment_find(x_190, x_193); -if (lean_obj_tag(x_195) == 0) -{ -lean_object* x_196; lean_object* x_197; lean_object* x_198; -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_196 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_196, 0, x_190); -lean_ctor_set(x_196, 1, x_191); -lean_ctor_set(x_196, 2, x_10); -x_197 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_197, 0, x_1); -lean_ctor_set(x_197, 1, x_2); -lean_ctor_set(x_197, 2, x_3); -lean_ctor_set(x_197, 3, x_196); -if (lean_is_scalar(x_189)) { - x_198 = lean_alloc_ctor(1, 2, 0); -} else { - x_198 = x_189; - lean_ctor_set_tag(x_198, 1); -} -lean_ctor_set(x_198, 0, x_197); -lean_ctor_set(x_198, 1, x_187); -return x_198; -} -else -{ -lean_object* x_199; -x_199 = lean_ctor_get(x_195, 0); -lean_inc(x_199); -lean_dec(x_195); -if (lean_obj_tag(x_199) == 5) -{ -lean_object* x_200; lean_object* x_201; -x_200 = lean_ctor_get(x_199, 0); -lean_inc(x_200); -lean_dec(x_199); -x_201 = lean_ctor_get(x_200, 4); -lean_inc(x_201); -if (lean_obj_tag(x_201) == 0) -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; -lean_dec(x_200); -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_202 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_202, 0, x_190); -lean_ctor_set(x_202, 1, x_191); -lean_ctor_set(x_202, 2, x_10); -x_203 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_203, 0, x_1); -lean_ctor_set(x_203, 1, x_2); -lean_ctor_set(x_203, 2, x_3); -lean_ctor_set(x_203, 3, x_202); -if (lean_is_scalar(x_189)) { - x_204 = lean_alloc_ctor(1, 2, 0); -} else { - x_204 = x_189; - lean_ctor_set_tag(x_204, 1); -} -lean_ctor_set(x_204, 0, x_203); -lean_ctor_set(x_204, 1, x_187); -return x_204; -} -else -{ -lean_object* x_205; -x_205 = lean_ctor_get(x_201, 1); -lean_inc(x_205); -if (lean_obj_tag(x_205) == 0) -{ -lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; uint8_t x_216; -x_206 = lean_ctor_get(x_200, 1); -lean_inc(x_206); -lean_dec(x_200); -x_207 = lean_ctor_get(x_201, 0); -lean_inc(x_207); -lean_dec(x_201); -x_208 = lean_unsigned_to_nat(0u); -x_209 = l_Lean_Expr_getAppNumArgsAux___main(x_188, x_208); -x_210 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_209); -x_211 = lean_mk_array(x_209, x_210); -x_212 = lean_unsigned_to_nat(1u); -x_213 = lean_nat_sub(x_209, x_212); -lean_dec(x_209); -x_214 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_188, x_211, x_213); -x_215 = lean_array_get_size(x_214); -x_216 = lean_nat_dec_eq(x_206, x_215); -lean_dec(x_215); -lean_dec(x_206); -if (x_216 == 0) -{ -lean_object* x_217; lean_object* x_218; lean_object* x_219; -lean_dec(x_214); -lean_dec(x_207); -lean_dec(x_194); -lean_dec(x_184); -lean_dec(x_4); -x_217 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_217, 0, x_190); -lean_ctor_set(x_217, 1, x_191); -lean_ctor_set(x_217, 2, x_10); -x_218 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_218, 0, x_1); -lean_ctor_set(x_218, 1, x_2); -lean_ctor_set(x_218, 2, x_3); -lean_ctor_set(x_218, 3, x_217); -if (lean_is_scalar(x_189)) { - x_219 = lean_alloc_ctor(1, 2, 0); -} else { - x_219 = x_189; - lean_ctor_set_tag(x_219, 1); -} -lean_ctor_set(x_219, 0, x_218); -lean_ctor_set(x_219, 1, x_187); -return x_219; -} -else -{ -lean_object* x_220; -lean_inc(x_207); -lean_inc(x_190); -x_220 = lean_environment_find(x_190, x_207); -if (lean_obj_tag(x_220) == 0) -{ -lean_object* x_221; lean_object* x_222; lean_object* x_223; -lean_dec(x_214); -lean_dec(x_207); -lean_dec(x_194); -lean_dec(x_184); -lean_dec(x_4); -x_221 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_221, 0, x_190); -lean_ctor_set(x_221, 1, x_191); -lean_ctor_set(x_221, 2, x_10); -x_222 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_222, 0, x_1); -lean_ctor_set(x_222, 1, x_2); -lean_ctor_set(x_222, 2, x_3); -lean_ctor_set(x_222, 3, x_221); -if (lean_is_scalar(x_189)) { - x_223 = lean_alloc_ctor(1, 2, 0); -} else { - x_223 = x_189; - lean_ctor_set_tag(x_223, 1); -} -lean_ctor_set(x_223, 0, x_222); -lean_ctor_set(x_223, 1, x_187); -return x_223; -} -else -{ -lean_object* x_224; lean_object* x_225; -lean_dec(x_220); -lean_dec(x_191); -lean_dec(x_190); -lean_dec(x_189); -x_224 = l_Lean_mkConst(x_207, x_194); -lean_inc(x_4); -x_225 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_isProp___spec__14(x_224, x_214, x_4, x_187); -if (lean_obj_tag(x_225) == 0) -{ -lean_object* x_226; lean_object* x_227; lean_object* x_228; -x_226 = lean_ctor_get(x_225, 0); -lean_inc(x_226); -x_227 = lean_ctor_get(x_225, 1); -lean_inc(x_227); -lean_dec(x_225); -lean_inc(x_3); -lean_inc_n(x_2, 2); -lean_inc(x_1); -x_228 = l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24(x_1, x_2, x_3, x_2, x_2, x_226, x_4, x_227); -if (lean_obj_tag(x_228) == 0) -{ -lean_object* x_229; lean_object* x_230; lean_object* x_231; -x_229 = lean_ctor_get(x_228, 0); -lean_inc(x_229); -x_230 = lean_ctor_get(x_228, 1); -lean_inc(x_230); -lean_dec(x_228); -lean_inc(x_229); -x_231 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_185, x_229, x_229, x_184, x_230); -lean_dec(x_229); -if (lean_obj_tag(x_231) == 0) -{ -lean_object* x_232; -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 7) -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_234 = x_231; -} else { - lean_dec_ref(x_231); - x_234 = lean_box(0); -} -x_235 = lean_ctor_get(x_232, 1); -lean_inc(x_235); -lean_dec(x_232); -if (lean_is_scalar(x_234)) { - x_236 = lean_alloc_ctor(0, 2, 0); -} else { - x_236 = x_234; -} -lean_ctor_set(x_236, 0, x_235); -lean_ctor_set(x_236, 1, x_233); -return x_236; -} -else -{ -lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; -lean_dec(x_232); -x_237 = lean_ctor_get(x_231, 1); -lean_inc(x_237); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_238 = x_231; -} else { - lean_dec_ref(x_231); - x_238 = lean_box(0); -} -x_239 = lean_ctor_get(x_237, 0); -lean_inc(x_239); -x_240 = lean_ctor_get(x_237, 1); -lean_inc(x_240); -x_241 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_241, 0, x_239); -lean_ctor_set(x_241, 1, x_240); -lean_ctor_set(x_241, 2, x_10); -x_242 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_242, 0, x_1); -lean_ctor_set(x_242, 1, x_2); -lean_ctor_set(x_242, 2, x_3); -lean_ctor_set(x_242, 3, x_241); -if (lean_is_scalar(x_238)) { - x_243 = lean_alloc_ctor(1, 2, 0); -} else { - x_243 = x_238; - lean_ctor_set_tag(x_243, 1); -} -lean_ctor_set(x_243, 0, x_242); -lean_ctor_set(x_243, 1, x_237); -return x_243; -} -} -else -{ -lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_244 = lean_ctor_get(x_231, 0); -lean_inc(x_244); -x_245 = lean_ctor_get(x_231, 1); -lean_inc(x_245); -if (lean_is_exclusive(x_231)) { - lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - x_246 = x_231; -} else { - lean_dec_ref(x_231); - x_246 = lean_box(0); -} -if (lean_is_scalar(x_246)) { - x_247 = lean_alloc_ctor(1, 2, 0); -} else { - x_247 = x_246; -} -lean_ctor_set(x_247, 0, x_244); -lean_ctor_set(x_247, 1, x_245); -return x_247; -} -} -else -{ -lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; -lean_dec(x_184); -lean_dec(x_10); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_248 = lean_ctor_get(x_228, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_228, 1); -lean_inc(x_249); -if (lean_is_exclusive(x_228)) { - lean_ctor_release(x_228, 0); - lean_ctor_release(x_228, 1); - x_250 = x_228; -} else { - lean_dec_ref(x_228); - x_250 = lean_box(0); -} -if (lean_is_scalar(x_250)) { - x_251 = lean_alloc_ctor(1, 2, 0); -} else { - x_251 = x_250; -} -lean_ctor_set(x_251, 0, x_248); -lean_ctor_set(x_251, 1, x_249); -return x_251; -} -} -else -{ -lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; -lean_dec(x_184); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_252 = lean_ctor_get(x_225, 0); -lean_inc(x_252); -x_253 = lean_ctor_get(x_225, 1); -lean_inc(x_253); -if (lean_is_exclusive(x_225)) { - lean_ctor_release(x_225, 0); - lean_ctor_release(x_225, 1); - x_254 = x_225; -} else { - lean_dec_ref(x_225); - x_254 = lean_box(0); -} -if (lean_is_scalar(x_254)) { - x_255 = lean_alloc_ctor(1, 2, 0); -} else { - x_255 = x_254; -} -lean_ctor_set(x_255, 0, x_252); -lean_ctor_set(x_255, 1, x_253); -return x_255; -} -} -} -} -else -{ -lean_object* x_256; lean_object* x_257; lean_object* x_258; -lean_dec(x_205); -lean_dec(x_201); -lean_dec(x_200); -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_256 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_256, 0, x_190); -lean_ctor_set(x_256, 1, x_191); -lean_ctor_set(x_256, 2, x_10); -x_257 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_257, 0, x_1); -lean_ctor_set(x_257, 1, x_2); -lean_ctor_set(x_257, 2, x_3); -lean_ctor_set(x_257, 3, x_256); -if (lean_is_scalar(x_189)) { - x_258 = lean_alloc_ctor(1, 2, 0); -} else { - x_258 = x_189; - lean_ctor_set_tag(x_258, 1); -} -lean_ctor_set(x_258, 0, x_257); -lean_ctor_set(x_258, 1, x_187); -return x_258; -} -} -} -else -{ -lean_object* x_259; lean_object* x_260; lean_object* x_261; -lean_dec(x_199); -lean_dec(x_194); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_259 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_259, 0, x_190); -lean_ctor_set(x_259, 1, x_191); -lean_ctor_set(x_259, 2, x_10); -x_260 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_260, 0, x_1); -lean_ctor_set(x_260, 1, x_2); -lean_ctor_set(x_260, 2, x_3); -lean_ctor_set(x_260, 3, x_259); -if (lean_is_scalar(x_189)) { - x_261 = lean_alloc_ctor(1, 2, 0); -} else { - x_261 = x_189; - lean_ctor_set_tag(x_261, 1); -} -lean_ctor_set(x_261, 0, x_260); -lean_ctor_set(x_261, 1, x_187); -return x_261; -} -} -} -else -{ -lean_object* x_262; lean_object* x_263; lean_object* x_264; -lean_dec(x_192); -lean_dec(x_188); -lean_dec(x_184); -lean_dec(x_4); -x_262 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_262, 0, x_190); -lean_ctor_set(x_262, 1, x_191); -lean_ctor_set(x_262, 2, x_10); -x_263 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_263, 0, x_1); -lean_ctor_set(x_263, 1, x_2); -lean_ctor_set(x_263, 2, x_3); -lean_ctor_set(x_263, 3, x_262); -if (lean_is_scalar(x_189)) { - x_264 = lean_alloc_ctor(1, 2, 0); -} else { - x_264 = x_189; - lean_ctor_set_tag(x_264, 1); -} -lean_ctor_set(x_264, 0, x_263); -lean_ctor_set(x_264, 1, x_187); -return x_264; -} -} -else -{ -lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; -lean_dec(x_184); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_265 = lean_ctor_get(x_186, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_186, 1); -lean_inc(x_266); -if (lean_is_exclusive(x_186)) { - lean_ctor_release(x_186, 0); - lean_ctor_release(x_186, 1); - x_267 = x_186; -} else { - lean_dec_ref(x_186); - x_267 = lean_box(0); -} -if (lean_is_scalar(x_267)) { - x_268 = lean_alloc_ctor(1, 2, 0); -} else { - x_268 = x_267; -} -lean_ctor_set(x_268, 0, x_265); -lean_ctor_set(x_268, 1, x_266); -return x_268; -} -} -} -else -{ -uint8_t x_269; -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_269 = !lean_is_exclusive(x_6); -if (x_269 == 0) -{ -return x_6; -} -else -{ -lean_object* x_270; lean_object* x_271; lean_object* x_272; -x_270 = lean_ctor_get(x_6, 0); -x_271 = lean_ctor_get(x_6, 1); -lean_inc(x_271); -lean_inc(x_270); -lean_dec(x_6); -x_272 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_272, 0, x_270); -lean_ctor_set(x_272, 1, x_271); -return x_272; -} -} -} -} -lean_object* l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -switch (lean_obj_tag(x_1)) { -case 0: -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -lean_dec(x_2); -x_55 = lean_ctor_get(x_1, 0); -lean_inc(x_55); -lean_dec(x_1); -x_56 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_56, 0, x_55); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_56); -lean_ctor_set(x_57, 1, x_3); -return x_57; -} -case 1: -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_1, 0); -lean_inc(x_58); -lean_dec(x_1); -x_59 = l___private_Init_Lean_Meta_InferType_8__inferFVarType(x_58, x_2, x_3); -return x_59; -} -case 2: -{ -lean_object* x_60; lean_object* x_61; -x_60 = lean_ctor_get(x_1, 0); -lean_inc(x_60); -lean_dec(x_1); -x_61 = l___private_Init_Lean_Meta_InferType_7__inferMVarType(x_60, x_2, x_3); -lean_dec(x_2); -return x_61; -} -case 3: -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -lean_dec(x_2); -x_62 = lean_ctor_get(x_1, 0); -lean_inc(x_62); -lean_dec(x_1); -x_63 = l_Lean_mkLevelSucc(x_62); -x_64 = l_Lean_mkSort(x_63); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_64); -lean_ctor_set(x_65, 1, x_3); -return x_65; -} -case 4: -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_1, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_1, 1); -lean_inc(x_67); -lean_dec(x_1); -x_68 = l___private_Init_Lean_Meta_InferType_2__inferConstType(x_66, x_67, x_2, x_3); -lean_dec(x_2); -return x_68; -} -case 5: -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_69 = lean_ctor_get(x_1, 0); -lean_inc(x_69); -x_70 = l_Lean_Expr_getAppFn___main(x_69); -lean_dec(x_69); -x_71 = lean_unsigned_to_nat(0u); -x_72 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_71); -x_73 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_72); -x_74 = lean_mk_array(x_72, x_73); -x_75 = lean_unsigned_to_nat(1u); -x_76 = lean_nat_sub(x_72, x_75); -lean_dec(x_72); -lean_inc(x_1); -x_77 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_74, x_76); -x_78 = lean_ctor_get(x_3, 2); -lean_inc(x_78); -x_79 = lean_ctor_get(x_78, 0); -lean_inc(x_79); -lean_dec(x_78); -x_80 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_79, x_1); -lean_dec(x_79); -if (lean_obj_tag(x_80) == 0) -{ -lean_object* x_81; -x_81 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_isProp___spec__14(x_70, x_77, x_2, x_3); -if (lean_obj_tag(x_81) == 0) -{ -lean_object* x_82; lean_object* x_83; uint8_t x_84; -x_82 = lean_ctor_get(x_81, 1); -lean_inc(x_82); -x_83 = lean_ctor_get(x_82, 2); -lean_inc(x_83); -x_84 = !lean_is_exclusive(x_81); -if (x_84 == 0) -{ -lean_object* x_85; lean_object* x_86; uint8_t x_87; -x_85 = lean_ctor_get(x_81, 0); -x_86 = lean_ctor_get(x_81, 1); -lean_dec(x_86); -x_87 = !lean_is_exclusive(x_82); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; -x_88 = lean_ctor_get(x_82, 2); -lean_dec(x_88); -x_89 = !lean_is_exclusive(x_83); -if (x_89 == 0) -{ -lean_object* x_90; lean_object* x_91; -x_90 = lean_ctor_get(x_83, 0); -lean_inc(x_85); -x_91 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_90, x_1, x_85); -lean_ctor_set(x_83, 0, x_91); -return x_81; -} -else -{ -lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_92 = lean_ctor_get(x_83, 0); -x_93 = lean_ctor_get(x_83, 1); -lean_inc(x_93); -lean_inc(x_92); -lean_dec(x_83); -lean_inc(x_85); -x_94 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_92, x_1, x_85); -x_95 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_95, 0, x_94); -lean_ctor_set(x_95, 1, x_93); -lean_ctor_set(x_82, 2, x_95); -return x_81; -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_96 = lean_ctor_get(x_82, 0); -x_97 = lean_ctor_get(x_82, 1); -x_98 = lean_ctor_get(x_82, 3); -x_99 = lean_ctor_get(x_82, 4); -x_100 = lean_ctor_get(x_82, 5); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_82); -x_101 = lean_ctor_get(x_83, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_83, 1); -lean_inc(x_102); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - x_103 = x_83; -} else { - lean_dec_ref(x_83); - x_103 = lean_box(0); -} -lean_inc(x_85); -x_104 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_101, x_1, x_85); -if (lean_is_scalar(x_103)) { - x_105 = lean_alloc_ctor(0, 2, 0); -} else { - x_105 = x_103; -} -lean_ctor_set(x_105, 0, x_104); -lean_ctor_set(x_105, 1, x_102); -x_106 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_106, 0, x_96); -lean_ctor_set(x_106, 1, x_97); -lean_ctor_set(x_106, 2, x_105); -lean_ctor_set(x_106, 3, x_98); -lean_ctor_set(x_106, 4, x_99); -lean_ctor_set(x_106, 5, x_100); -lean_ctor_set(x_81, 1, x_106); -return x_81; -} -} -else -{ -lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_107 = lean_ctor_get(x_81, 0); -lean_inc(x_107); -lean_dec(x_81); -x_108 = lean_ctor_get(x_82, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_82, 1); -lean_inc(x_109); -x_110 = lean_ctor_get(x_82, 3); -lean_inc(x_110); -x_111 = lean_ctor_get(x_82, 4); -lean_inc(x_111); -x_112 = lean_ctor_get(x_82, 5); -lean_inc(x_112); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - lean_ctor_release(x_82, 2); - lean_ctor_release(x_82, 3); - lean_ctor_release(x_82, 4); - lean_ctor_release(x_82, 5); - x_113 = x_82; -} else { - lean_dec_ref(x_82); - x_113 = lean_box(0); -} -x_114 = lean_ctor_get(x_83, 0); -lean_inc(x_114); -x_115 = lean_ctor_get(x_83, 1); -lean_inc(x_115); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - x_116 = x_83; -} else { - lean_dec_ref(x_83); - x_116 = lean_box(0); -} -lean_inc(x_107); -x_117 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_114, x_1, x_107); -if (lean_is_scalar(x_116)) { - x_118 = lean_alloc_ctor(0, 2, 0); -} else { - x_118 = x_116; -} -lean_ctor_set(x_118, 0, x_117); -lean_ctor_set(x_118, 1, x_115); -if (lean_is_scalar(x_113)) { - x_119 = lean_alloc_ctor(0, 6, 0); -} else { - x_119 = x_113; -} -lean_ctor_set(x_119, 0, x_108); -lean_ctor_set(x_119, 1, x_109); -lean_ctor_set(x_119, 2, x_118); -lean_ctor_set(x_119, 3, x_110); -lean_ctor_set(x_119, 4, x_111); -lean_ctor_set(x_119, 5, x_112); -x_120 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_120, 0, x_107); -lean_ctor_set(x_120, 1, x_119); -return x_120; -} -} -else -{ -uint8_t x_121; -lean_dec(x_1); -x_121 = !lean_is_exclusive(x_81); -if (x_121 == 0) -{ -return x_81; -} -else -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; -x_122 = lean_ctor_get(x_81, 0); -x_123 = lean_ctor_get(x_81, 1); -lean_inc(x_123); -lean_inc(x_122); -lean_dec(x_81); -x_124 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_124, 0, x_122); -lean_ctor_set(x_124, 1, x_123); -return x_124; -} -} -} -else -{ -lean_object* x_125; lean_object* x_126; -lean_dec(x_77); -lean_dec(x_70); -lean_dec(x_2); -lean_dec(x_1); -x_125 = lean_ctor_get(x_80, 0); -lean_inc(x_125); -lean_dec(x_80); -x_126 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_3); -return x_126; -} -} -case 7: -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; -x_127 = lean_ctor_get(x_3, 2); -lean_inc(x_127); -x_128 = lean_ctor_get(x_127, 0); -lean_inc(x_128); -lean_dec(x_127); -x_129 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_128, x_1); -lean_dec(x_128); -if (lean_obj_tag(x_129) == 0) -{ -lean_object* x_130; -lean_inc(x_1); -x_130 = l___private_Init_Lean_Meta_InferType_4__inferForallType___at_Lean_Meta_isProp___spec__16(x_1, x_2, x_3); -if (lean_obj_tag(x_130) == 0) -{ -lean_object* x_131; lean_object* x_132; uint8_t x_133; -x_131 = lean_ctor_get(x_130, 1); -lean_inc(x_131); -x_132 = lean_ctor_get(x_131, 2); -lean_inc(x_132); -x_133 = !lean_is_exclusive(x_130); -if (x_133 == 0) -{ -lean_object* x_134; lean_object* x_135; uint8_t x_136; -x_134 = lean_ctor_get(x_130, 0); -x_135 = lean_ctor_get(x_130, 1); -lean_dec(x_135); -x_136 = !lean_is_exclusive(x_131); -if (x_136 == 0) -{ -lean_object* x_137; uint8_t x_138; -x_137 = lean_ctor_get(x_131, 2); -lean_dec(x_137); -x_138 = !lean_is_exclusive(x_132); -if (x_138 == 0) -{ -lean_object* x_139; lean_object* x_140; -x_139 = lean_ctor_get(x_132, 0); -lean_inc(x_134); -x_140 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_139, x_1, x_134); -lean_ctor_set(x_132, 0, x_140); -return x_130; -} -else -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; -x_141 = lean_ctor_get(x_132, 0); -x_142 = lean_ctor_get(x_132, 1); -lean_inc(x_142); -lean_inc(x_141); -lean_dec(x_132); -lean_inc(x_134); -x_143 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_141, x_1, x_134); -x_144 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_144, 0, x_143); -lean_ctor_set(x_144, 1, x_142); -lean_ctor_set(x_131, 2, x_144); -return x_130; -} -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -x_145 = lean_ctor_get(x_131, 0); -x_146 = lean_ctor_get(x_131, 1); -x_147 = lean_ctor_get(x_131, 3); -x_148 = lean_ctor_get(x_131, 4); -x_149 = lean_ctor_get(x_131, 5); -lean_inc(x_149); -lean_inc(x_148); -lean_inc(x_147); -lean_inc(x_146); -lean_inc(x_145); -lean_dec(x_131); -x_150 = lean_ctor_get(x_132, 0); -lean_inc(x_150); -x_151 = lean_ctor_get(x_132, 1); -lean_inc(x_151); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_152 = x_132; -} else { - lean_dec_ref(x_132); - x_152 = lean_box(0); -} -lean_inc(x_134); -x_153 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_150, x_1, x_134); -if (lean_is_scalar(x_152)) { - x_154 = lean_alloc_ctor(0, 2, 0); -} else { - x_154 = x_152; -} -lean_ctor_set(x_154, 0, x_153); -lean_ctor_set(x_154, 1, x_151); -x_155 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_155, 0, x_145); -lean_ctor_set(x_155, 1, x_146); -lean_ctor_set(x_155, 2, x_154); -lean_ctor_set(x_155, 3, x_147); -lean_ctor_set(x_155, 4, x_148); -lean_ctor_set(x_155, 5, x_149); -lean_ctor_set(x_130, 1, x_155); -return x_130; -} -} -else -{ -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; -x_156 = lean_ctor_get(x_130, 0); -lean_inc(x_156); -lean_dec(x_130); -x_157 = lean_ctor_get(x_131, 0); -lean_inc(x_157); -x_158 = lean_ctor_get(x_131, 1); -lean_inc(x_158); -x_159 = lean_ctor_get(x_131, 3); -lean_inc(x_159); -x_160 = lean_ctor_get(x_131, 4); -lean_inc(x_160); -x_161 = lean_ctor_get(x_131, 5); -lean_inc(x_161); -if (lean_is_exclusive(x_131)) { - lean_ctor_release(x_131, 0); - lean_ctor_release(x_131, 1); - lean_ctor_release(x_131, 2); - lean_ctor_release(x_131, 3); - lean_ctor_release(x_131, 4); - lean_ctor_release(x_131, 5); - x_162 = x_131; -} else { - lean_dec_ref(x_131); - x_162 = lean_box(0); -} -x_163 = lean_ctor_get(x_132, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_132, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_165 = x_132; -} else { - lean_dec_ref(x_132); - x_165 = lean_box(0); -} -lean_inc(x_156); -x_166 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_163, x_1, x_156); -if (lean_is_scalar(x_165)) { - x_167 = lean_alloc_ctor(0, 2, 0); -} else { - x_167 = x_165; -} -lean_ctor_set(x_167, 0, x_166); -lean_ctor_set(x_167, 1, x_164); -if (lean_is_scalar(x_162)) { - x_168 = lean_alloc_ctor(0, 6, 0); -} else { - x_168 = x_162; -} -lean_ctor_set(x_168, 0, x_157); -lean_ctor_set(x_168, 1, x_158); -lean_ctor_set(x_168, 2, x_167); -lean_ctor_set(x_168, 3, x_159); -lean_ctor_set(x_168, 4, x_160); -lean_ctor_set(x_168, 5, x_161); -x_169 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_169, 0, x_156); -lean_ctor_set(x_169, 1, x_168); -return x_169; -} -} -else -{ -uint8_t x_170; -lean_dec(x_1); -x_170 = !lean_is_exclusive(x_130); -if (x_170 == 0) -{ -return x_130; -} -else -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; -x_171 = lean_ctor_get(x_130, 0); -x_172 = lean_ctor_get(x_130, 1); -lean_inc(x_172); -lean_inc(x_171); -lean_dec(x_130); -x_173 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_173, 0, x_171); -lean_ctor_set(x_173, 1, x_172); -return x_173; -} -} -} -else -{ -lean_object* x_174; lean_object* x_175; -lean_dec(x_2); -lean_dec(x_1); -x_174 = lean_ctor_get(x_129, 0); -lean_inc(x_174); -lean_dec(x_129); -x_175 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_175, 0, x_174); -lean_ctor_set(x_175, 1, x_3); -return x_175; -} -} -case 9: -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; -lean_dec(x_2); -x_176 = lean_ctor_get(x_1, 0); -lean_inc(x_176); -lean_dec(x_1); -x_177 = l_Lean_Literal_type(x_176); -lean_dec(x_176); -x_178 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_178, 0, x_177); -lean_ctor_set(x_178, 1, x_3); -return x_178; -} -case 10: -{ -lean_object* x_179; -x_179 = lean_ctor_get(x_1, 1); -lean_inc(x_179); -lean_dec(x_1); -x_1 = x_179; -goto _start; -} -case 11: -{ -lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; -x_181 = lean_ctor_get(x_1, 0); -lean_inc(x_181); -x_182 = lean_ctor_get(x_1, 1); -lean_inc(x_182); -x_183 = lean_ctor_get(x_1, 2); -lean_inc(x_183); -x_184 = lean_ctor_get(x_3, 2); -lean_inc(x_184); -x_185 = lean_ctor_get(x_184, 0); -lean_inc(x_185); -lean_dec(x_184); -x_186 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_185, x_1); -lean_dec(x_185); -if (lean_obj_tag(x_186) == 0) -{ -lean_object* x_187; -x_187 = l___private_Init_Lean_Meta_InferType_3__inferProjType___at_Lean_Meta_isProp___spec__23(x_181, x_182, x_183, x_2, x_3); -if (lean_obj_tag(x_187) == 0) -{ -lean_object* x_188; lean_object* x_189; uint8_t x_190; -x_188 = lean_ctor_get(x_187, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_188, 2); -lean_inc(x_189); -x_190 = !lean_is_exclusive(x_187); -if (x_190 == 0) -{ -lean_object* x_191; lean_object* x_192; uint8_t x_193; -x_191 = lean_ctor_get(x_187, 0); -x_192 = lean_ctor_get(x_187, 1); -lean_dec(x_192); -x_193 = !lean_is_exclusive(x_188); -if (x_193 == 0) -{ -lean_object* x_194; uint8_t x_195; -x_194 = lean_ctor_get(x_188, 2); -lean_dec(x_194); -x_195 = !lean_is_exclusive(x_189); -if (x_195 == 0) -{ -lean_object* x_196; lean_object* x_197; -x_196 = lean_ctor_get(x_189, 0); -lean_inc(x_191); -x_197 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_196, x_1, x_191); -lean_ctor_set(x_189, 0, x_197); -return x_187; -} -else -{ -lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; -x_198 = lean_ctor_get(x_189, 0); -x_199 = lean_ctor_get(x_189, 1); -lean_inc(x_199); -lean_inc(x_198); -lean_dec(x_189); -lean_inc(x_191); -x_200 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_198, x_1, x_191); -x_201 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_201, 0, x_200); -lean_ctor_set(x_201, 1, x_199); -lean_ctor_set(x_188, 2, x_201); -return x_187; -} -} -else -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; -x_202 = lean_ctor_get(x_188, 0); -x_203 = lean_ctor_get(x_188, 1); -x_204 = lean_ctor_get(x_188, 3); -x_205 = lean_ctor_get(x_188, 4); -x_206 = lean_ctor_get(x_188, 5); -lean_inc(x_206); -lean_inc(x_205); -lean_inc(x_204); -lean_inc(x_203); -lean_inc(x_202); -lean_dec(x_188); -x_207 = lean_ctor_get(x_189, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_189, 1); -lean_inc(x_208); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - x_209 = x_189; -} else { - lean_dec_ref(x_189); - x_209 = lean_box(0); -} -lean_inc(x_191); -x_210 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_207, x_1, x_191); -if (lean_is_scalar(x_209)) { - x_211 = lean_alloc_ctor(0, 2, 0); -} else { - x_211 = x_209; -} -lean_ctor_set(x_211, 0, x_210); -lean_ctor_set(x_211, 1, x_208); -x_212 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_212, 0, x_202); -lean_ctor_set(x_212, 1, x_203); -lean_ctor_set(x_212, 2, x_211); -lean_ctor_set(x_212, 3, x_204); -lean_ctor_set(x_212, 4, x_205); -lean_ctor_set(x_212, 5, x_206); -lean_ctor_set(x_187, 1, x_212); -return x_187; -} -} -else -{ -lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; -x_213 = lean_ctor_get(x_187, 0); -lean_inc(x_213); -lean_dec(x_187); -x_214 = lean_ctor_get(x_188, 0); -lean_inc(x_214); -x_215 = lean_ctor_get(x_188, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_188, 3); -lean_inc(x_216); -x_217 = lean_ctor_get(x_188, 4); -lean_inc(x_217); -x_218 = lean_ctor_get(x_188, 5); -lean_inc(x_218); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - lean_ctor_release(x_188, 3); - lean_ctor_release(x_188, 4); - lean_ctor_release(x_188, 5); - x_219 = x_188; -} else { - lean_dec_ref(x_188); - x_219 = lean_box(0); -} -x_220 = lean_ctor_get(x_189, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_189, 1); -lean_inc(x_221); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - lean_ctor_release(x_189, 1); - x_222 = x_189; -} else { - lean_dec_ref(x_189); - x_222 = lean_box(0); -} -lean_inc(x_213); -x_223 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_220, x_1, x_213); -if (lean_is_scalar(x_222)) { - x_224 = lean_alloc_ctor(0, 2, 0); -} else { - x_224 = x_222; -} -lean_ctor_set(x_224, 0, x_223); -lean_ctor_set(x_224, 1, x_221); -if (lean_is_scalar(x_219)) { - x_225 = lean_alloc_ctor(0, 6, 0); -} else { - x_225 = x_219; -} -lean_ctor_set(x_225, 0, x_214); -lean_ctor_set(x_225, 1, x_215); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_216); -lean_ctor_set(x_225, 4, x_217); -lean_ctor_set(x_225, 5, x_218); -x_226 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_226, 0, x_213); -lean_ctor_set(x_226, 1, x_225); -return x_226; -} -} -else -{ -uint8_t x_227; -lean_dec(x_1); -x_227 = !lean_is_exclusive(x_187); -if (x_227 == 0) -{ -return x_187; -} -else -{ -lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_228 = lean_ctor_get(x_187, 0); -x_229 = lean_ctor_get(x_187, 1); -lean_inc(x_229); -lean_inc(x_228); -lean_dec(x_187); -x_230 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_230, 0, x_228); -lean_ctor_set(x_230, 1, x_229); -return x_230; -} -} -} -else -{ -lean_object* x_231; lean_object* x_232; -lean_dec(x_183); -lean_dec(x_182); -lean_dec(x_181); -lean_dec(x_2); -lean_dec(x_1); -x_231 = lean_ctor_get(x_186, 0); -lean_inc(x_231); -lean_dec(x_186); -x_232 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_232, 0, x_231); -lean_ctor_set(x_232, 1, x_3); -return x_232; -} -} -case 12: -{ -lean_object* x_233; lean_object* x_234; lean_object* x_235; -lean_dec(x_1); -x_233 = l_Lean_Meta_isClassQuick___main___closed__1; -x_234 = l_unreachable_x21___rarg(x_233); -x_235 = lean_apply_2(x_234, x_2, x_3); -return x_235; -} -default: -{ -lean_object* x_236; -x_236 = lean_box(0); -x_4 = x_236; -goto block_54; -} -} -block_54: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; -lean_dec(x_4); -x_5 = lean_ctor_get(x_3, 2); -lean_inc(x_5); -x_6 = lean_ctor_get(x_5, 0); -lean_inc(x_6); -lean_dec(x_5); -x_7 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_6, x_1); -lean_dec(x_6); -if (lean_obj_tag(x_7) == 0) -{ -lean_object* x_8; -lean_inc(x_1); -x_8 = l_Lean_Meta_lambdaTelescope___at_Lean_Meta_isProp___spec__4(x_1, x_2, x_3); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 1); -lean_inc(x_9); -x_10 = lean_ctor_get(x_9, 2); -lean_inc(x_10); -x_11 = !lean_is_exclusive(x_8); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_12 = lean_ctor_get(x_8, 0); -x_13 = lean_ctor_get(x_8, 1); -lean_dec(x_13); -x_14 = !lean_is_exclusive(x_9); -if (x_14 == 0) -{ -lean_object* x_15; uint8_t x_16; -x_15 = lean_ctor_get(x_9, 2); -lean_dec(x_15); -x_16 = !lean_is_exclusive(x_10); -if (x_16 == 0) -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_ctor_get(x_10, 0); -lean_inc(x_12); -x_18 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_17, x_1, x_12); -lean_ctor_set(x_10, 0, x_18); -return x_8; -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_10, 0); -x_20 = lean_ctor_get(x_10, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_10); -lean_inc(x_12); -x_21 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_19, x_1, x_12); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_20); -lean_ctor_set(x_9, 2, x_22); -return x_8; -} -} -else -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_23 = lean_ctor_get(x_9, 0); -x_24 = lean_ctor_get(x_9, 1); -x_25 = lean_ctor_get(x_9, 3); -x_26 = lean_ctor_get(x_9, 4); -x_27 = lean_ctor_get(x_9, 5); -lean_inc(x_27); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_9); -x_28 = lean_ctor_get(x_10, 0); -lean_inc(x_28); -x_29 = lean_ctor_get(x_10, 1); -lean_inc(x_29); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_30 = x_10; -} else { - lean_dec_ref(x_10); - x_30 = lean_box(0); -} -lean_inc(x_12); -x_31 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_28, x_1, x_12); -if (lean_is_scalar(x_30)) { - x_32 = lean_alloc_ctor(0, 2, 0); -} else { - x_32 = x_30; -} -lean_ctor_set(x_32, 0, x_31); -lean_ctor_set(x_32, 1, x_29); -x_33 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_33, 0, x_23); -lean_ctor_set(x_33, 1, x_24); -lean_ctor_set(x_33, 2, x_32); -lean_ctor_set(x_33, 3, x_25); -lean_ctor_set(x_33, 4, x_26); -lean_ctor_set(x_33, 5, x_27); -lean_ctor_set(x_8, 1, x_33); -return x_8; -} -} -else -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_34 = lean_ctor_get(x_8, 0); -lean_inc(x_34); -lean_dec(x_8); -x_35 = lean_ctor_get(x_9, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_9, 1); -lean_inc(x_36); -x_37 = lean_ctor_get(x_9, 3); -lean_inc(x_37); -x_38 = lean_ctor_get(x_9, 4); -lean_inc(x_38); -x_39 = lean_ctor_get(x_9, 5); -lean_inc(x_39); -if (lean_is_exclusive(x_9)) { - lean_ctor_release(x_9, 0); - lean_ctor_release(x_9, 1); - lean_ctor_release(x_9, 2); - lean_ctor_release(x_9, 3); - lean_ctor_release(x_9, 4); - lean_ctor_release(x_9, 5); - x_40 = x_9; -} else { - lean_dec_ref(x_9); - x_40 = lean_box(0); -} -x_41 = lean_ctor_get(x_10, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_10, 1); -lean_inc(x_42); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - x_43 = x_10; -} else { - lean_dec_ref(x_10); - x_43 = lean_box(0); -} -lean_inc(x_34); -x_44 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_41, x_1, x_34); -if (lean_is_scalar(x_43)) { - x_45 = lean_alloc_ctor(0, 2, 0); -} else { - x_45 = x_43; -} -lean_ctor_set(x_45, 0, x_44); -lean_ctor_set(x_45, 1, x_42); -if (lean_is_scalar(x_40)) { - x_46 = lean_alloc_ctor(0, 6, 0); -} else { - x_46 = x_40; -} -lean_ctor_set(x_46, 0, x_35); -lean_ctor_set(x_46, 1, x_36); -lean_ctor_set(x_46, 2, x_45); -lean_ctor_set(x_46, 3, x_37); -lean_ctor_set(x_46, 4, x_38); -lean_ctor_set(x_46, 5, x_39); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_34); -lean_ctor_set(x_47, 1, x_46); -return x_47; -} -} -else -{ -uint8_t x_48; -lean_dec(x_1); -x_48 = !lean_is_exclusive(x_8); -if (x_48 == 0) -{ -return x_8; -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_8, 0); -x_50 = lean_ctor_get(x_8, 1); -lean_inc(x_50); -lean_inc(x_49); -lean_dec(x_8); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_49); -lean_ctor_set(x_51, 1, x_50); -return x_51; -} -} -} -else -{ -lean_object* x_52; lean_object* x_53; -lean_dec(x_2); -lean_dec(x_1); -x_52 = lean_ctor_get(x_7, 0); -lean_inc(x_52); -lean_dec(x_7); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_3); -return x_53; -} -} -} -} -lean_object* l_Lean_Meta_isPropAux___at_Lean_Meta_isProp___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -lean_inc(x_1); -x_4 = l___private_Init_Lean_Meta_InferType_13__isPropQuick___main(x_1, x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; uint8_t x_6; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_unbox(x_5); -lean_dec(x_5); -switch (x_6) { -case 0: -{ -uint8_t x_7; -lean_dec(x_2); -lean_dec(x_1); -x_7 = !lean_is_exclusive(x_4); -if (x_7 == 0) -{ -lean_object* x_8; uint8_t x_9; lean_object* x_10; -x_8 = lean_ctor_get(x_4, 0); -lean_dec(x_8); -x_9 = 0; -x_10 = lean_box(x_9); -lean_ctor_set(x_4, 0, x_10); -return x_4; -} -else -{ -lean_object* x_11; uint8_t x_12; lean_object* x_13; lean_object* x_14; -x_11 = lean_ctor_get(x_4, 1); -lean_inc(x_11); -lean_dec(x_4); -x_12 = 0; -x_13 = lean_box(x_12); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_11); -return x_14; -} -} -case 1: -{ -uint8_t x_15; -lean_dec(x_2); -lean_dec(x_1); -x_15 = !lean_is_exclusive(x_4); -if (x_15 == 0) -{ -lean_object* x_16; uint8_t x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_4, 0); -lean_dec(x_16); -x_17 = 1; -x_18 = lean_box(x_17); -lean_ctor_set(x_4, 0, x_18); -return x_4; -} -else -{ -lean_object* x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_4, 1); -lean_inc(x_19); -lean_dec(x_4); -x_20 = 1; -x_21 = lean_box(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_19); -return x_22; -} -} -default: -{ -lean_object* x_23; lean_object* x_24; -x_23 = lean_ctor_get(x_4, 1); -lean_inc(x_23); -lean_dec(x_4); -lean_inc(x_2); -x_24 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_1, x_2, x_23); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; -x_25 = lean_ctor_get(x_2, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_24, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_24, 1); -lean_inc(x_27); -lean_dec(x_24); -x_28 = lean_ctor_get(x_2, 1); -lean_inc(x_28); -x_29 = lean_ctor_get(x_2, 2); -lean_inc(x_29); -x_30 = !lean_is_exclusive(x_25); -if (x_30 == 0) -{ -uint8_t x_31; lean_object* x_32; uint8_t x_33; lean_object* x_34; -x_31 = 1; -lean_ctor_set_uint8(x_25, sizeof(void*)*1 + 4, x_31); -x_32 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_32, 0, x_25); -lean_ctor_set(x_32, 1, x_28); -lean_ctor_set(x_32, 2, x_29); -x_33 = 0; -lean_inc(x_26); -x_34 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_33, x_26, x_26, x_32, x_27); -lean_dec(x_26); -if (lean_obj_tag(x_34) == 0) -{ -lean_object* x_35; -x_35 = lean_ctor_get(x_34, 0); -lean_inc(x_35); -if (lean_obj_tag(x_35) == 3) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; -x_36 = lean_ctor_get(x_34, 1); -lean_inc(x_36); -lean_dec(x_34); -x_37 = lean_ctor_get(x_35, 0); -lean_inc(x_37); -lean_dec(x_35); -x_38 = l_Lean_Meta_instantiateLevelMVars(x_37, x_2, x_36); -lean_dec(x_2); -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; lean_object* x_42; -x_40 = lean_ctor_get(x_38, 0); -x_41 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_40); -lean_dec(x_40); -x_42 = lean_box(x_41); -lean_ctor_set(x_38, 0, x_42); -return x_38; -} -else -{ -lean_object* x_43; lean_object* x_44; uint8_t x_45; lean_object* x_46; lean_object* x_47; -x_43 = lean_ctor_get(x_38, 0); -x_44 = lean_ctor_get(x_38, 1); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_38); -x_45 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_43); -lean_dec(x_43); -x_46 = lean_box(x_45); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_44); -return x_47; -} -} -else -{ -uint8_t x_48; -lean_dec(x_35); -lean_dec(x_2); -x_48 = !lean_is_exclusive(x_34); -if (x_48 == 0) -{ -lean_object* x_49; uint8_t x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_34, 0); -lean_dec(x_49); -x_50 = 0; -x_51 = lean_box(x_50); -lean_ctor_set(x_34, 0, x_51); -return x_34; -} -else -{ -lean_object* x_52; uint8_t x_53; lean_object* x_54; lean_object* x_55; -x_52 = lean_ctor_get(x_34, 1); -lean_inc(x_52); -lean_dec(x_34); -x_53 = 0; -x_54 = lean_box(x_53); -x_55 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_52); -return x_55; -} -} -} -else -{ -uint8_t x_56; -lean_dec(x_2); -x_56 = !lean_is_exclusive(x_34); -if (x_56 == 0) -{ -return x_34; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_34, 0); -x_58 = lean_ctor_get(x_34, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_34); -x_59 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -return x_59; -} -} -} -else -{ -lean_object* x_60; uint8_t x_61; uint8_t x_62; uint8_t x_63; uint8_t x_64; uint8_t x_65; lean_object* x_66; lean_object* x_67; uint8_t x_68; lean_object* x_69; -x_60 = lean_ctor_get(x_25, 0); -x_61 = lean_ctor_get_uint8(x_25, sizeof(void*)*1); -x_62 = lean_ctor_get_uint8(x_25, sizeof(void*)*1 + 1); -x_63 = lean_ctor_get_uint8(x_25, sizeof(void*)*1 + 2); -x_64 = lean_ctor_get_uint8(x_25, sizeof(void*)*1 + 3); -lean_inc(x_60); -lean_dec(x_25); -x_65 = 1; -x_66 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_66, 0, x_60); -lean_ctor_set_uint8(x_66, sizeof(void*)*1, x_61); -lean_ctor_set_uint8(x_66, sizeof(void*)*1 + 1, x_62); -lean_ctor_set_uint8(x_66, sizeof(void*)*1 + 2, x_63); -lean_ctor_set_uint8(x_66, sizeof(void*)*1 + 3, x_64); -lean_ctor_set_uint8(x_66, sizeof(void*)*1 + 4, x_65); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_66); -lean_ctor_set(x_67, 1, x_28); -lean_ctor_set(x_67, 2, x_29); -x_68 = 0; -lean_inc(x_26); -x_69 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_68, x_26, x_26, x_67, x_27); -lean_dec(x_26); -if (lean_obj_tag(x_69) == 0) -{ -lean_object* x_70; -x_70 = lean_ctor_get(x_69, 0); -lean_inc(x_70); -if (lean_obj_tag(x_70) == 3) -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; uint8_t x_77; lean_object* x_78; lean_object* x_79; -x_71 = lean_ctor_get(x_69, 1); -lean_inc(x_71); -lean_dec(x_69); -x_72 = lean_ctor_get(x_70, 0); -lean_inc(x_72); -lean_dec(x_70); -x_73 = l_Lean_Meta_instantiateLevelMVars(x_72, x_2, x_71); -lean_dec(x_2); -x_74 = lean_ctor_get(x_73, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_73, 1); -lean_inc(x_75); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - x_76 = x_73; -} else { - lean_dec_ref(x_73); - x_76 = lean_box(0); -} -x_77 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_74); -lean_dec(x_74); -x_78 = lean_box(x_77); -if (lean_is_scalar(x_76)) { - x_79 = lean_alloc_ctor(0, 2, 0); -} else { - x_79 = x_76; -} -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_75); -return x_79; -} -else -{ -lean_object* x_80; lean_object* x_81; uint8_t x_82; lean_object* x_83; lean_object* x_84; -lean_dec(x_70); -lean_dec(x_2); -x_80 = lean_ctor_get(x_69, 1); -lean_inc(x_80); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - x_81 = x_69; -} else { - lean_dec_ref(x_69); - x_81 = lean_box(0); -} -x_82 = 0; -x_83 = lean_box(x_82); -if (lean_is_scalar(x_81)) { - x_84 = lean_alloc_ctor(0, 2, 0); -} else { - x_84 = x_81; -} -lean_ctor_set(x_84, 0, x_83); -lean_ctor_set(x_84, 1, x_80); -return x_84; -} -} -else -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -lean_dec(x_2); -x_85 = lean_ctor_get(x_69, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_69, 1); -lean_inc(x_86); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - x_87 = x_69; -} else { - lean_dec_ref(x_69); - x_87 = lean_box(0); -} -if (lean_is_scalar(x_87)) { - x_88 = lean_alloc_ctor(1, 2, 0); -} else { - x_88 = x_87; -} -lean_ctor_set(x_88, 0, x_85); -lean_ctor_set(x_88, 1, x_86); -return x_88; -} -} -} -else -{ -uint8_t x_89; -lean_dec(x_2); -x_89 = !lean_is_exclusive(x_24); -if (x_89 == 0) -{ -return x_24; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_24, 0); -x_91 = lean_ctor_get(x_24, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_24); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; -} -} -} -} -} -else -{ -uint8_t x_93; -lean_dec(x_2); -lean_dec(x_1); -x_93 = !lean_is_exclusive(x_4); -if (x_93 == 0) -{ -return x_4; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_4, 0); -x_95 = lean_ctor_get(x_4, 1); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_4); -x_96 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_96, 0, x_94); -lean_ctor_set(x_96, 1, x_95); -return x_96; -} -} -} -} -lean_object* l_Lean_Meta_isProp(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_isPropAux___at_Lean_Meta_isProp___spec__1(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__10___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__10(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_2); -lean_dec(x_2); -x_11 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___lambda__1(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_1); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_1); -lean_dec(x_1); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -return x_14; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__12___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__12(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -uint8_t x_9; lean_object* x_10; -x_9 = lean_unbox(x_1); -lean_dec(x_1); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__9(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__13___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__13(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -return x_7; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__15___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__15(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_3); -return x_8; -} -} -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_isProp___spec__18(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_2); -lean_dec(x_1); -return x_8; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__20___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__20(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); -lean_dec(x_1); -return x_8; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_4); -lean_dec(x_4); -x_11 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___lambda__1(x_1, x_2, x_3, x_10, x_5, x_6, x_7, x_8, x_9); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_1); -lean_dec(x_1); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__21(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -return x_14; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__22___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__22(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); -lean_dec(x_1); -return x_8; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__19___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -uint8_t x_9; lean_object* x_10; -x_9 = lean_unbox(x_1); -lean_dec(x_1); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isProp___spec__19(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Nat_foldMAux___main___at_Lean_Meta_isProp___spec__24(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -return x_9; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_unsigned_to_nat(0u); -x_8 = lean_nat_dec_eq(x_3, x_7); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_9 = lean_unsigned_to_nat(1u); -x_10 = lean_nat_sub(x_3, x_9); -lean_dec(x_3); -x_11 = lean_nat_sub(x_2, x_10); -x_12 = lean_nat_sub(x_11, x_9); -lean_dec(x_11); -x_13 = l_Lean_Expr_Inhabited; -x_14 = lean_array_get(x_13, x_1, x_12); -lean_dec(x_12); -lean_inc(x_5); -x_15 = l_Lean_Meta_getFVarLocalDecl(x_14, x_5, x_6); -lean_dec(x_14); -if (lean_obj_tag(x_15) == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_16 = lean_ctor_get(x_15, 0); -lean_inc(x_16); -x_17 = lean_ctor_get(x_15, 1); -lean_inc(x_17); -lean_dec(x_15); -x_18 = l_Lean_LocalDecl_type(x_16); -lean_inc(x_5); -lean_inc(x_18); -x_19 = l_Lean_Meta_isPropAux___at_Lean_Meta_isProp___spec__1(x_18, x_5, x_17); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; uint8_t x_27; uint8_t x_28; uint8_t x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_Meta_collectDeps(x_1, x_18); -lean_dec(x_18); -x_23 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_4, x_22); -x_24 = l_Lean_LocalDecl_binderInfo(x_16); -lean_dec(x_16); -x_25 = 1; -x_26 = l_Lean_BinderInfo_beq(x_24, x_25); -x_27 = 3; -x_28 = l_Lean_BinderInfo_beq(x_24, x_27); -x_29 = 0; -x_30 = lean_alloc_ctor(0, 1, 4); -lean_ctor_set(x_30, 0, x_22); -lean_ctor_set_uint8(x_30, sizeof(void*)*1, x_26); -lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 1, x_28); -x_31 = lean_unbox(x_20); -lean_dec(x_20); -lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 2, x_31); -lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 3, x_29); -x_32 = lean_array_push(x_23, x_30); -x_3 = x_10; -x_4 = x_32; -x_6 = x_21; -goto _start; -} -else -{ -uint8_t x_34; -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_10); -lean_dec(x_5); -lean_dec(x_4); -x_34 = !lean_is_exclusive(x_19); -if (x_34 == 0) -{ -return x_19; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_19, 0); -x_36 = lean_ctor_get(x_19, 1); -lean_inc(x_36); -lean_inc(x_35); -lean_dec(x_19); -x_37 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_37, 0, x_35); -lean_ctor_set(x_37, 1, x_36); -return x_37; -} -} -} -else -{ -uint8_t x_38; -lean_dec(x_10); -lean_dec(x_5); -lean_dec(x_4); -x_38 = !lean_is_exclusive(x_15); -if (x_38 == 0) -{ -return x_15; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_39 = lean_ctor_get(x_15, 0); -x_40 = lean_ctor_get(x_15, 1); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_15); -x_41 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -return x_41; -} -} -} -else -{ -lean_object* x_42; -lean_dec(x_5); -lean_dec(x_3); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_4); -lean_ctor_set(x_42, 1, x_6); -return x_42; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_4); -x_9 = lean_nat_dec_lt(x_5, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; -lean_dec(x_5); -x_10 = l_Array_empty___closed__1; -lean_inc(x_2); -x_11 = l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(x_1, x_2, x_2, x_10, x_6, x_7); -lean_dec(x_2); -if (lean_obj_tag(x_11) == 0) -{ -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_11, 0); -x_14 = l_Lean_Meta_collectDeps(x_1, x_3); -x_15 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_13, x_14); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_14); -lean_ctor_set(x_11, 0, x_16); -return x_11; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_17 = lean_ctor_get(x_11, 0); -x_18 = lean_ctor_get(x_11, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_11); -x_19 = l_Lean_Meta_collectDeps(x_1, x_3); -x_20 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_17, x_19); -x_21 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_21, 0, x_20); -lean_ctor_set(x_21, 1, x_19); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_18); -return x_22; -} -} -else -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_11); -if (x_23 == 0) -{ -return x_11; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_11, 0); -x_25 = lean_ctor_get(x_11, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_11); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -lean_object* x_27; lean_object* x_28; -x_27 = lean_array_fget(x_4, x_5); -lean_inc(x_6); -x_28 = l_Lean_Meta_getFVarLocalDecl(x_27, x_6, x_7); -if (lean_obj_tag(x_28) == 0) -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = l_Lean_LocalDecl_type(x_29); -lean_dec(x_29); -lean_inc(x_6); -lean_inc(x_31); -x_32 = l_Lean_Meta_isClassQuick___main(x_31, x_6, x_30); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -switch (lean_obj_tag(x_33)) { -case 0: -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -lean_dec(x_31); -lean_dec(x_27); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = lean_unsigned_to_nat(1u); -x_36 = lean_nat_add(x_5, x_35); -lean_dec(x_5); -x_5 = x_36; -x_7 = x_34; -goto _start; -} -case 1: -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; -lean_dec(x_31); -x_38 = lean_ctor_get(x_32, 1); -lean_inc(x_38); -lean_dec(x_32); -x_39 = lean_ctor_get(x_33, 0); -lean_inc(x_39); -lean_dec(x_33); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_add(x_5, x_40); -lean_dec(x_5); -x_42 = !lean_is_exclusive(x_6); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_6, 2); -x_44 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_27); -x_45 = lean_array_push(x_43, x_44); -lean_ctor_set(x_6, 2, x_45); -x_5 = x_41; -x_7 = x_38; -goto _start; -} -else -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_47 = lean_ctor_get(x_6, 0); -x_48 = lean_ctor_get(x_6, 1); -x_49 = lean_ctor_get(x_6, 2); -lean_inc(x_49); -lean_inc(x_48); -lean_inc(x_47); -lean_dec(x_6); -x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_39); -lean_ctor_set(x_50, 1, x_27); -x_51 = lean_array_push(x_49, x_50); -x_52 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_52, 0, x_47); -lean_ctor_set(x_52, 1, x_48); -lean_ctor_set(x_52, 2, x_51); -x_5 = x_41; -x_6 = x_52; -x_7 = x_38; -goto _start; -} -} -default: -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_32, 1); -lean_inc(x_54); -lean_dec(x_32); -lean_inc(x_6); -x_55 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_31, x_6, x_54); -if (lean_obj_tag(x_55) == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_55, 0); -lean_inc(x_56); -if (lean_obj_tag(x_56) == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -lean_dec(x_27); -x_57 = lean_ctor_get(x_55, 1); -lean_inc(x_57); -lean_dec(x_55); -x_58 = lean_unsigned_to_nat(1u); -x_59 = lean_nat_add(x_5, x_58); -lean_dec(x_5); -x_5 = x_59; -x_7 = x_57; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; -x_61 = lean_ctor_get(x_55, 1); -lean_inc(x_61); -lean_dec(x_55); -x_62 = lean_ctor_get(x_56, 0); -lean_inc(x_62); -lean_dec(x_56); -x_63 = lean_unsigned_to_nat(1u); -x_64 = lean_nat_add(x_5, x_63); -lean_dec(x_5); -x_65 = !lean_is_exclusive(x_6); -if (x_65 == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_6, 2); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_27); -x_68 = lean_array_push(x_66, x_67); -lean_ctor_set(x_6, 2, x_68); -x_5 = x_64; -x_7 = x_61; -goto _start; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_70 = lean_ctor_get(x_6, 0); -x_71 = lean_ctor_get(x_6, 1); -x_72 = lean_ctor_get(x_6, 2); -lean_inc(x_72); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_6); -x_73 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_73, 0, x_62); -lean_ctor_set(x_73, 1, x_27); -x_74 = lean_array_push(x_72, x_73); -x_75 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_75, 0, x_70); -lean_ctor_set(x_75, 1, x_71); -lean_ctor_set(x_75, 2, x_74); -x_5 = x_64; -x_6 = x_75; -x_7 = x_61; -goto _start; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_27); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -x_77 = !lean_is_exclusive(x_55); -if (x_77 == 0) -{ -return x_55; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_55, 0); -x_79 = lean_ctor_get(x_55, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_55); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_31); -lean_dec(x_27); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_32); -if (x_81 == 0) -{ -return x_32; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_32, 0); -x_83 = lean_ctor_get(x_32, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_32); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -else -{ -uint8_t x_85; -lean_dec(x_27); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -x_85 = !lean_is_exclusive(x_28); -if (x_85 == 0) -{ -return x_28; -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_28, 0); -x_87 = lean_ctor_get(x_28, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_28); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; -x_10 = l_Lean_Expr_isForall(x_7); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_11 = l_Array_empty___closed__1; -lean_inc(x_2); -x_12 = l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(x_1, x_2, x_2, x_11, x_8, x_9); -lean_dec(x_2); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = l_Lean_Meta_collectDeps(x_1, x_3); -lean_dec(x_1); -x_16 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_14, x_15); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_15); -lean_ctor_set(x_12, 0, x_17); -return x_12; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_12); -x_20 = l_Lean_Meta_collectDeps(x_1, x_3); -lean_dec(x_1); -x_21 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_18, x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_20); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); -return x_23; -} -} -else -{ -uint8_t x_24; -lean_dec(x_1); -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) -{ -return x_12; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -lean_object* x_28; -x_28 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5(x_4, x_5, x_6, x_1, x_2, x_7, x_8, x_9); -return x_28; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_13 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1; -lean_inc(x_8); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_13); -lean_closure_set(x_14, 1, x_8); -x_15 = lean_box(x_1); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_8); -lean_inc(x_7); -lean_inc(x_4); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___lambda__1___boxed), 9, 6); -lean_closure_set(x_16, 0, x_4); -lean_closure_set(x_16, 1, x_7); -lean_closure_set(x_16, 2, x_8); -lean_closure_set(x_16, 3, x_15); -lean_closure_set(x_16, 4, x_2); -lean_closure_set(x_16, 5, x_3); -x_17 = lean_array_get_size(x_9); -x_18 = lean_nat_dec_lt(x_10, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_11, x_12); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_9, x_10); -lean_inc(x_11); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_11, x_12); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_11); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_11, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_10, x_28); -lean_dec(x_10); -x_10 = x_29; -x_12 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_10, x_33); -lean_dec(x_10); -x_35 = !lean_is_exclusive(x_11); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_11, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_11, 2, x_38); -x_10 = x_34; -x_12 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_11, 0); -x_41 = lean_ctor_get(x_11, 1); -x_42 = lean_ctor_get(x_11, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_11); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_10 = x_34; -x_11 = x_45; -x_12 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_11); -x_48 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_24, x_11, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_10, x_51); -lean_dec(x_10); -x_10 = x_52; -x_12 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_10, x_56); -lean_dec(x_10); -x_58 = !lean_is_exclusive(x_11); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_11, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_11, 2, x_61); -x_10 = x_57; -x_12 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_11, 0); -x_64 = lean_ctor_get(x_11, 1); -x_65 = lean_ctor_get(x_11, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_11); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_10 = x_57; -x_11 = x_68; -x_12 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_4); -x_9 = lean_nat_dec_lt(x_5, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; -lean_dec(x_5); -x_10 = l_Array_empty___closed__1; -lean_inc(x_2); -x_11 = l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(x_1, x_2, x_2, x_10, x_6, x_7); -lean_dec(x_2); -if (lean_obj_tag(x_11) == 0) -{ -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_11, 0); -x_14 = l_Lean_Meta_collectDeps(x_1, x_3); -x_15 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_13, x_14); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_14); -lean_ctor_set(x_11, 0, x_16); -return x_11; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_17 = lean_ctor_get(x_11, 0); -x_18 = lean_ctor_get(x_11, 1); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_11); -x_19 = l_Lean_Meta_collectDeps(x_1, x_3); -x_20 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_17, x_19); -x_21 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_21, 0, x_20); -lean_ctor_set(x_21, 1, x_19); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_18); -return x_22; -} -} -else -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_11); -if (x_23 == 0) -{ -return x_11; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_11, 0); -x_25 = lean_ctor_get(x_11, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_11); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -else -{ -lean_object* x_27; lean_object* x_28; -x_27 = lean_array_fget(x_4, x_5); -lean_inc(x_6); -x_28 = l_Lean_Meta_getFVarLocalDecl(x_27, x_6, x_7); -if (lean_obj_tag(x_28) == 0) -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = l_Lean_LocalDecl_type(x_29); -lean_dec(x_29); -lean_inc(x_6); -lean_inc(x_31); -x_32 = l_Lean_Meta_isClassQuick___main(x_31, x_6, x_30); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -switch (lean_obj_tag(x_33)) { -case 0: -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -lean_dec(x_31); -lean_dec(x_27); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -x_35 = lean_unsigned_to_nat(1u); -x_36 = lean_nat_add(x_5, x_35); -lean_dec(x_5); -x_5 = x_36; -x_7 = x_34; -goto _start; -} -case 1: -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; -lean_dec(x_31); -x_38 = lean_ctor_get(x_32, 1); -lean_inc(x_38); -lean_dec(x_32); -x_39 = lean_ctor_get(x_33, 0); -lean_inc(x_39); -lean_dec(x_33); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_add(x_5, x_40); -lean_dec(x_5); -x_42 = !lean_is_exclusive(x_6); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_6, 2); -x_44 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_27); -x_45 = lean_array_push(x_43, x_44); -lean_ctor_set(x_6, 2, x_45); -x_5 = x_41; -x_7 = x_38; -goto _start; -} -else -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_47 = lean_ctor_get(x_6, 0); -x_48 = lean_ctor_get(x_6, 1); -x_49 = lean_ctor_get(x_6, 2); -lean_inc(x_49); -lean_inc(x_48); -lean_inc(x_47); -lean_dec(x_6); -x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_39); -lean_ctor_set(x_50, 1, x_27); -x_51 = lean_array_push(x_49, x_50); -x_52 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_52, 0, x_47); -lean_ctor_set(x_52, 1, x_48); -lean_ctor_set(x_52, 2, x_51); -x_5 = x_41; -x_6 = x_52; -x_7 = x_38; -goto _start; -} -} -default: -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_32, 1); -lean_inc(x_54); -lean_dec(x_32); -lean_inc(x_6); -x_55 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_isProp___spec__7(x_31, x_6, x_54); -if (lean_obj_tag(x_55) == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_55, 0); -lean_inc(x_56); -if (lean_obj_tag(x_56) == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -lean_dec(x_27); -x_57 = lean_ctor_get(x_55, 1); -lean_inc(x_57); -lean_dec(x_55); -x_58 = lean_unsigned_to_nat(1u); -x_59 = lean_nat_add(x_5, x_58); -lean_dec(x_5); -x_5 = x_59; -x_7 = x_57; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; -x_61 = lean_ctor_get(x_55, 1); -lean_inc(x_61); -lean_dec(x_55); -x_62 = lean_ctor_get(x_56, 0); -lean_inc(x_62); -lean_dec(x_56); -x_63 = lean_unsigned_to_nat(1u); -x_64 = lean_nat_add(x_5, x_63); -lean_dec(x_5); -x_65 = !lean_is_exclusive(x_6); -if (x_65 == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_6, 2); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_27); -x_68 = lean_array_push(x_66, x_67); -lean_ctor_set(x_6, 2, x_68); -x_5 = x_64; -x_7 = x_61; -goto _start; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_70 = lean_ctor_get(x_6, 0); -x_71 = lean_ctor_get(x_6, 1); -x_72 = lean_ctor_get(x_6, 2); -lean_inc(x_72); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_6); -x_73 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_73, 0, x_62); -lean_ctor_set(x_73, 1, x_27); -x_74 = lean_array_push(x_72, x_73); -x_75 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_75, 0, x_70); -lean_ctor_set(x_75, 1, x_71); -lean_ctor_set(x_75, 2, x_74); -x_5 = x_64; -x_6 = x_75; -x_7 = x_61; -goto _start; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_27); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -x_77 = !lean_is_exclusive(x_55); -if (x_77 == 0) -{ -return x_55; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_55, 0); -x_79 = lean_ctor_get(x_55, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_55); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_31); -lean_dec(x_27); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_32); -if (x_81 == 0) -{ -return x_32; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_32, 0); -x_83 = lean_ctor_get(x_32, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_32); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -else -{ -uint8_t x_85; -lean_dec(x_27); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -x_85 = !lean_is_exclusive(x_28); -if (x_85 == 0) -{ -return x_28; -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_28, 0); -x_87 = lean_ctor_get(x_28, 1); -lean_inc(x_87); -lean_inc(x_86); -lean_dec(x_28); -x_88 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_88, 0, x_86); -lean_ctor_set(x_88, 1, x_87); -return x_88; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_22 = lean_ctor_get(x_6, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_6, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 2); -lean_inc(x_24); -x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); -lean_dec(x_6); -x_26 = lean_array_get_size(x_4); -lean_inc(x_4); -x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); -lean_dec(x_26); -lean_dec(x_23); -x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = (uint8_t)((x_25 << 24) >> 61); -lean_inc(x_29); -x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); -x_33 = l_Lean_mkFVar(x_29); -x_34 = lean_array_push(x_4, x_33); -if (lean_obj_tag(x_2) == 0) -{ -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -else -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_2, 0); -lean_inc(x_36); -x_37 = lean_array_get_size(x_34); -x_38 = lean_nat_dec_lt(x_37, x_36); -lean_dec(x_36); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -lean_dec(x_2); -lean_inc(x_34); -x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); -lean_dec(x_24); -x_40 = !lean_is_exclusive(x_7); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_7, 1); -lean_dec(x_41); -lean_ctor_set(x_7, 1, x_32); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__8(x_34, x_37, x_39, x_34, x_5, x_7, x_30); -lean_dec(x_39); -lean_dec(x_34); -return x_42; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_7, 0); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_32); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__8(x_34, x_37, x_39, x_34, x_5, x_45, x_30); -lean_dec(x_39); -lean_dec(x_34); -return x_46; -} -} -else -{ -lean_dec(x_37); -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -} -} -else -{ -lean_object* x_48; -x_48 = lean_box(0); -x_9 = x_48; -goto block_21; -} -block_21: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_7, 1); -lean_dec(x_13); -lean_inc(x_3); -lean_ctor_set(x_7, 1, x_3); -if (x_1 == 0) -{ -lean_object* x_14; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__6(x_4, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_11); -lean_dec(x_4); -return x_14; -} -else -{ -lean_object* x_15; -lean_inc(x_5); -lean_inc(x_4); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_7, 0); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_7); -lean_inc(x_3); -x_18 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_3); -lean_ctor_set(x_18, 2, x_17); -if (x_1 == 0) -{ -lean_object* x_19; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__6(x_4, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_11); -lean_dec(x_4); -return x_19; -} -else -{ -lean_object* x_20; -lean_inc(x_5); -lean_inc(x_4); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_20; -} -} -} -} -} -lean_object* _init_l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4___closed__1() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_Array_empty___closed__1; -x_2 = lean_array_get_size(x_1); -return x_2; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; -x_5 = lean_ctor_get(x_3, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_3, 1); -lean_inc(x_6); -x_7 = lean_ctor_get(x_3, 2); -lean_inc(x_7); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) -{ -uint8_t x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; -x_9 = 1; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 4, x_9); -lean_inc(x_6); -x_10 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_10, 0, x_5); -lean_ctor_set(x_10, 1, x_6); -lean_ctor_set(x_10, 2, x_7); -x_11 = 0; -lean_inc(x_1); -x_12 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_11, x_1, x_1, x_10, x_4); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; uint8_t x_15; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -x_15 = l_Lean_Expr_isForall(x_13); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -lean_dec(x_13); -lean_dec(x_6); -lean_dec(x_2); -x_16 = l_Array_empty___closed__1; -x_17 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4___closed__1; -x_18 = l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(x_16, x_17, x_17, x_16, x_3, x_14); -if (lean_obj_tag(x_18) == 0) -{ -uint8_t x_19; -x_19 = !lean_is_exclusive(x_18); -if (x_19 == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_18, 0); -x_21 = l_Lean_Meta_collectDeps(x_16, x_1); -lean_dec(x_1); -x_22 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_20, x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_21); -lean_ctor_set(x_18, 0, x_23); -return x_18; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_24 = lean_ctor_get(x_18, 0); -x_25 = lean_ctor_get(x_18, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_18); -x_26 = l_Lean_Meta_collectDeps(x_16, x_1); -lean_dec(x_1); -x_27 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_24, x_26); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_27); -lean_ctor_set(x_28, 1, x_26); -x_29 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_29, 0, x_28); -lean_ctor_set(x_29, 1, x_25); -return x_29; -} -} -else -{ -uint8_t x_30; -lean_dec(x_1); -x_30 = !lean_is_exclusive(x_18); -if (x_30 == 0) -{ -return x_18; -} -else -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_31 = lean_ctor_get(x_18, 0); -x_32 = lean_ctor_get(x_18, 1); -lean_inc(x_32); -lean_inc(x_31); -lean_dec(x_18); -x_33 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_33, 0, x_31); -lean_ctor_set(x_33, 1, x_32); -return x_33; -} -} -} -else -{ -lean_object* x_34; uint8_t x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -lean_dec(x_1); -x_34 = lean_ctor_get(x_14, 2); -lean_inc(x_34); -x_35 = 1; -x_36 = l_Array_empty___closed__1; -x_37 = lean_unsigned_to_nat(0u); -x_38 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5(x_35, x_2, x_6, x_36, x_37, x_13, x_3, x_14); -if (lean_obj_tag(x_38) == 0) -{ -uint8_t x_39; -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_38, 1); -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) -{ -lean_object* x_42; -x_42 = lean_ctor_get(x_40, 2); -lean_dec(x_42); -lean_ctor_set(x_40, 2, x_34); -return x_38; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_43 = lean_ctor_get(x_40, 0); -x_44 = lean_ctor_get(x_40, 1); -x_45 = lean_ctor_get(x_40, 3); -x_46 = lean_ctor_get(x_40, 4); -x_47 = lean_ctor_get(x_40, 5); -lean_inc(x_47); -lean_inc(x_46); -lean_inc(x_45); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_40); -x_48 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_48, 0, x_43); -lean_ctor_set(x_48, 1, x_44); -lean_ctor_set(x_48, 2, x_34); -lean_ctor_set(x_48, 3, x_45); -lean_ctor_set(x_48, 4, x_46); -lean_ctor_set(x_48, 5, x_47); -lean_ctor_set(x_38, 1, x_48); -return x_38; -} -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_49 = lean_ctor_get(x_38, 1); -x_50 = lean_ctor_get(x_38, 0); -lean_inc(x_49); -lean_inc(x_50); -lean_dec(x_38); -x_51 = lean_ctor_get(x_49, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_49, 1); -lean_inc(x_52); -x_53 = lean_ctor_get(x_49, 3); -lean_inc(x_53); -x_54 = lean_ctor_get(x_49, 4); -lean_inc(x_54); -x_55 = lean_ctor_get(x_49, 5); -lean_inc(x_55); -if (lean_is_exclusive(x_49)) { - lean_ctor_release(x_49, 0); - lean_ctor_release(x_49, 1); - lean_ctor_release(x_49, 2); - lean_ctor_release(x_49, 3); - lean_ctor_release(x_49, 4); - lean_ctor_release(x_49, 5); - x_56 = x_49; -} else { - lean_dec_ref(x_49); - x_56 = lean_box(0); -} -if (lean_is_scalar(x_56)) { - x_57 = lean_alloc_ctor(0, 6, 0); -} else { - x_57 = x_56; -} -lean_ctor_set(x_57, 0, x_51); -lean_ctor_set(x_57, 1, x_52); -lean_ctor_set(x_57, 2, x_34); -lean_ctor_set(x_57, 3, x_53); -lean_ctor_set(x_57, 4, x_54); -lean_ctor_set(x_57, 5, x_55); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_50); -lean_ctor_set(x_58, 1, x_57); -return x_58; -} -} -else -{ -uint8_t x_59; -x_59 = !lean_is_exclusive(x_38); -if (x_59 == 0) -{ -lean_object* x_60; uint8_t x_61; -x_60 = lean_ctor_get(x_38, 1); -x_61 = !lean_is_exclusive(x_60); -if (x_61 == 0) -{ -lean_object* x_62; -x_62 = lean_ctor_get(x_60, 2); -lean_dec(x_62); -lean_ctor_set(x_60, 2, x_34); -return x_38; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_60, 0); -x_64 = lean_ctor_get(x_60, 1); -x_65 = lean_ctor_get(x_60, 3); -x_66 = lean_ctor_get(x_60, 4); -x_67 = lean_ctor_get(x_60, 5); -lean_inc(x_67); -lean_inc(x_66); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_60); -x_68 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_34); -lean_ctor_set(x_68, 3, x_65); -lean_ctor_set(x_68, 4, x_66); -lean_ctor_set(x_68, 5, x_67); -lean_ctor_set(x_38, 1, x_68); -return x_38; -} -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_69 = lean_ctor_get(x_38, 1); -x_70 = lean_ctor_get(x_38, 0); -lean_inc(x_69); -lean_inc(x_70); -lean_dec(x_38); -x_71 = lean_ctor_get(x_69, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_69, 1); -lean_inc(x_72); -x_73 = lean_ctor_get(x_69, 3); -lean_inc(x_73); -x_74 = lean_ctor_get(x_69, 4); -lean_inc(x_74); -x_75 = lean_ctor_get(x_69, 5); -lean_inc(x_75); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - lean_ctor_release(x_69, 2); - lean_ctor_release(x_69, 3); - lean_ctor_release(x_69, 4); - lean_ctor_release(x_69, 5); - x_76 = x_69; -} else { - lean_dec_ref(x_69); - x_76 = lean_box(0); -} -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 6, 0); -} else { - x_77 = x_76; -} -lean_ctor_set(x_77, 0, x_71); -lean_ctor_set(x_77, 1, x_72); -lean_ctor_set(x_77, 2, x_34); -lean_ctor_set(x_77, 3, x_73); -lean_ctor_set(x_77, 4, x_74); -lean_ctor_set(x_77, 5, x_75); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_70); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -} -else -{ -uint8_t x_79; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_79 = !lean_is_exclusive(x_12); -if (x_79 == 0) -{ -return x_12; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_12, 0); -x_81 = lean_ctor_get(x_12, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_12); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; -} -} -} -else -{ -lean_object* x_83; uint8_t x_84; uint8_t x_85; uint8_t x_86; uint8_t x_87; uint8_t x_88; lean_object* x_89; lean_object* x_90; uint8_t x_91; lean_object* x_92; -x_83 = lean_ctor_get(x_5, 0); -x_84 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_85 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_86 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_87 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -lean_inc(x_83); -lean_dec(x_5); -x_88 = 1; -x_89 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_89, 0, x_83); -lean_ctor_set_uint8(x_89, sizeof(void*)*1, x_84); -lean_ctor_set_uint8(x_89, sizeof(void*)*1 + 1, x_85); -lean_ctor_set_uint8(x_89, sizeof(void*)*1 + 2, x_86); -lean_ctor_set_uint8(x_89, sizeof(void*)*1 + 3, x_87); -lean_ctor_set_uint8(x_89, sizeof(void*)*1 + 4, x_88); -lean_inc(x_6); -x_90 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_90, 0, x_89); -lean_ctor_set(x_90, 1, x_6); -lean_ctor_set(x_90, 2, x_7); -x_91 = 0; -lean_inc(x_1); -x_92 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_91, x_1, x_1, x_90, x_4); -if (lean_obj_tag(x_92) == 0) -{ -lean_object* x_93; lean_object* x_94; uint8_t x_95; -x_93 = lean_ctor_get(x_92, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_92, 1); -lean_inc(x_94); -lean_dec(x_92); -x_95 = l_Lean_Expr_isForall(x_93); -if (x_95 == 0) -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; -lean_dec(x_93); -lean_dec(x_6); -lean_dec(x_2); -x_96 = l_Array_empty___closed__1; -x_97 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4___closed__1; -x_98 = l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(x_96, x_97, x_97, x_96, x_3, x_94); -if (lean_obj_tag(x_98) == 0) -{ -lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; -x_99 = lean_ctor_get(x_98, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_98, 1); -lean_inc(x_100); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_101 = x_98; -} else { - lean_dec_ref(x_98); - x_101 = lean_box(0); -} -x_102 = l_Lean_Meta_collectDeps(x_96, x_1); -lean_dec(x_1); -x_103 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_99, x_102); -x_104 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_104, 0, x_103); -lean_ctor_set(x_104, 1, x_102); -if (lean_is_scalar(x_101)) { - x_105 = lean_alloc_ctor(0, 2, 0); -} else { - x_105 = x_101; -} -lean_ctor_set(x_105, 0, x_104); -lean_ctor_set(x_105, 1, x_100); -return x_105; -} -else -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; -lean_dec(x_1); -x_106 = lean_ctor_get(x_98, 0); -lean_inc(x_106); -x_107 = lean_ctor_get(x_98, 1); -lean_inc(x_107); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - x_108 = x_98; -} else { - lean_dec_ref(x_98); - x_108 = lean_box(0); -} -if (lean_is_scalar(x_108)) { - x_109 = lean_alloc_ctor(1, 2, 0); -} else { - x_109 = x_108; -} -lean_ctor_set(x_109, 0, x_106); -lean_ctor_set(x_109, 1, x_107); -return x_109; -} -} -else -{ -lean_object* x_110; uint8_t x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; -lean_dec(x_1); -x_110 = lean_ctor_get(x_94, 2); -lean_inc(x_110); -x_111 = 1; -x_112 = l_Array_empty___closed__1; -x_113 = lean_unsigned_to_nat(0u); -x_114 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5(x_111, x_2, x_6, x_112, x_113, x_93, x_3, x_94); -if (lean_obj_tag(x_114) == 0) -{ -lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; -x_115 = lean_ctor_get(x_114, 1); -lean_inc(x_115); -x_116 = lean_ctor_get(x_114, 0); -lean_inc(x_116); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - x_117 = x_114; -} else { - lean_dec_ref(x_114); - x_117 = lean_box(0); -} -x_118 = lean_ctor_get(x_115, 0); -lean_inc(x_118); -x_119 = lean_ctor_get(x_115, 1); -lean_inc(x_119); -x_120 = lean_ctor_get(x_115, 3); -lean_inc(x_120); -x_121 = lean_ctor_get(x_115, 4); -lean_inc(x_121); -x_122 = lean_ctor_get(x_115, 5); -lean_inc(x_122); -if (lean_is_exclusive(x_115)) { - lean_ctor_release(x_115, 0); - lean_ctor_release(x_115, 1); - lean_ctor_release(x_115, 2); - lean_ctor_release(x_115, 3); - lean_ctor_release(x_115, 4); - lean_ctor_release(x_115, 5); - x_123 = x_115; -} else { - lean_dec_ref(x_115); - x_123 = lean_box(0); -} -if (lean_is_scalar(x_123)) { - x_124 = lean_alloc_ctor(0, 6, 0); -} else { - x_124 = x_123; -} -lean_ctor_set(x_124, 0, x_118); -lean_ctor_set(x_124, 1, x_119); -lean_ctor_set(x_124, 2, x_110); -lean_ctor_set(x_124, 3, x_120); -lean_ctor_set(x_124, 4, x_121); -lean_ctor_set(x_124, 5, x_122); -if (lean_is_scalar(x_117)) { - x_125 = lean_alloc_ctor(0, 2, 0); -} else { - x_125 = x_117; -} -lean_ctor_set(x_125, 0, x_116); -lean_ctor_set(x_125, 1, x_124); -return x_125; -} -else -{ -lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_126 = lean_ctor_get(x_114, 1); -lean_inc(x_126); -x_127 = lean_ctor_get(x_114, 0); -lean_inc(x_127); -if (lean_is_exclusive(x_114)) { - lean_ctor_release(x_114, 0); - lean_ctor_release(x_114, 1); - x_128 = x_114; -} else { - lean_dec_ref(x_114); - x_128 = lean_box(0); -} -x_129 = lean_ctor_get(x_126, 0); -lean_inc(x_129); -x_130 = lean_ctor_get(x_126, 1); -lean_inc(x_130); -x_131 = lean_ctor_get(x_126, 3); -lean_inc(x_131); -x_132 = lean_ctor_get(x_126, 4); -lean_inc(x_132); -x_133 = lean_ctor_get(x_126, 5); -lean_inc(x_133); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - lean_ctor_release(x_126, 2); - lean_ctor_release(x_126, 3); - lean_ctor_release(x_126, 4); - lean_ctor_release(x_126, 5); - x_134 = x_126; -} else { - lean_dec_ref(x_126); - x_134 = lean_box(0); -} -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 6, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_129); -lean_ctor_set(x_135, 1, x_130); -lean_ctor_set(x_135, 2, x_110); -lean_ctor_set(x_135, 3, x_131); -lean_ctor_set(x_135, 4, x_132); -lean_ctor_set(x_135, 5, x_133); -if (lean_is_scalar(x_128)) { - x_136 = lean_alloc_ctor(1, 2, 0); -} else { - x_136 = x_128; -} -lean_ctor_set(x_136, 0, x_127); -lean_ctor_set(x_136, 1, x_135); -return x_136; -} -} -} -else -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_137 = lean_ctor_get(x_92, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_92, 1); -lean_inc(x_138); -if (lean_is_exclusive(x_92)) { - lean_ctor_release(x_92, 0); - lean_ctor_release(x_92, 1); - x_139 = x_92; -} else { - lean_dec_ref(x_92); - x_139 = lean_box(0); -} -if (lean_is_scalar(x_139)) { - x_140 = lean_alloc_ctor(1, 2, 0); -} else { - x_140 = x_139; -} -lean_ctor_set(x_140, 0, x_137); -lean_ctor_set(x_140, 1, x_138); -return x_140; -} -} -} -} -lean_object* l_Lean_Meta_forallBoundedTelescope___at_Lean_Meta_getFunInfo___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4(x_1, x_2, x_3, x_4); -return x_5; -} -} -lean_object* l_Lean_Meta_getFunInfoAuxAux___at_Lean_Meta_getFunInfo___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; uint8_t x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_5 = lean_ctor_get(x_3, 0); -lean_inc(x_5); -x_6 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); -lean_dec(x_5); -x_7 = lean_ctor_get(x_4, 2); -lean_inc(x_7); -x_8 = lean_ctor_get(x_7, 1); -lean_inc(x_8); -lean_dec(x_7); -lean_inc(x_2); -lean_inc(x_1); -x_9 = lean_alloc_ctor(0, 2, 1); -lean_ctor_set(x_9, 0, x_1); -lean_ctor_set(x_9, 1, x_2); -lean_ctor_set_uint8(x_9, sizeof(void*)*2, x_6); -x_10 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(x_8, x_9); -lean_dec(x_8); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; -lean_inc(x_3); -x_11 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_1, x_3, x_4); -if (lean_obj_tag(x_11) == 0) -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -x_13 = lean_ctor_get(x_11, 1); -lean_inc(x_13); -lean_dec(x_11); -x_14 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4(x_12, x_2, x_3, x_13); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; lean_object* x_16; uint8_t x_17; -x_15 = lean_ctor_get(x_14, 1); -lean_inc(x_15); -x_16 = lean_ctor_get(x_15, 2); -lean_inc(x_16); -x_17 = !lean_is_exclusive(x_14); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; -x_18 = lean_ctor_get(x_14, 0); -x_19 = lean_ctor_get(x_14, 1); -lean_dec(x_19); -x_20 = !lean_is_exclusive(x_15); -if (x_20 == 0) -{ -lean_object* x_21; uint8_t x_22; -x_21 = lean_ctor_get(x_15, 2); -lean_dec(x_21); -x_22 = !lean_is_exclusive(x_16); -if (x_22 == 0) -{ -lean_object* x_23; lean_object* x_24; -x_23 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -x_24 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_23, x_9, x_18); -lean_ctor_set(x_16, 1, x_24); -return x_14; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_25 = lean_ctor_get(x_16, 0); -x_26 = lean_ctor_get(x_16, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_16); -lean_inc(x_18); -x_27 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_26, x_9, x_18); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_25); -lean_ctor_set(x_28, 1, x_27); -lean_ctor_set(x_15, 2, x_28); -return x_14; -} -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_29 = lean_ctor_get(x_15, 0); -x_30 = lean_ctor_get(x_15, 1); -x_31 = lean_ctor_get(x_15, 3); -x_32 = lean_ctor_get(x_15, 4); -x_33 = lean_ctor_get(x_15, 5); -lean_inc(x_33); -lean_inc(x_32); -lean_inc(x_31); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_15); -x_34 = lean_ctor_get(x_16, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_16, 1); -lean_inc(x_35); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - x_36 = x_16; -} else { - lean_dec_ref(x_16); - x_36 = lean_box(0); -} -lean_inc(x_18); -x_37 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_35, x_9, x_18); -if (lean_is_scalar(x_36)) { - x_38 = lean_alloc_ctor(0, 2, 0); -} else { - x_38 = x_36; -} -lean_ctor_set(x_38, 0, x_34); -lean_ctor_set(x_38, 1, x_37); -x_39 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_39, 0, x_29); -lean_ctor_set(x_39, 1, x_30); -lean_ctor_set(x_39, 2, x_38); -lean_ctor_set(x_39, 3, x_31); -lean_ctor_set(x_39, 4, x_32); -lean_ctor_set(x_39, 5, x_33); -lean_ctor_set(x_14, 1, x_39); -return x_14; -} -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_40 = lean_ctor_get(x_14, 0); -lean_inc(x_40); -lean_dec(x_14); -x_41 = lean_ctor_get(x_15, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_15, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_15, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_15, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_15, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_15)) { - lean_ctor_release(x_15, 0); - lean_ctor_release(x_15, 1); - lean_ctor_release(x_15, 2); - lean_ctor_release(x_15, 3); - lean_ctor_release(x_15, 4); - lean_ctor_release(x_15, 5); - x_46 = x_15; -} else { - lean_dec_ref(x_15); - x_46 = lean_box(0); -} -x_47 = lean_ctor_get(x_16, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_16, 1); -lean_inc(x_48); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - x_49 = x_16; -} else { - lean_dec_ref(x_16); - x_49 = lean_box(0); -} -lean_inc(x_40); -x_50 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_48, x_9, x_40); -if (lean_is_scalar(x_49)) { - x_51 = lean_alloc_ctor(0, 2, 0); -} else { - x_51 = x_49; -} -lean_ctor_set(x_51, 0, x_47); -lean_ctor_set(x_51, 1, x_50); -if (lean_is_scalar(x_46)) { - x_52 = lean_alloc_ctor(0, 6, 0); -} else { - x_52 = x_46; -} -lean_ctor_set(x_52, 0, x_41); -lean_ctor_set(x_52, 1, x_42); -lean_ctor_set(x_52, 2, x_51); -lean_ctor_set(x_52, 3, x_43); -lean_ctor_set(x_52, 4, x_44); -lean_ctor_set(x_52, 5, x_45); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_40); -lean_ctor_set(x_53, 1, x_52); -return x_53; -} -} -else -{ -uint8_t x_54; -lean_dec(x_9); -x_54 = !lean_is_exclusive(x_14); -if (x_54 == 0) -{ -return x_14; -} -else -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_14, 0); -x_56 = lean_ctor_get(x_14, 1); -lean_inc(x_56); -lean_inc(x_55); -lean_dec(x_14); -x_57 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_57, 0, x_55); -lean_ctor_set(x_57, 1, x_56); -return x_57; -} -} -} -else -{ -uint8_t x_58; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_58 = !lean_is_exclusive(x_11); -if (x_58 == 0) -{ -return x_11; -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_11, 0); -x_60 = lean_ctor_get(x_11, 1); -lean_inc(x_60); -lean_inc(x_59); -lean_dec(x_11); -x_61 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_61, 0, x_59); -lean_ctor_set(x_61, 1, x_60); -return x_61; -} -} -} -else -{ -lean_object* x_62; lean_object* x_63; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_62 = lean_ctor_get(x_10, 0); -lean_inc(x_62); -lean_dec(x_10); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_62); -lean_ctor_set(x_63, 1, x_4); -return x_63; -} -} -} -lean_object* l_Lean_Meta_getFunInfo(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; -x_4 = lean_box(0); -x_5 = l_Lean_Meta_getFunInfoAuxAux___at_Lean_Meta_getFunInfo___spec__1(x_1, x_4, x_2, x_3); -return x_5; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Nat_foldMAux___main___at_Lean_Meta_getFunInfo___spec__2(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_2); -lean_dec(x_1); -return x_7; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__6(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -return x_8; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_4); -lean_dec(x_4); -x_11 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___lambda__1(x_1, x_2, x_3, x_10, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_3); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_1); -lean_dec(x_1); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__7(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -return x_14; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_getFunInfo___spec__8(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -return x_8; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -uint8_t x_9; lean_object* x_10; -x_9 = lean_unbox(x_1); -lean_dec(x_1); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_getFunInfo___spec__5(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l_Lean_Meta_getFunInfoNArgs(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; -x_5 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_5, 0, x_2); -x_6 = l_Lean_Meta_getFunInfoAuxAux___at_Lean_Meta_getFunInfo___spec__1(x_1, x_5, x_3, x_4); -return x_6; -} -} -lean_object* l___private_Init_Lean_Meta_Check_5__checkApp___at_Lean_Meta_check___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -lean_inc(x_3); -lean_inc(x_1); -x_5 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_1, x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -lean_object* x_6; lean_object* x_7; -x_6 = lean_ctor_get(x_5, 1); -lean_inc(x_6); -lean_dec(x_5); -lean_inc(x_3); -lean_inc(x_2); -x_7 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_2, x_3, x_6); -if (lean_obj_tag(x_7) == 0) -{ -lean_object* x_8; lean_object* x_9; -x_8 = lean_ctor_get(x_7, 1); -lean_inc(x_8); -lean_dec(x_7); -lean_inc(x_3); -lean_inc(x_1); -x_9 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_1, x_3, x_8); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; lean_object* x_13; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_9, 1); -lean_inc(x_11); -lean_dec(x_9); -x_12 = 0; -lean_inc(x_3); -lean_inc(x_10); -x_13 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_12, x_10, x_10, x_3, x_11); -lean_dec(x_10); -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - x_16 = x_13; -} else { - lean_dec_ref(x_13); - x_16 = lean_box(0); -} -if (lean_obj_tag(x_14) == 7) -{ -lean_object* x_28; lean_object* x_29; -lean_dec(x_16); -x_28 = lean_ctor_get(x_14, 1); -lean_inc(x_28); -lean_dec(x_14); -lean_inc(x_3); -lean_inc(x_2); -x_29 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_2, x_3, x_15); -if (lean_obj_tag(x_29) == 0) -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_29, 1); -lean_inc(x_31); -lean_dec(x_29); -lean_inc(x_3); -x_32 = l_Lean_Meta_isDefEq(x_28, x_30, x_3, x_31); -lean_dec(x_30); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; uint8_t x_34; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_unbox(x_33); -lean_dec(x_33); -if (x_34 == 0) -{ -uint8_t x_35; -x_35 = !lean_is_exclusive(x_32); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_36 = lean_ctor_get(x_32, 1); -x_37 = lean_ctor_get(x_32, 0); -lean_dec(x_37); -x_38 = lean_ctor_get(x_36, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_36, 1); -lean_inc(x_39); -x_40 = lean_ctor_get(x_3, 1); -lean_inc(x_40); -lean_dec(x_3); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_38); -lean_ctor_set(x_41, 1, x_39); -lean_ctor_set(x_41, 2, x_40); -x_42 = lean_alloc_ctor(12, 3, 0); -lean_ctor_set(x_42, 0, x_1); -lean_ctor_set(x_42, 1, x_2); -lean_ctor_set(x_42, 2, x_41); -lean_ctor_set_tag(x_32, 1); -lean_ctor_set(x_32, 0, x_42); -return x_32; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_43 = lean_ctor_get(x_32, 1); -lean_inc(x_43); -lean_dec(x_32); -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_3, 1); -lean_inc(x_46); -lean_dec(x_3); -x_47 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_47, 0, x_44); -lean_ctor_set(x_47, 1, x_45); -lean_ctor_set(x_47, 2, x_46); -x_48 = lean_alloc_ctor(12, 3, 0); -lean_ctor_set(x_48, 0, x_1); -lean_ctor_set(x_48, 1, x_2); -lean_ctor_set(x_48, 2, x_47); -x_49 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_43); -return x_49; -} -} -else -{ -uint8_t x_50; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_50 = !lean_is_exclusive(x_32); -if (x_50 == 0) -{ -lean_object* x_51; lean_object* x_52; -x_51 = lean_ctor_get(x_32, 0); -lean_dec(x_51); -x_52 = lean_box(0); -lean_ctor_set(x_32, 0, x_52); -return x_32; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_53 = lean_ctor_get(x_32, 1); -lean_inc(x_53); -lean_dec(x_32); -x_54 = lean_box(0); -x_55 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_53); -return x_55; -} -} -} -else -{ -uint8_t x_56; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_56 = !lean_is_exclusive(x_32); -if (x_56 == 0) -{ -return x_32; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_32, 0); -x_58 = lean_ctor_get(x_32, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_32); -x_59 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -return x_59; -} -} -} -else -{ -uint8_t x_60; -lean_dec(x_28); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_60 = !lean_is_exclusive(x_29); -if (x_60 == 0) -{ -return x_29; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_29, 0); -x_62 = lean_ctor_get(x_29, 1); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_29); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_61); -lean_ctor_set(x_63, 1, x_62); -return x_63; -} -} -} -else -{ -lean_object* x_64; -x_64 = lean_box(0); -x_17 = x_64; -goto block_27; -} -block_27: -{ -uint8_t x_18; -lean_dec(x_17); -x_18 = l_Lean_Expr_isForall(x_14); -lean_dec(x_14); -if (x_18 == 0) -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_19 = lean_ctor_get(x_15, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_15, 1); -lean_inc(x_20); -x_21 = lean_ctor_get(x_3, 1); -lean_inc(x_21); -lean_dec(x_3); -x_22 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_22, 0, x_19); -lean_ctor_set(x_22, 1, x_20); -lean_ctor_set(x_22, 2, x_21); -x_23 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_23, 0, x_1); -lean_ctor_set(x_23, 1, x_2); -lean_ctor_set(x_23, 2, x_22); -if (lean_is_scalar(x_16)) { - x_24 = lean_alloc_ctor(1, 2, 0); -} else { - x_24 = x_16; - lean_ctor_set_tag(x_24, 1); -} -lean_ctor_set(x_24, 0, x_23); -lean_ctor_set(x_24, 1, x_15); -return x_24; -} -else -{ -lean_object* x_25; lean_object* x_26; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_25 = lean_box(0); -if (lean_is_scalar(x_16)) { - x_26 = lean_alloc_ctor(0, 2, 0); -} else { - x_26 = x_16; -} -lean_ctor_set(x_26, 0, x_25); -lean_ctor_set(x_26, 1, x_15); -return x_26; -} -} -} -else -{ -uint8_t x_65; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_65 = !lean_is_exclusive(x_13); -if (x_65 == 0) -{ -return x_13; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_13, 0); -x_67 = lean_ctor_get(x_13, 1); -lean_inc(x_67); -lean_inc(x_66); -lean_dec(x_13); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_66); -lean_ctor_set(x_68, 1, x_67); -return x_68; -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_69 = !lean_is_exclusive(x_9); -if (x_69 == 0) -{ -return x_9; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_9, 0); -x_71 = lean_ctor_get(x_9, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_9); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_73 = !lean_is_exclusive(x_7); -if (x_73 == 0) -{ -return x_7; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_7, 0); -x_75 = lean_ctor_get(x_7, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_7); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_77 = !lean_is_exclusive(x_5); -if (x_77 == 0) -{ -return x_5; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_5, 0); -x_79 = lean_ctor_get(x_5, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_5); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_check___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -lean_inc(x_2); -lean_inc(x_1); -x_4 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_1, x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; -x_5 = lean_ctor_get(x_4, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_4, 1); -lean_inc(x_6); -lean_dec(x_4); -x_7 = 0; -lean_inc(x_2); -lean_inc(x_5); -x_8 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_7, x_5, x_5, x_2, x_6); -lean_dec(x_5); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -switch (lean_obj_tag(x_9)) { -case 2: -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_8, 1); -lean_inc(x_10); -lean_dec(x_8); -x_11 = lean_ctor_get(x_9, 0); -lean_inc(x_11); -lean_dec(x_9); -lean_inc(x_11); -x_12 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_11, x_2, x_10); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; uint8_t x_14; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_unbox(x_13); -lean_dec(x_13); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -lean_dec(x_1); -x_15 = lean_ctor_get(x_12, 1); -lean_inc(x_15); -lean_dec(x_12); -x_16 = l_Lean_Meta_mkFreshId___rarg(x_15); -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -x_19 = l_Lean_mkLevelMVar(x_17); -lean_inc(x_19); -x_20 = l_Lean_mkSort(x_19); -x_21 = l_Lean_Meta_assignExprMVar(x_11, x_20, x_2, x_18); -lean_dec(x_2); -if (lean_obj_tag(x_21) == 0) -{ -uint8_t x_22; -x_22 = !lean_is_exclusive(x_21); -if (x_22 == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_21, 0); -lean_dec(x_23); -lean_ctor_set(x_21, 0, x_19); -return x_21; -} -else -{ -lean_object* x_24; lean_object* x_25; -x_24 = lean_ctor_get(x_21, 1); -lean_inc(x_24); -lean_dec(x_21); -x_25 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_25, 0, x_19); -lean_ctor_set(x_25, 1, x_24); -return x_25; -} -} -else -{ -uint8_t x_26; -lean_dec(x_19); -x_26 = !lean_is_exclusive(x_21); -if (x_26 == 0) -{ -return x_21; -} -else -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_27 = lean_ctor_get(x_21, 0); -x_28 = lean_ctor_get(x_21, 1); -lean_inc(x_28); -lean_inc(x_27); -lean_dec(x_21); -x_29 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_29, 0, x_27); -lean_ctor_set(x_29, 1, x_28); -return x_29; -} -} -} -else -{ -uint8_t x_30; -lean_dec(x_11); -x_30 = !lean_is_exclusive(x_12); -if (x_30 == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_31 = lean_ctor_get(x_12, 1); -x_32 = lean_ctor_get(x_12, 0); -lean_dec(x_32); -x_33 = lean_ctor_get(x_31, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_31, 1); -lean_inc(x_34); -x_35 = lean_ctor_get(x_2, 1); -lean_inc(x_35); -lean_dec(x_2); -x_36 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_36, 0, x_33); -lean_ctor_set(x_36, 1, x_34); -lean_ctor_set(x_36, 2, x_35); -x_37 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_37, 0, x_1); -lean_ctor_set(x_37, 1, x_36); -lean_ctor_set_tag(x_12, 1); -lean_ctor_set(x_12, 0, x_37); -return x_12; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_38 = lean_ctor_get(x_12, 1); -lean_inc(x_38); -lean_dec(x_12); -x_39 = lean_ctor_get(x_38, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_38, 1); -lean_inc(x_40); -x_41 = lean_ctor_get(x_2, 1); -lean_inc(x_41); -lean_dec(x_2); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_39); -lean_ctor_set(x_42, 1, x_40); -lean_ctor_set(x_42, 2, x_41); -x_43 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_43, 0, x_1); -lean_ctor_set(x_43, 1, x_42); -x_44 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_44, 0, x_43); -lean_ctor_set(x_44, 1, x_38); -return x_44; -} -} -} -else -{ -uint8_t x_45; -lean_dec(x_11); -lean_dec(x_2); -lean_dec(x_1); -x_45 = !lean_is_exclusive(x_12); -if (x_45 == 0) -{ -return x_12; -} -else -{ -lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_46 = lean_ctor_get(x_12, 0); -x_47 = lean_ctor_get(x_12, 1); -lean_inc(x_47); -lean_inc(x_46); -lean_dec(x_12); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_46); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -} -case 3: -{ -uint8_t x_49; -lean_dec(x_2); -lean_dec(x_1); -x_49 = !lean_is_exclusive(x_8); -if (x_49 == 0) -{ -lean_object* x_50; lean_object* x_51; -x_50 = lean_ctor_get(x_8, 0); -lean_dec(x_50); -x_51 = lean_ctor_get(x_9, 0); -lean_inc(x_51); -lean_dec(x_9); -lean_ctor_set(x_8, 0, x_51); -return x_8; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_8, 1); -lean_inc(x_52); -lean_dec(x_8); -x_53 = lean_ctor_get(x_9, 0); -lean_inc(x_53); -lean_dec(x_9); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_53); -lean_ctor_set(x_54, 1, x_52); -return x_54; -} -} -default: -{ -uint8_t x_55; -lean_dec(x_9); -x_55 = !lean_is_exclusive(x_8); -if (x_55 == 0) -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_56 = lean_ctor_get(x_8, 1); -x_57 = lean_ctor_get(x_8, 0); -lean_dec(x_57); -x_58 = lean_ctor_get(x_56, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_56, 1); -lean_inc(x_59); -x_60 = lean_ctor_get(x_2, 1); -lean_inc(x_60); -lean_dec(x_2); -x_61 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_61, 0, x_58); -lean_ctor_set(x_61, 1, x_59); -lean_ctor_set(x_61, 2, x_60); -x_62 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_62, 0, x_1); -lean_ctor_set(x_62, 1, x_61); -lean_ctor_set_tag(x_8, 1); -lean_ctor_set(x_8, 0, x_62); -return x_8; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_63 = lean_ctor_get(x_8, 1); -lean_inc(x_63); -lean_dec(x_8); -x_64 = lean_ctor_get(x_63, 0); -lean_inc(x_64); -x_65 = lean_ctor_get(x_63, 1); -lean_inc(x_65); -x_66 = lean_ctor_get(x_2, 1); -lean_inc(x_66); -lean_dec(x_2); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_64); -lean_ctor_set(x_67, 1, x_65); -lean_ctor_set(x_67, 2, x_66); -x_68 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_68, 0, x_1); -lean_ctor_set(x_68, 1, x_67); -x_69 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_63); -return x_69; -} -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_2); -lean_dec(x_1); -x_70 = !lean_is_exclusive(x_8); -if (x_70 == 0) -{ -return x_8; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_8, 0); -x_72 = lean_ctor_get(x_8, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_8); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_2); -lean_dec(x_1); -x_74 = !lean_is_exclusive(x_4); -if (x_74 == 0) -{ -return x_4; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_4, 0); -x_76 = lean_ctor_get(x_4, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_4); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_getLevelAux___at_Lean_Meta_check___spec__6(x_1, x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -uint8_t x_5; -x_5 = !lean_is_exclusive(x_4); -if (x_5 == 0) -{ -lean_object* x_6; lean_object* x_7; -x_6 = lean_ctor_get(x_4, 0); -lean_dec(x_6); -x_7 = lean_box(0); -lean_ctor_set(x_4, 0, x_7); -return x_4; -} -else -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_8 = lean_ctor_get(x_4, 1); -lean_inc(x_8); -lean_dec(x_4); -x_9 = lean_box(0); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_8); -return x_10; -} -} -else -{ -uint8_t x_11; -x_11 = !lean_is_exclusive(x_4); -if (x_11 == 0) -{ -return x_4; -} -else -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = lean_ctor_get(x_4, 0); -x_13 = lean_ctor_get(x_4, 1); -lean_inc(x_13); -lean_inc(x_12); -lean_dec(x_4); -x_14 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_14, 0, x_12); -lean_ctor_set(x_14, 1, x_13); -return x_14; -} -} -} -} -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; uint8_t x_6; -x_5 = lean_array_get_size(x_1); -x_6 = lean_nat_dec_lt(x_2, x_5); -lean_dec(x_5); -if (x_6 == 0) -{ -lean_object* x_7; lean_object* x_8; -lean_dec(x_3); -lean_dec(x_2); -x_7 = lean_box(0); -x_8 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_8, 0, x_7); -lean_ctor_set(x_8, 1, x_4); -return x_8; -} -else -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_array_fget(x_1, x_2); -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_add(x_2, x_10); -lean_dec(x_2); -lean_inc(x_3); -x_12 = l_Lean_Meta_getFVarLocalDecl(x_9, x_3, x_4); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_9); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -x_15 = lean_ctor_get(x_13, 3); -lean_inc(x_15); -lean_dec(x_13); -lean_inc(x_3); -lean_inc(x_15); -x_16 = l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(x_15, x_3, x_14); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_ctor_get(x_16, 1); -lean_inc(x_17); -lean_dec(x_16); -lean_inc(x_3); -x_18 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_15, x_3, x_17); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; -x_19 = lean_ctor_get(x_18, 1); -lean_inc(x_19); -lean_dec(x_18); -x_2 = x_11; -x_4 = x_19; -goto _start; -} -else -{ -uint8_t x_21; -lean_dec(x_11); -lean_dec(x_3); -x_21 = !lean_is_exclusive(x_18); -if (x_21 == 0) -{ -return x_18; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_18, 0); -x_23 = lean_ctor_get(x_18, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_18); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -else -{ -uint8_t x_25; -lean_dec(x_15); -lean_dec(x_11); -lean_dec(x_3); -x_25 = !lean_is_exclusive(x_16); -if (x_25 == 0) -{ -return x_16; -} -else -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_16, 0); -x_27 = lean_ctor_get(x_16, 1); -lean_inc(x_27); -lean_inc(x_26); -lean_dec(x_16); -x_28 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_28, 0, x_26); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_29 = lean_ctor_get(x_12, 1); -lean_inc(x_29); -lean_dec(x_12); -x_30 = lean_ctor_get(x_13, 3); -lean_inc(x_30); -x_31 = lean_ctor_get(x_13, 4); -lean_inc(x_31); -lean_dec(x_13); -lean_inc(x_3); -lean_inc(x_30); -x_32 = l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(x_30, x_3, x_29); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; -x_33 = lean_ctor_get(x_32, 1); -lean_inc(x_33); -lean_dec(x_32); -lean_inc(x_3); -lean_inc(x_30); -x_34 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_30, x_3, x_33); -if (lean_obj_tag(x_34) == 0) -{ -lean_object* x_35; lean_object* x_36; -x_35 = lean_ctor_get(x_34, 1); -lean_inc(x_35); -lean_dec(x_34); -lean_inc(x_3); -lean_inc(x_31); -x_36 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_isProp___spec__2(x_31, x_3, x_35); -if (lean_obj_tag(x_36) == 0) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -lean_inc(x_3); -x_39 = l_Lean_Meta_isDefEq(x_30, x_37, x_3, x_38); -lean_dec(x_37); -if (lean_obj_tag(x_39) == 0) -{ -lean_object* x_40; uint8_t x_41; -x_40 = lean_ctor_get(x_39, 0); -lean_inc(x_40); -x_41 = lean_unbox(x_40); -lean_dec(x_40); -if (x_41 == 0) -{ -uint8_t x_42; -lean_dec(x_31); -lean_dec(x_11); -x_42 = !lean_is_exclusive(x_39); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_43 = lean_ctor_get(x_39, 1); -x_44 = lean_ctor_get(x_39, 0); -lean_dec(x_44); -x_45 = lean_ctor_get(x_43, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_43, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_3, 1); -lean_inc(x_47); -lean_dec(x_3); -x_48 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_48, 0, x_45); -lean_ctor_set(x_48, 1, x_46); -lean_ctor_set(x_48, 2, x_47); -x_49 = l_Lean_Expr_fvarId_x21(x_9); -lean_dec(x_9); -x_50 = lean_alloc_ctor(11, 2, 0); -lean_ctor_set(x_50, 0, x_49); -lean_ctor_set(x_50, 1, x_48); -lean_ctor_set_tag(x_39, 1); -lean_ctor_set(x_39, 0, x_50); -return x_39; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_51 = lean_ctor_get(x_39, 1); -lean_inc(x_51); -lean_dec(x_39); -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -x_54 = lean_ctor_get(x_3, 1); -lean_inc(x_54); -lean_dec(x_3); -x_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_52); -lean_ctor_set(x_55, 1, x_53); -lean_ctor_set(x_55, 2, x_54); -x_56 = l_Lean_Expr_fvarId_x21(x_9); -lean_dec(x_9); -x_57 = lean_alloc_ctor(11, 2, 0); -lean_ctor_set(x_57, 0, x_56); -lean_ctor_set(x_57, 1, x_55); -x_58 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_51); -return x_58; -} -} -else -{ -lean_object* x_59; lean_object* x_60; -lean_dec(x_9); -x_59 = lean_ctor_get(x_39, 1); -lean_inc(x_59); -lean_dec(x_39); -lean_inc(x_3); -x_60 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_31, x_3, x_59); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; -x_61 = lean_ctor_get(x_60, 1); -lean_inc(x_61); -lean_dec(x_60); -x_2 = x_11; -x_4 = x_61; -goto _start; -} -else -{ -uint8_t x_63; -lean_dec(x_11); -lean_dec(x_3); -x_63 = !lean_is_exclusive(x_60); -if (x_63 == 0) -{ -return x_60; -} -else -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_60, 0); -x_65 = lean_ctor_get(x_60, 1); -lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_60); -x_66 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_66, 0, x_64); -lean_ctor_set(x_66, 1, x_65); -return x_66; -} -} -} -} -else -{ -uint8_t x_67; -lean_dec(x_31); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_3); -x_67 = !lean_is_exclusive(x_39); -if (x_67 == 0) -{ -return x_39; -} -else -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_68 = lean_ctor_get(x_39, 0); -x_69 = lean_ctor_get(x_39, 1); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_39); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -return x_70; -} -} -} -else -{ -uint8_t x_71; -lean_dec(x_31); -lean_dec(x_30); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_3); -x_71 = !lean_is_exclusive(x_36); -if (x_71 == 0) -{ -return x_36; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_36, 0); -x_73 = lean_ctor_get(x_36, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_36); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_31); -lean_dec(x_30); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_3); -x_75 = !lean_is_exclusive(x_34); -if (x_75 == 0) -{ -return x_34; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_34, 0); -x_77 = lean_ctor_get(x_34, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_34); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -else -{ -uint8_t x_79; -lean_dec(x_31); -lean_dec(x_30); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_3); -x_79 = !lean_is_exclusive(x_32); -if (x_79 == 0) -{ -return x_32; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_32, 0); -x_81 = lean_ctor_get(x_32, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_32); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; -} -} -} -} -else -{ -uint8_t x_83; -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_3); -x_83 = !lean_is_exclusive(x_12); -if (x_83 == 0) -{ -return x_12; -} -else -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_84 = lean_ctor_get(x_12, 0); -x_85 = lean_ctor_get(x_12, 1); -lean_inc(x_85); -lean_inc(x_84); -lean_dec(x_12); -x_86 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_86, 0, x_84); -lean_ctor_set(x_86, 1, x_85); -return x_86; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__14(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_array_get_size(x_2); -x_7 = lean_nat_dec_lt(x_3, x_6); -lean_dec(x_6); -if (x_7 == 0) -{ -lean_object* x_8; -lean_dec(x_4); -lean_dec(x_3); -x_8 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_8) == 4) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -lean_dec(x_8); -x_10 = lean_ctor_get(x_5, 0); -lean_inc(x_10); -lean_inc(x_9); -x_11 = lean_is_class(x_10, x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -lean_dec(x_9); -x_12 = lean_box(0); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_5); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_14, 0, x_9); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_5); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_8); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_5); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_array_fget(x_2, x_3); -lean_inc(x_4); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_LocalDecl_type(x_20); -lean_dec(x_20); -lean_inc(x_4); -lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -switch (lean_obj_tag(x_24)) { -case 0: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_18); -x_25 = lean_ctor_get(x_23, 1); -lean_inc(x_25); -lean_dec(x_23); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_3, x_26); -lean_dec(x_3); -x_3 = x_27; -x_5 = x_25; -goto _start; -} -case 1: -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); -lean_dec(x_3); -x_33 = !lean_is_exclusive(x_4); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_4, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_18); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_4, 2, x_36); -x_3 = x_32; -x_5 = x_29; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_4, 0); -x_39 = lean_ctor_get(x_4, 1); -x_40 = lean_ctor_get(x_4, 2); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_dec(x_4); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_30); -lean_ctor_set(x_41, 1, x_18); -x_42 = lean_array_push(x_40, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_39); -lean_ctor_set(x_43, 2, x_42); -x_3 = x_32; -x_4 = x_43; -x_5 = x_29; -goto _start; -} -} -default: -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_ctor_get(x_23, 1); -lean_inc(x_45); -lean_dec(x_23); -lean_inc(x_4); -x_46 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_22, x_4, x_45); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_18); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_3, x_49); -lean_dec(x_3); -x_3 = x_50; -x_5 = x_48; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_ctor_get(x_47, 0); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_3, x_54); -lean_dec(x_3); -x_56 = !lean_is_exclusive(x_4); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_4, 2); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_18); -x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_4, 2, x_59); -x_3 = x_55; -x_5 = x_52; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_4, 0); -x_62 = lean_ctor_get(x_4, 1); -x_63 = lean_ctor_get(x_4, 2); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_4); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_53); -lean_ctor_set(x_64, 1, x_18); -x_65 = lean_array_push(x_63, x_64); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_62); -lean_ctor_set(x_66, 2, x_65); -x_3 = x_55; -x_4 = x_66; -x_5 = x_52; -goto _start; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_68 = !lean_is_exclusive(x_46); -if (x_68 == 0) -{ -return x_46; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_46, 0); -x_70 = lean_ctor_get(x_46, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_46); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_72 = !lean_is_exclusive(x_23); -if (x_72 == 0) -{ -return x_23; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_23, 0); -x_74 = lean_ctor_get(x_23, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_23); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -uint8_t x_76; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_76 = !lean_is_exclusive(x_19); -if (x_76 == 0) -{ -return x_19; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_19, 0); -x_78 = lean_ctor_get(x_19, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_19); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___lambda__1(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; -x_10 = l_Lean_Expr_isForall(x_7); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -x_11 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_11) == 4) -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -lean_dec(x_11); -x_13 = lean_ctor_get(x_9, 0); -lean_inc(x_13); -lean_inc(x_12); -x_14 = lean_is_class(x_13, x_12); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; -lean_dec(x_12); -x_15 = lean_box(0); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_9); -return x_16; -} -else -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_17, 0, x_12); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_9); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; -lean_dec(x_11); -x_19 = lean_box(0); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_19); -lean_ctor_set(x_20, 1, x_9); -return x_20; -} -} -else -{ -lean_object* x_21; -x_21 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13(x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_21; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; -lean_inc(x_8); -x_13 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); -lean_closure_set(x_13, 0, x_8); -x_14 = lean_box(x_1); -lean_inc(x_7); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_8); -x_15 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___lambda__1___boxed), 9, 6); -lean_closure_set(x_15, 0, x_8); -lean_closure_set(x_15, 1, x_14); -lean_closure_set(x_15, 2, x_2); -lean_closure_set(x_15, 3, x_3); -lean_closure_set(x_15, 4, x_4); -lean_closure_set(x_15, 5, x_7); -x_16 = lean_array_get_size(x_9); -x_17 = lean_nat_dec_lt(x_10, x_16); -lean_dec(x_16); -if (x_17 == 0) -{ -lean_object* x_18; -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_18 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_13, x_15, x_11, x_12); -return x_18; -} -else -{ -lean_object* x_19; lean_object* x_20; -lean_dec(x_15); -lean_dec(x_13); -x_19 = lean_array_fget(x_9, x_10); -lean_inc(x_11); -x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_11, x_12); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_20, 1); -lean_inc(x_22); -lean_dec(x_20); -x_23 = l_Lean_LocalDecl_type(x_21); -lean_dec(x_21); -lean_inc(x_11); -lean_inc(x_23); -x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_11, x_22); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -switch (lean_obj_tag(x_25)) { -case 0: -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_dec(x_23); -lean_dec(x_19); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_10, x_27); -lean_dec(x_10); -x_10 = x_28; -x_12 = x_26; -goto _start; -} -case 1: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 1); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_10, x_32); -lean_dec(x_10); -x_34 = !lean_is_exclusive(x_11); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_11, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_31); -lean_ctor_set(x_36, 1, x_19); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_11, 2, x_37); -x_10 = x_33; -x_12 = x_30; -goto _start; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_11, 0); -x_40 = lean_ctor_get(x_11, 1); -x_41 = lean_ctor_get(x_11, 2); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_11); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_31); -lean_ctor_set(x_42, 1, x_19); -x_43 = lean_array_push(x_41, x_42); -x_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_43); -x_10 = x_33; -x_11 = x_44; -x_12 = x_30; -goto _start; -} -} -default: -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_24, 1); -lean_inc(x_46); -lean_dec(x_24); -lean_inc(x_11); -x_47 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_23, x_11, x_46); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_19); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -x_50 = lean_unsigned_to_nat(1u); -x_51 = lean_nat_add(x_10, x_50); -lean_dec(x_10); -x_10 = x_51; -x_12 = x_49; -goto _start; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; -x_53 = lean_ctor_get(x_47, 1); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_ctor_get(x_48, 0); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_unsigned_to_nat(1u); -x_56 = lean_nat_add(x_10, x_55); -lean_dec(x_10); -x_57 = !lean_is_exclusive(x_11); -if (x_57 == 0) -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_11, 2); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_54); -lean_ctor_set(x_59, 1, x_19); -x_60 = lean_array_push(x_58, x_59); -lean_ctor_set(x_11, 2, x_60); -x_10 = x_56; -x_12 = x_53; -goto _start; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_62 = lean_ctor_get(x_11, 0); -x_63 = lean_ctor_get(x_11, 1); -x_64 = lean_ctor_get(x_11, 2); -lean_inc(x_64); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_11); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_54); -lean_ctor_set(x_65, 1, x_19); -x_66 = lean_array_push(x_64, x_65); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_63); -lean_ctor_set(x_67, 2, x_66); -x_10 = x_56; -x_11 = x_67; -x_12 = x_53; -goto _start; -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_69 = !lean_is_exclusive(x_47); -if (x_69 == 0) -{ -return x_47; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_47, 0); -x_71 = lean_ctor_get(x_47, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_47); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_73 = !lean_is_exclusive(x_24); -if (x_73 == 0) -{ -return x_24; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_24, 0); -x_75 = lean_ctor_get(x_24, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_24); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_77 = !lean_is_exclusive(x_20); -if (x_77 == 0) -{ -return x_20; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_20, 0); -x_79 = lean_ctor_get(x_20, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_20); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__16(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_array_get_size(x_2); -x_7 = lean_nat_dec_lt(x_3, x_6); -lean_dec(x_6); -if (x_7 == 0) -{ -lean_object* x_8; -lean_dec(x_4); -lean_dec(x_3); -x_8 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_8) == 4) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -lean_dec(x_8); -x_10 = lean_ctor_get(x_5, 0); -lean_inc(x_10); -lean_inc(x_9); -x_11 = lean_is_class(x_10, x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -lean_dec(x_9); -x_12 = lean_box(0); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_5); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_14, 0, x_9); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_5); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_8); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_5); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_array_fget(x_2, x_3); -lean_inc(x_4); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_LocalDecl_type(x_20); -lean_dec(x_20); -lean_inc(x_4); -lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -switch (lean_obj_tag(x_24)) { -case 0: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_18); -x_25 = lean_ctor_get(x_23, 1); -lean_inc(x_25); -lean_dec(x_23); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_3, x_26); -lean_dec(x_3); -x_3 = x_27; -x_5 = x_25; -goto _start; -} -case 1: -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_3, x_31); -lean_dec(x_3); -x_33 = !lean_is_exclusive(x_4); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_4, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_18); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_4, 2, x_36); -x_3 = x_32; -x_5 = x_29; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_4, 0); -x_39 = lean_ctor_get(x_4, 1); -x_40 = lean_ctor_get(x_4, 2); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_dec(x_4); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_30); -lean_ctor_set(x_41, 1, x_18); -x_42 = lean_array_push(x_40, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_39); -lean_ctor_set(x_43, 2, x_42); -x_3 = x_32; -x_4 = x_43; -x_5 = x_29; -goto _start; -} -} -default: -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_ctor_get(x_23, 1); -lean_inc(x_45); -lean_dec(x_23); -lean_inc(x_4); -x_46 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_22, x_4, x_45); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_18); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_3, x_49); -lean_dec(x_3); -x_3 = x_50; -x_5 = x_48; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_ctor_get(x_47, 0); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_3, x_54); -lean_dec(x_3); -x_56 = !lean_is_exclusive(x_4); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_4, 2); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_18); -x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_4, 2, x_59); -x_3 = x_55; -x_5 = x_52; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_4, 0); -x_62 = lean_ctor_get(x_4, 1); -x_63 = lean_ctor_get(x_4, 2); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_4); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_53); -lean_ctor_set(x_64, 1, x_18); -x_65 = lean_array_push(x_63, x_64); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_62); -lean_ctor_set(x_66, 2, x_65); -x_3 = x_55; -x_4 = x_66; -x_5 = x_52; -goto _start; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_68 = !lean_is_exclusive(x_46); -if (x_68 == 0) -{ -return x_46; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_46, 0); -x_70 = lean_ctor_get(x_46, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_46); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_72 = !lean_is_exclusive(x_23); -if (x_72 == 0) -{ -return x_23; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_23, 0); -x_74 = lean_ctor_get(x_23, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_23); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -uint8_t x_76; -lean_dec(x_18); -lean_dec(x_4); -lean_dec(x_3); -x_76 = !lean_is_exclusive(x_19); -if (x_76 == 0) -{ -return x_19; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_19, 0); -x_78 = lean_ctor_get(x_19, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_19); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_22 = lean_ctor_get(x_6, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_6, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 2); -lean_inc(x_24); -x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); -lean_dec(x_6); -x_26 = lean_array_get_size(x_4); -lean_inc(x_4); -x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); -lean_dec(x_26); -lean_dec(x_23); -x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = (uint8_t)((x_25 << 24) >> 61); -lean_inc(x_29); -x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); -x_33 = l_Lean_mkFVar(x_29); -x_34 = lean_array_push(x_4, x_33); -if (lean_obj_tag(x_2) == 0) -{ -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -else -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_2, 0); -lean_inc(x_36); -x_37 = lean_array_get_size(x_34); -x_38 = lean_nat_dec_lt(x_37, x_36); -lean_dec(x_36); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -lean_dec(x_2); -lean_inc(x_34); -x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); -lean_dec(x_37); -lean_dec(x_24); -x_40 = !lean_is_exclusive(x_7); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_7, 1); -lean_dec(x_41); -lean_ctor_set(x_7, 1, x_32); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__16(x_39, x_34, x_5, x_7, x_30); -lean_dec(x_34); -lean_dec(x_39); -return x_42; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_7, 0); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_32); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__16(x_39, x_34, x_5, x_45, x_30); -lean_dec(x_34); -lean_dec(x_39); -return x_46; -} -} -else -{ -lean_dec(x_37); -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -} -} -else -{ -lean_object* x_48; -x_48 = lean_box(0); -x_9 = x_48; -goto block_21; -} -block_21: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_7, 1); -lean_dec(x_13); -lean_inc(x_3); -lean_ctor_set(x_7, 1, x_3); -if (x_1 == 0) -{ -lean_object* x_14; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__14(x_11, x_4, x_5, x_7, x_8); -lean_dec(x_4); -lean_dec(x_11); -return x_14; -} -else -{ -lean_object* x_15; -lean_inc(x_5); -lean_inc(x_4); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_7, 0); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_7); -lean_inc(x_3); -x_18 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_3); -lean_ctor_set(x_18, 2, x_17); -if (x_1 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__14(x_11, x_4, x_5, x_18, x_8); -lean_dec(x_4); -lean_dec(x_11); -return x_19; -} -else -{ -lean_object* x_20; -lean_inc(x_5); -lean_inc(x_4); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_20; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_check___spec__12(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -uint8_t x_5; lean_object* x_6; -x_5 = 0; -lean_inc(x_3); -lean_inc(x_1); -x_6 = l___private_Init_Lean_Meta_3__auxFixpoint___main(x_5, x_1, x_1, x_3, x_4); -if (lean_obj_tag(x_6) == 0) -{ -uint8_t x_7; -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -lean_object* x_8; lean_object* x_9; uint8_t x_10; -x_8 = lean_ctor_get(x_6, 0); -x_9 = lean_ctor_get(x_6, 1); -x_10 = l_Lean_Expr_isForall(x_8); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -x_11 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_11) == 4) -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -lean_dec(x_11); -x_13 = lean_ctor_get(x_9, 0); -lean_inc(x_13); -lean_inc(x_12); -x_14 = lean_is_class(x_13, x_12); -if (x_14 == 0) -{ -lean_object* x_15; -lean_dec(x_12); -x_15 = lean_box(0); -lean_ctor_set(x_6, 0, x_15); -return x_6; -} -else -{ -lean_object* x_16; -x_16 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_16, 0, x_12); -lean_ctor_set(x_6, 0, x_16); -return x_6; -} -} -else -{ -lean_object* x_17; -lean_dec(x_11); -x_17 = lean_box(0); -lean_ctor_set(x_6, 0, x_17); -return x_6; -} -} -else -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -lean_free_object(x_6); -lean_dec(x_1); -x_18 = lean_ctor_get(x_9, 2); -lean_inc(x_18); -x_19 = lean_ctor_get(x_3, 1); -lean_inc(x_19); -x_20 = 1; -x_21 = l_Array_empty___closed__1; -x_22 = lean_unsigned_to_nat(0u); -x_23 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13(x_20, x_2, x_19, x_21, x_22, x_8, x_3, x_9); -if (lean_obj_tag(x_23) == 0) -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_23); -if (x_24 == 0) -{ -lean_object* x_25; uint8_t x_26; -x_25 = lean_ctor_get(x_23, 1); -x_26 = !lean_is_exclusive(x_25); -if (x_26 == 0) -{ -lean_object* x_27; -x_27 = lean_ctor_get(x_25, 2); -lean_dec(x_27); -lean_ctor_set(x_25, 2, x_18); -return x_23; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_28 = lean_ctor_get(x_25, 0); -x_29 = lean_ctor_get(x_25, 1); -x_30 = lean_ctor_get(x_25, 3); -x_31 = lean_ctor_get(x_25, 4); -x_32 = lean_ctor_get(x_25, 5); -lean_inc(x_32); -lean_inc(x_31); -lean_inc(x_30); -lean_inc(x_29); -lean_inc(x_28); -lean_dec(x_25); -x_33 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_33, 0, x_28); -lean_ctor_set(x_33, 1, x_29); -lean_ctor_set(x_33, 2, x_18); -lean_ctor_set(x_33, 3, x_30); -lean_ctor_set(x_33, 4, x_31); -lean_ctor_set(x_33, 5, x_32); -lean_ctor_set(x_23, 1, x_33); -return x_23; -} -} -else -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_34 = lean_ctor_get(x_23, 1); -x_35 = lean_ctor_get(x_23, 0); -lean_inc(x_34); -lean_inc(x_35); -lean_dec(x_23); -x_36 = lean_ctor_get(x_34, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_34, 1); -lean_inc(x_37); -x_38 = lean_ctor_get(x_34, 3); -lean_inc(x_38); -x_39 = lean_ctor_get(x_34, 4); -lean_inc(x_39); -x_40 = lean_ctor_get(x_34, 5); -lean_inc(x_40); -if (lean_is_exclusive(x_34)) { - lean_ctor_release(x_34, 0); - lean_ctor_release(x_34, 1); - lean_ctor_release(x_34, 2); - lean_ctor_release(x_34, 3); - lean_ctor_release(x_34, 4); - lean_ctor_release(x_34, 5); - x_41 = x_34; -} else { - lean_dec_ref(x_34); - x_41 = lean_box(0); -} -if (lean_is_scalar(x_41)) { - x_42 = lean_alloc_ctor(0, 6, 0); -} else { - x_42 = x_41; -} -lean_ctor_set(x_42, 0, x_36); -lean_ctor_set(x_42, 1, x_37); -lean_ctor_set(x_42, 2, x_18); -lean_ctor_set(x_42, 3, x_38); -lean_ctor_set(x_42, 4, x_39); -lean_ctor_set(x_42, 5, x_40); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_35); -lean_ctor_set(x_43, 1, x_42); -return x_43; -} -} -else -{ -uint8_t x_44; -x_44 = !lean_is_exclusive(x_23); -if (x_44 == 0) -{ -lean_object* x_45; uint8_t x_46; -x_45 = lean_ctor_get(x_23, 1); -x_46 = !lean_is_exclusive(x_45); -if (x_46 == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_45, 2); -lean_dec(x_47); -lean_ctor_set(x_45, 2, x_18); -return x_23; -} -else -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_48 = lean_ctor_get(x_45, 0); -x_49 = lean_ctor_get(x_45, 1); -x_50 = lean_ctor_get(x_45, 3); -x_51 = lean_ctor_get(x_45, 4); -x_52 = lean_ctor_get(x_45, 5); -lean_inc(x_52); -lean_inc(x_51); -lean_inc(x_50); -lean_inc(x_49); -lean_inc(x_48); -lean_dec(x_45); -x_53 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_53, 0, x_48); -lean_ctor_set(x_53, 1, x_49); -lean_ctor_set(x_53, 2, x_18); -lean_ctor_set(x_53, 3, x_50); -lean_ctor_set(x_53, 4, x_51); -lean_ctor_set(x_53, 5, x_52); -lean_ctor_set(x_23, 1, x_53); -return x_23; -} -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_54 = lean_ctor_get(x_23, 1); -x_55 = lean_ctor_get(x_23, 0); -lean_inc(x_54); -lean_inc(x_55); -lean_dec(x_23); -x_56 = lean_ctor_get(x_54, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_54, 1); -lean_inc(x_57); -x_58 = lean_ctor_get(x_54, 3); -lean_inc(x_58); -x_59 = lean_ctor_get(x_54, 4); -lean_inc(x_59); -x_60 = lean_ctor_get(x_54, 5); -lean_inc(x_60); -if (lean_is_exclusive(x_54)) { - lean_ctor_release(x_54, 0); - lean_ctor_release(x_54, 1); - lean_ctor_release(x_54, 2); - lean_ctor_release(x_54, 3); - lean_ctor_release(x_54, 4); - lean_ctor_release(x_54, 5); - x_61 = x_54; -} else { - lean_dec_ref(x_54); - x_61 = lean_box(0); -} -if (lean_is_scalar(x_61)) { - x_62 = lean_alloc_ctor(0, 6, 0); -} else { - x_62 = x_61; -} -lean_ctor_set(x_62, 0, x_56); -lean_ctor_set(x_62, 1, x_57); -lean_ctor_set(x_62, 2, x_18); -lean_ctor_set(x_62, 3, x_58); -lean_ctor_set(x_62, 4, x_59); -lean_ctor_set(x_62, 5, x_60); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_55); -lean_ctor_set(x_63, 1, x_62); -return x_63; -} -} -} -} -else -{ -lean_object* x_64; lean_object* x_65; uint8_t x_66; -x_64 = lean_ctor_get(x_6, 0); -x_65 = lean_ctor_get(x_6, 1); -lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_6); -x_66 = l_Lean_Expr_isForall(x_64); -if (x_66 == 0) -{ -lean_object* x_67; -lean_dec(x_64); -lean_dec(x_3); -lean_dec(x_2); -x_67 = l_Lean_Expr_getAppFn___main(x_1); -lean_dec(x_1); -if (lean_obj_tag(x_67) == 4) -{ -lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_68 = lean_ctor_get(x_67, 0); -lean_inc(x_68); -lean_dec(x_67); -x_69 = lean_ctor_get(x_65, 0); -lean_inc(x_69); -lean_inc(x_68); -x_70 = lean_is_class(x_69, x_68); -if (x_70 == 0) -{ -lean_object* x_71; lean_object* x_72; -lean_dec(x_68); -x_71 = lean_box(0); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_71); -lean_ctor_set(x_72, 1, x_65); -return x_72; -} -else -{ -lean_object* x_73; lean_object* x_74; -x_73 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_73, 0, x_68); -x_74 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_74, 0, x_73); -lean_ctor_set(x_74, 1, x_65); -return x_74; -} -} -else -{ -lean_object* x_75; lean_object* x_76; -lean_dec(x_67); -x_75 = lean_box(0); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_75); -lean_ctor_set(x_76, 1, x_65); -return x_76; -} -} -else -{ -lean_object* x_77; lean_object* x_78; uint8_t x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; -lean_dec(x_1); -x_77 = lean_ctor_get(x_65, 2); -lean_inc(x_77); -x_78 = lean_ctor_get(x_3, 1); -lean_inc(x_78); -x_79 = 1; -x_80 = l_Array_empty___closed__1; -x_81 = lean_unsigned_to_nat(0u); -x_82 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13(x_79, x_2, x_78, x_80, x_81, x_64, x_3, x_65); -if (lean_obj_tag(x_82) == 0) -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_83 = lean_ctor_get(x_82, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_82, 0); -lean_inc(x_84); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - x_85 = x_82; -} else { - lean_dec_ref(x_82); - x_85 = lean_box(0); -} -x_86 = lean_ctor_get(x_83, 0); -lean_inc(x_86); -x_87 = lean_ctor_get(x_83, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_83, 3); -lean_inc(x_88); -x_89 = lean_ctor_get(x_83, 4); -lean_inc(x_89); -x_90 = lean_ctor_get(x_83, 5); -lean_inc(x_90); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - lean_ctor_release(x_83, 4); - lean_ctor_release(x_83, 5); - x_91 = x_83; -} else { - lean_dec_ref(x_83); - x_91 = lean_box(0); -} -if (lean_is_scalar(x_91)) { - x_92 = lean_alloc_ctor(0, 6, 0); -} else { - x_92 = x_91; -} -lean_ctor_set(x_92, 0, x_86); -lean_ctor_set(x_92, 1, x_87); -lean_ctor_set(x_92, 2, x_77); -lean_ctor_set(x_92, 3, x_88); -lean_ctor_set(x_92, 4, x_89); -lean_ctor_set(x_92, 5, x_90); -if (lean_is_scalar(x_85)) { - x_93 = lean_alloc_ctor(0, 2, 0); -} else { - x_93 = x_85; -} -lean_ctor_set(x_93, 0, x_84); -lean_ctor_set(x_93, 1, x_92); -return x_93; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_94 = lean_ctor_get(x_82, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_82, 0); -lean_inc(x_95); -if (lean_is_exclusive(x_82)) { - lean_ctor_release(x_82, 0); - lean_ctor_release(x_82, 1); - x_96 = x_82; -} else { - lean_dec_ref(x_82); - x_96 = lean_box(0); -} -x_97 = lean_ctor_get(x_94, 0); -lean_inc(x_97); -x_98 = lean_ctor_get(x_94, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_94, 3); -lean_inc(x_99); -x_100 = lean_ctor_get(x_94, 4); -lean_inc(x_100); -x_101 = lean_ctor_get(x_94, 5); -lean_inc(x_101); -if (lean_is_exclusive(x_94)) { - lean_ctor_release(x_94, 0); - lean_ctor_release(x_94, 1); - lean_ctor_release(x_94, 2); - lean_ctor_release(x_94, 3); - lean_ctor_release(x_94, 4); - lean_ctor_release(x_94, 5); - x_102 = x_94; -} else { - lean_dec_ref(x_94); - x_102 = lean_box(0); -} -if (lean_is_scalar(x_102)) { - x_103 = lean_alloc_ctor(0, 6, 0); -} else { - x_103 = x_102; -} -lean_ctor_set(x_103, 0, x_97); -lean_ctor_set(x_103, 1, x_98); -lean_ctor_set(x_103, 2, x_77); -lean_ctor_set(x_103, 3, x_99); -lean_ctor_set(x_103, 4, x_100); -lean_ctor_set(x_103, 5, x_101); -if (lean_is_scalar(x_96)) { - x_104 = lean_alloc_ctor(1, 2, 0); -} else { - x_104 = x_96; -} -lean_ctor_set(x_104, 0, x_95); -lean_ctor_set(x_104, 1, x_103); -return x_104; -} -} -} -} -else -{ -uint8_t x_105; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_105 = !lean_is_exclusive(x_6); -if (x_105 == 0) -{ -return x_6; -} -else -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_106 = lean_ctor_get(x_6, 0); -x_107 = lean_ctor_get(x_6, 1); -lean_inc(x_107); -lean_inc(x_106); -lean_dec(x_6); -x_108 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_108, 0, x_106); -lean_ctor_set(x_108, 1, x_107); -return x_108; -} -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; uint8_t x_5; -x_4 = lean_box(0); -x_5 = !lean_is_exclusive(x_2); -if (x_5 == 0) -{ -lean_object* x_6; uint8_t x_7; -x_6 = lean_ctor_get(x_2, 0); -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -uint8_t x_8; lean_object* x_9; -x_8 = 2; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_8); -x_9 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_check___spec__12(x_1, x_4, x_2, x_3); -return x_9; -} -else -{ -lean_object* x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; -x_10 = lean_ctor_get(x_6, 0); -x_11 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_12 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_13 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_14 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_10); -lean_dec(x_6); -x_15 = 2; -x_16 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_16, 0, x_10); -lean_ctor_set_uint8(x_16, sizeof(void*)*1, x_11); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 1, x_12); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 2, x_13); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 3, x_14); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_15); -lean_ctor_set(x_2, 0, x_16); -x_17 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_check___spec__12(x_1, x_4, x_2, x_3); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_18 = lean_ctor_get(x_2, 0); -x_19 = lean_ctor_get(x_2, 1); -x_20 = lean_ctor_get(x_2, 2); -lean_inc(x_20); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_2); -x_21 = lean_ctor_get(x_18, 0); -lean_inc(x_21); -x_22 = lean_ctor_get_uint8(x_18, sizeof(void*)*1); -x_23 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 1); -x_24 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 2); -x_25 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - x_26 = x_18; -} else { - lean_dec_ref(x_18); - x_26 = lean_box(0); -} -x_27 = 2; -if (lean_is_scalar(x_26)) { - x_28 = lean_alloc_ctor(0, 1, 5); -} else { - x_28 = x_26; -} -lean_ctor_set(x_28, 0, x_21); -lean_ctor_set_uint8(x_28, sizeof(void*)*1, x_22); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 1, x_23); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 2, x_24); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 3, x_25); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 4, x_27); -x_29 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_29, 0, x_28); -lean_ctor_set(x_29, 1, x_19); -lean_ctor_set(x_29, 2, x_20); -x_30 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_check___spec__12(x_1, x_4, x_29, x_3); -return x_30; -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_check___spec__10(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__17(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; -lean_dec(x_4); -x_9 = lean_unsigned_to_nat(0u); -lean_inc(x_5); -x_10 = l_Array_forMAux___main___at_Lean_Meta_check___spec__7(x_1, x_9, x_5, x_6); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; -x_11 = lean_ctor_get(x_10, 1); -lean_inc(x_11); -lean_dec(x_10); -x_12 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_2, x_5, x_11); -return x_12; -} -else -{ -uint8_t x_13; -lean_dec(x_5); -lean_dec(x_2); -x_13 = !lean_is_exclusive(x_10); -if (x_13 == 0) -{ -return x_10; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_10, 0); -x_15 = lean_ctor_get(x_10, 1); -lean_inc(x_15); -lean_inc(x_14); -lean_dec(x_10); -x_16 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_16, 0, x_14); -lean_ctor_set(x_16, 1, x_15); -return x_16; -} -} -} -else -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_5, x_6); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_18, 1); -lean_inc(x_20); -lean_dec(x_18); -x_21 = l_Lean_LocalDecl_type(x_19); -lean_dec(x_19); -lean_inc(x_5); -lean_inc(x_21); -x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_5, x_20); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -switch (lean_obj_tag(x_23)) { -case 0: -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -lean_dec(x_21); -lean_dec(x_17); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_unsigned_to_nat(1u); -x_26 = lean_nat_add(x_4, x_25); -lean_dec(x_4); -x_4 = x_26; -x_6 = x_24; -goto _start; -} -case 1: -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; -lean_dec(x_21); -x_28 = lean_ctor_get(x_22, 1); -lean_inc(x_28); -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 0); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_unsigned_to_nat(1u); -x_31 = lean_nat_add(x_4, x_30); -lean_dec(x_4); -x_32 = !lean_is_exclusive(x_5); -if (x_32 == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_5, 2); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_29); -lean_ctor_set(x_34, 1, x_17); -x_35 = lean_array_push(x_33, x_34); -lean_ctor_set(x_5, 2, x_35); -x_4 = x_31; -x_6 = x_28; -goto _start; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_5, 0); -x_38 = lean_ctor_get(x_5, 1); -x_39 = lean_ctor_get(x_5, 2); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_5); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_29); -lean_ctor_set(x_40, 1, x_17); -x_41 = lean_array_push(x_39, x_40); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_37); -lean_ctor_set(x_42, 1, x_38); -lean_ctor_set(x_42, 2, x_41); -x_4 = x_31; -x_5 = x_42; -x_6 = x_28; -goto _start; -} -} -default: -{ -lean_object* x_44; lean_object* x_45; -x_44 = lean_ctor_get(x_22, 1); -lean_inc(x_44); -lean_dec(x_22); -lean_inc(x_5); -x_45 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_21, x_5, x_44); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; -x_46 = lean_ctor_get(x_45, 0); -lean_inc(x_46); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; -lean_dec(x_17); -x_47 = lean_ctor_get(x_45, 1); -lean_inc(x_47); -lean_dec(x_45); -x_48 = lean_unsigned_to_nat(1u); -x_49 = lean_nat_add(x_4, x_48); -lean_dec(x_4); -x_4 = x_49; -x_6 = x_47; -goto _start; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; -x_51 = lean_ctor_get(x_45, 1); -lean_inc(x_51); -lean_dec(x_45); -x_52 = lean_ctor_get(x_46, 0); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_unsigned_to_nat(1u); -x_54 = lean_nat_add(x_4, x_53); -lean_dec(x_4); -x_55 = !lean_is_exclusive(x_5); -if (x_55 == 0) -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_5, 2); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_52); -lean_ctor_set(x_57, 1, x_17); -x_58 = lean_array_push(x_56, x_57); -lean_ctor_set(x_5, 2, x_58); -x_4 = x_54; -x_6 = x_51; -goto _start; -} -else -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_60 = lean_ctor_get(x_5, 0); -x_61 = lean_ctor_get(x_5, 1); -x_62 = lean_ctor_get(x_5, 2); -lean_inc(x_62); -lean_inc(x_61); -lean_inc(x_60); -lean_dec(x_5); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_52); -lean_ctor_set(x_63, 1, x_17); -x_64 = lean_array_push(x_62, x_63); -x_65 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_65, 0, x_60); -lean_ctor_set(x_65, 1, x_61); -lean_ctor_set(x_65, 2, x_64); -x_4 = x_54; -x_5 = x_65; -x_6 = x_51; -goto _start; -} -} -} -else -{ -uint8_t x_67; -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_67 = !lean_is_exclusive(x_45); -if (x_67 == 0) -{ -return x_45; -} -else -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_68 = lean_ctor_get(x_45, 0); -x_69 = lean_ctor_get(x_45, 1); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_45); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -return x_70; -} -} -} -} -} -else -{ -uint8_t x_71; -lean_dec(x_21); -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_71 = !lean_is_exclusive(x_22); -if (x_71 == 0) -{ -return x_22; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_22, 0); -x_73 = lean_ctor_get(x_22, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_22); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_17); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_75 = !lean_is_exclusive(x_18); -if (x_75 == 0) -{ -return x_18; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_18, 0); -x_77 = lean_ctor_get(x_18, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_18); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_check___spec__9(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -switch (lean_obj_tag(x_4)) { -case 6: -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; uint64_t x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_18 = lean_ctor_get(x_4, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_4, 1); -lean_inc(x_19); -x_20 = lean_ctor_get(x_4, 2); -lean_inc(x_20); -x_21 = lean_ctor_get_uint64(x_4, sizeof(void*)*3); -lean_dec(x_4); -x_22 = lean_array_get_size(x_2); -lean_inc(x_2); -x_23 = lean_expr_instantiate_rev_range(x_19, x_3, x_22, x_2); -lean_dec(x_22); -lean_dec(x_19); -x_24 = l_Lean_Meta_mkFreshId___rarg(x_6); -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = (uint8_t)((x_21 << 24) >> 61); -lean_inc(x_25); -x_28 = lean_local_ctx_mk_local_decl(x_1, x_25, x_18, x_23, x_27); -x_29 = l_Lean_mkFVar(x_25); -x_30 = lean_array_push(x_2, x_29); -x_1 = x_28; -x_2 = x_30; -x_4 = x_20; -x_6 = x_26; -goto _start; -} -case 8: -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_32 = lean_ctor_get(x_4, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_4, 1); -lean_inc(x_33); -x_34 = lean_ctor_get(x_4, 2); -lean_inc(x_34); -x_35 = lean_ctor_get(x_4, 3); -lean_inc(x_35); -lean_dec(x_4); -x_36 = lean_array_get_size(x_2); -lean_inc(x_2); -x_37 = lean_expr_instantiate_rev_range(x_33, x_3, x_36, x_2); -lean_dec(x_33); -lean_inc(x_2); -x_38 = lean_expr_instantiate_rev_range(x_34, x_3, x_36, x_2); -lean_dec(x_36); -lean_dec(x_34); -x_39 = l_Lean_Meta_mkFreshId___rarg(x_6); -x_40 = lean_ctor_get(x_39, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_39, 1); -lean_inc(x_41); -lean_dec(x_39); -lean_inc(x_40); -x_42 = lean_local_ctx_mk_let_decl(x_1, x_40, x_32, x_37, x_38); -x_43 = l_Lean_mkFVar(x_40); -x_44 = lean_array_push(x_2, x_43); -x_1 = x_42; -x_2 = x_44; -x_4 = x_35; -x_6 = x_41; -goto _start; -} -default: -{ -lean_object* x_46; -x_46 = lean_box(0); -x_7 = x_46; -goto block_17; -} -} -block_17: -{ -lean_object* x_8; lean_object* x_9; uint8_t x_10; -lean_dec(x_7); -x_8 = lean_array_get_size(x_2); -lean_inc(x_2); -x_9 = lean_expr_instantiate_rev_range(x_4, x_3, x_8, x_2); -lean_dec(x_8); -lean_dec(x_4); -x_10 = !lean_is_exclusive(x_5); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; -x_11 = lean_ctor_get(x_5, 1); -lean_dec(x_11); -lean_ctor_set(x_5, 1, x_1); -x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__17(x_2, x_9, x_2, x_3, x_5, x_6); -lean_dec(x_2); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_5, 0); -x_14 = lean_ctor_get(x_5, 2); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_5); -x_15 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_15, 0, x_13); -lean_ctor_set(x_15, 1, x_1); -lean_ctor_set(x_15, 2, x_14); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__17(x_2, x_9, x_2, x_3, x_15, x_6); -lean_dec(x_2); -return x_16; -} -} -} -} -lean_object* l_Lean_Meta_lambdaTelescope___at_Lean_Meta_check___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; -x_4 = lean_ctor_get(x_3, 2); -lean_inc(x_4); -x_5 = lean_ctor_get(x_2, 1); -lean_inc(x_5); -x_6 = l_Array_empty___closed__1; -x_7 = lean_unsigned_to_nat(0u); -x_8 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_check___spec__9(x_5, x_6, x_7, x_1, x_2, x_3); -if (lean_obj_tag(x_8) == 0) -{ -uint8_t x_9; -x_9 = !lean_is_exclusive(x_8); -if (x_9 == 0) -{ -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_8, 1); -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) -{ -lean_object* x_12; -x_12 = lean_ctor_get(x_10, 2); -lean_dec(x_12); -lean_ctor_set(x_10, 2, x_4); -return x_8; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_13 = lean_ctor_get(x_10, 0); -x_14 = lean_ctor_get(x_10, 1); -x_15 = lean_ctor_get(x_10, 3); -x_16 = lean_ctor_get(x_10, 4); -x_17 = lean_ctor_get(x_10, 5); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_inc(x_14); -lean_inc(x_13); -lean_dec(x_10); -x_18 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_18, 0, x_13); -lean_ctor_set(x_18, 1, x_14); -lean_ctor_set(x_18, 2, x_4); -lean_ctor_set(x_18, 3, x_15); -lean_ctor_set(x_18, 4, x_16); -lean_ctor_set(x_18, 5, x_17); -lean_ctor_set(x_8, 1, x_18); -return x_8; -} -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_19 = lean_ctor_get(x_8, 1); -x_20 = lean_ctor_get(x_8, 0); -lean_inc(x_19); -lean_inc(x_20); -lean_dec(x_8); -x_21 = lean_ctor_get(x_19, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_19, 1); -lean_inc(x_22); -x_23 = lean_ctor_get(x_19, 3); -lean_inc(x_23); -x_24 = lean_ctor_get(x_19, 4); -lean_inc(x_24); -x_25 = lean_ctor_get(x_19, 5); -lean_inc(x_25); -if (lean_is_exclusive(x_19)) { - lean_ctor_release(x_19, 0); - lean_ctor_release(x_19, 1); - lean_ctor_release(x_19, 2); - lean_ctor_release(x_19, 3); - lean_ctor_release(x_19, 4); - lean_ctor_release(x_19, 5); - x_26 = x_19; -} else { - lean_dec_ref(x_19); - x_26 = lean_box(0); -} -if (lean_is_scalar(x_26)) { - x_27 = lean_alloc_ctor(0, 6, 0); -} else { - x_27 = x_26; -} -lean_ctor_set(x_27, 0, x_21); -lean_ctor_set(x_27, 1, x_22); -lean_ctor_set(x_27, 2, x_4); -lean_ctor_set(x_27, 3, x_23); -lean_ctor_set(x_27, 4, x_24); -lean_ctor_set(x_27, 5, x_25); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_20); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -else -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_8); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_8, 1); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = lean_ctor_get(x_30, 2); -lean_dec(x_32); -lean_ctor_set(x_30, 2, x_4); -return x_8; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_33 = lean_ctor_get(x_30, 0); -x_34 = lean_ctor_get(x_30, 1); -x_35 = lean_ctor_get(x_30, 3); -x_36 = lean_ctor_get(x_30, 4); -x_37 = lean_ctor_get(x_30, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_30); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_34); -lean_ctor_set(x_38, 2, x_4); -lean_ctor_set(x_38, 3, x_35); -lean_ctor_set(x_38, 4, x_36); -lean_ctor_set(x_38, 5, x_37); -lean_ctor_set(x_8, 1, x_38); -return x_8; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_39 = lean_ctor_get(x_8, 1); -x_40 = lean_ctor_get(x_8, 0); -lean_inc(x_39); -lean_inc(x_40); -lean_dec(x_8); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_39, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_39, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_46 = x_39; -} else { - lean_dec_ref(x_39); - x_46 = lean_box(0); -} -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_46; -} -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); -lean_ctor_set(x_47, 2, x_4); -lean_ctor_set(x_47, 3, x_43); -lean_ctor_set(x_47, 4, x_44); -lean_ctor_set(x_47, 5, x_45); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_40); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___at_Lean_Meta_check___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_lambdaTelescope___at_Lean_Meta_check___spec__8(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__19(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; uint8_t x_6; -x_5 = lean_array_get_size(x_1); -x_6 = lean_nat_dec_lt(x_2, x_5); -lean_dec(x_5); -if (x_6 == 0) -{ -lean_object* x_7; lean_object* x_8; -lean_dec(x_3); -lean_dec(x_2); -x_7 = lean_box(0); -x_8 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_8, 0, x_7); -lean_ctor_set(x_8, 1, x_4); -return x_8; -} -else -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_array_fget(x_1, x_2); -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_add(x_2, x_10); -lean_dec(x_2); -lean_inc(x_3); -x_12 = l_Lean_Meta_getFVarLocalDecl(x_9, x_3, x_4); -lean_dec(x_9); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -x_15 = l_Lean_LocalDecl_type(x_13); -lean_dec(x_13); -lean_inc(x_3); -lean_inc(x_15); -x_16 = l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(x_15, x_3, x_14); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; -x_17 = lean_ctor_get(x_16, 1); -lean_inc(x_17); -lean_dec(x_16); -lean_inc(x_3); -x_18 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_15, x_3, x_17); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; -x_19 = lean_ctor_get(x_18, 1); -lean_inc(x_19); -lean_dec(x_18); -x_2 = x_11; -x_4 = x_19; -goto _start; -} -else -{ -uint8_t x_21; -lean_dec(x_11); -lean_dec(x_3); -x_21 = !lean_is_exclusive(x_18); -if (x_21 == 0) -{ -return x_18; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_18, 0); -x_23 = lean_ctor_get(x_18, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_18); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -else -{ -uint8_t x_25; -lean_dec(x_15); -lean_dec(x_11); -lean_dec(x_3); -x_25 = !lean_is_exclusive(x_16); -if (x_25 == 0) -{ -return x_16; -} -else -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_16, 0); -x_27 = lean_ctor_get(x_16, 1); -lean_inc(x_27); -lean_inc(x_26); -lean_dec(x_16); -x_28 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_28, 0, x_26); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -} -else -{ -uint8_t x_29; -lean_dec(x_11); -lean_dec(x_3); -x_29 = !lean_is_exclusive(x_12); -if (x_29 == 0) -{ -return x_12; -} -else -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_30 = lean_ctor_get(x_12, 0); -x_31 = lean_ctor_get(x_12, 1); -lean_inc(x_31); -lean_inc(x_30); -lean_dec(x_12); -x_32 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_32, 0, x_30); -lean_ctor_set(x_32, 1, x_31); -return x_32; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__21(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; -lean_dec(x_4); -x_9 = lean_unsigned_to_nat(0u); -lean_inc(x_5); -x_10 = l_Array_forMAux___main___at_Lean_Meta_check___spec__19(x_1, x_9, x_5, x_6); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; -x_11 = lean_ctor_get(x_10, 1); -lean_inc(x_11); -lean_dec(x_10); -lean_inc(x_5); -lean_inc(x_2); -x_12 = l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(x_2, x_5, x_11); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = lean_ctor_get(x_12, 1); -lean_inc(x_13); -lean_dec(x_12); -x_14 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_2, x_5, x_13); -return x_14; -} -else -{ -uint8_t x_15; -lean_dec(x_5); -lean_dec(x_2); -x_15 = !lean_is_exclusive(x_12); -if (x_15 == 0) -{ -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 0); -x_17 = lean_ctor_get(x_12, 1); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_12); -x_18 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_17); -return x_18; -} -} -} -else -{ -uint8_t x_19; -lean_dec(x_5); -lean_dec(x_2); -x_19 = !lean_is_exclusive(x_10); -if (x_19 == 0) -{ -return x_10; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_10, 0); -x_21 = lean_ctor_get(x_10, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_10); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; -x_23 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_24 = l_Lean_Meta_getFVarLocalDecl(x_23, x_5, x_6); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = l_Lean_LocalDecl_type(x_25); -lean_dec(x_25); -lean_inc(x_5); -lean_inc(x_27); -x_28 = l_Lean_Meta_isClassQuick___main(x_27, x_5, x_26); -if (lean_obj_tag(x_28) == 0) -{ -lean_object* x_29; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -switch (lean_obj_tag(x_29)) { -case 0: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; -lean_dec(x_27); -lean_dec(x_23); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_4, x_31); -lean_dec(x_4); -x_4 = x_32; -x_6 = x_30; -goto _start; -} -case 1: -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; -lean_dec(x_27); -x_34 = lean_ctor_get(x_28, 1); -lean_inc(x_34); -lean_dec(x_28); -x_35 = lean_ctor_get(x_29, 0); -lean_inc(x_35); -lean_dec(x_29); -x_36 = lean_unsigned_to_nat(1u); -x_37 = lean_nat_add(x_4, x_36); -lean_dec(x_4); -x_38 = !lean_is_exclusive(x_5); -if (x_38 == 0) -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_39 = lean_ctor_get(x_5, 2); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_23); -x_41 = lean_array_push(x_39, x_40); -lean_ctor_set(x_5, 2, x_41); -x_4 = x_37; -x_6 = x_34; -goto _start; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_43 = lean_ctor_get(x_5, 0); -x_44 = lean_ctor_get(x_5, 1); -x_45 = lean_ctor_get(x_5, 2); -lean_inc(x_45); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_5); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_35); -lean_ctor_set(x_46, 1, x_23); -x_47 = lean_array_push(x_45, x_46); -x_48 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_48, 0, x_43); -lean_ctor_set(x_48, 1, x_44); -lean_ctor_set(x_48, 2, x_47); -x_4 = x_37; -x_5 = x_48; -x_6 = x_34; -goto _start; -} -} -default: -{ -lean_object* x_50; lean_object* x_51; -x_50 = lean_ctor_get(x_28, 1); -lean_inc(x_50); -lean_dec(x_28); -lean_inc(x_5); -x_51 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_27, x_5, x_50); -if (lean_obj_tag(x_51) == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -if (lean_obj_tag(x_52) == 0) -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; -lean_dec(x_23); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -lean_dec(x_51); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_4, x_54); -lean_dec(x_4); -x_4 = x_55; -x_6 = x_53; -goto _start; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; -x_57 = lean_ctor_get(x_51, 1); -lean_inc(x_57); -lean_dec(x_51); -x_58 = lean_ctor_get(x_52, 0); -lean_inc(x_58); -lean_dec(x_52); -x_59 = lean_unsigned_to_nat(1u); -x_60 = lean_nat_add(x_4, x_59); -lean_dec(x_4); -x_61 = !lean_is_exclusive(x_5); -if (x_61 == 0) -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_62 = lean_ctor_get(x_5, 2); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_58); -lean_ctor_set(x_63, 1, x_23); -x_64 = lean_array_push(x_62, x_63); -lean_ctor_set(x_5, 2, x_64); -x_4 = x_60; -x_6 = x_57; -goto _start; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_5, 0); -x_67 = lean_ctor_get(x_5, 1); -x_68 = lean_ctor_get(x_5, 2); -lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); -lean_dec(x_5); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_58); -lean_ctor_set(x_69, 1, x_23); -x_70 = lean_array_push(x_68, x_69); -x_71 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_67); -lean_ctor_set(x_71, 2, x_70); -x_4 = x_60; -x_5 = x_71; -x_6 = x_57; -goto _start; -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_73 = !lean_is_exclusive(x_51); -if (x_73 == 0) -{ -return x_51; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_51, 0); -x_75 = lean_ctor_get(x_51, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_51); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_27); -lean_dec(x_23); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_77 = !lean_is_exclusive(x_28); -if (x_77 == 0) -{ -return x_28; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_28, 0); -x_79 = lean_ctor_get(x_28, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_28); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_23); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_24); -if (x_81 == 0) -{ -return x_24; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_24, 0); -x_83 = lean_ctor_get(x_24, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_24); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___lambda__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; -x_10 = l_Lean_Expr_isForall(x_7); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_11 = lean_unsigned_to_nat(0u); -lean_inc(x_8); -x_12 = l_Array_forMAux___main___at_Lean_Meta_check___spec__19(x_1, x_11, x_8, x_9); -lean_dec(x_1); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = lean_ctor_get(x_12, 1); -lean_inc(x_13); -lean_dec(x_12); -lean_inc(x_8); -lean_inc(x_2); -x_14 = l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(x_2, x_8, x_13); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; lean_object* x_16; -x_15 = lean_ctor_get(x_14, 1); -lean_inc(x_15); -lean_dec(x_14); -x_16 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_2, x_8, x_15); -return x_16; -} -else -{ -uint8_t x_17; -lean_dec(x_8); -lean_dec(x_2); -x_17 = !lean_is_exclusive(x_14); -if (x_17 == 0) -{ -return x_14; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_14, 0); -x_19 = lean_ctor_get(x_14, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_14); -x_20 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_19); -return x_20; -} -} -} -else -{ -uint8_t x_21; -lean_dec(x_8); -lean_dec(x_2); -x_21 = !lean_is_exclusive(x_12); -if (x_21 == 0) -{ -return x_12; -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_22 = lean_ctor_get(x_12, 0); -x_23 = lean_ctor_get(x_12, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_12); -x_24 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} -} -} -else -{ -lean_object* x_25; -lean_dec(x_2); -x_25 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__20(x_3, x_4, x_5, x_1, x_6, x_7, x_8, x_9); -return x_25; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; -lean_inc(x_8); -x_13 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); -lean_closure_set(x_13, 0, x_8); -x_14 = lean_box(x_1); -lean_inc(x_7); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_8); -lean_inc(x_4); -x_15 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___lambda__1___boxed), 9, 6); -lean_closure_set(x_15, 0, x_4); -lean_closure_set(x_15, 1, x_8); -lean_closure_set(x_15, 2, x_14); -lean_closure_set(x_15, 3, x_2); -lean_closure_set(x_15, 4, x_3); -lean_closure_set(x_15, 5, x_7); -x_16 = lean_array_get_size(x_9); -x_17 = lean_nat_dec_lt(x_10, x_16); -lean_dec(x_16); -if (x_17 == 0) -{ -lean_object* x_18; -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_18 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_13, x_15, x_11, x_12); -return x_18; -} -else -{ -lean_object* x_19; lean_object* x_20; -lean_dec(x_15); -lean_dec(x_13); -x_19 = lean_array_fget(x_9, x_10); -lean_inc(x_11); -x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_11, x_12); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_20, 1); -lean_inc(x_22); -lean_dec(x_20); -x_23 = l_Lean_LocalDecl_type(x_21); -lean_dec(x_21); -lean_inc(x_11); -lean_inc(x_23); -x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_11, x_22); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -switch (lean_obj_tag(x_25)) { -case 0: -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_dec(x_23); -lean_dec(x_19); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_10, x_27); -lean_dec(x_10); -x_10 = x_28; -x_12 = x_26; -goto _start; -} -case 1: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 1); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_10, x_32); -lean_dec(x_10); -x_34 = !lean_is_exclusive(x_11); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_11, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_31); -lean_ctor_set(x_36, 1, x_19); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_11, 2, x_37); -x_10 = x_33; -x_12 = x_30; -goto _start; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_11, 0); -x_40 = lean_ctor_get(x_11, 1); -x_41 = lean_ctor_get(x_11, 2); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_11); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_31); -lean_ctor_set(x_42, 1, x_19); -x_43 = lean_array_push(x_41, x_42); -x_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_43); -x_10 = x_33; -x_11 = x_44; -x_12 = x_30; -goto _start; -} -} -default: -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_24, 1); -lean_inc(x_46); -lean_dec(x_24); -lean_inc(x_11); -x_47 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_23, x_11, x_46); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_19); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -x_50 = lean_unsigned_to_nat(1u); -x_51 = lean_nat_add(x_10, x_50); -lean_dec(x_10); -x_10 = x_51; -x_12 = x_49; -goto _start; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; -x_53 = lean_ctor_get(x_47, 1); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_ctor_get(x_48, 0); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_unsigned_to_nat(1u); -x_56 = lean_nat_add(x_10, x_55); -lean_dec(x_10); -x_57 = !lean_is_exclusive(x_11); -if (x_57 == 0) -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_11, 2); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_54); -lean_ctor_set(x_59, 1, x_19); -x_60 = lean_array_push(x_58, x_59); -lean_ctor_set(x_11, 2, x_60); -x_10 = x_56; -x_12 = x_53; -goto _start; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_62 = lean_ctor_get(x_11, 0); -x_63 = lean_ctor_get(x_11, 1); -x_64 = lean_ctor_get(x_11, 2); -lean_inc(x_64); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_11); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_54); -lean_ctor_set(x_65, 1, x_19); -x_66 = lean_array_push(x_64, x_65); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_63); -lean_ctor_set(x_67, 2, x_66); -x_10 = x_56; -x_11 = x_67; -x_12 = x_53; -goto _start; -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_69 = !lean_is_exclusive(x_47); -if (x_69 == 0) -{ -return x_47; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_47, 0); -x_71 = lean_ctor_get(x_47, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_47); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_73 = !lean_is_exclusive(x_24); -if (x_73 == 0) -{ -return x_24; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_24, 0); -x_75 = lean_ctor_get(x_24, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_24); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_77 = !lean_is_exclusive(x_20); -if (x_77 == 0) -{ -return x_20; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_20, 0); -x_79 = lean_ctor_get(x_20, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_20); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__23(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; lean_object* x_10; -lean_dec(x_4); -x_9 = lean_unsigned_to_nat(0u); -lean_inc(x_5); -x_10 = l_Array_forMAux___main___at_Lean_Meta_check___spec__19(x_1, x_9, x_5, x_6); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; -x_11 = lean_ctor_get(x_10, 1); -lean_inc(x_11); -lean_dec(x_10); -lean_inc(x_5); -lean_inc(x_2); -x_12 = l___private_Init_Lean_Meta_Check_1__ensureType___at_Lean_Meta_check___spec__5(x_2, x_5, x_11); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = lean_ctor_get(x_12, 1); -lean_inc(x_13); -lean_dec(x_12); -x_14 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_2, x_5, x_13); -return x_14; -} -else -{ -uint8_t x_15; -lean_dec(x_5); -lean_dec(x_2); -x_15 = !lean_is_exclusive(x_12); -if (x_15 == 0) -{ -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 0); -x_17 = lean_ctor_get(x_12, 1); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_12); -x_18 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_17); -return x_18; -} -} -} -else -{ -uint8_t x_19; -lean_dec(x_5); -lean_dec(x_2); -x_19 = !lean_is_exclusive(x_10); -if (x_19 == 0) -{ -return x_10; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_10, 0); -x_21 = lean_ctor_get(x_10, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_10); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -lean_object* x_23; lean_object* x_24; -x_23 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_24 = l_Lean_Meta_getFVarLocalDecl(x_23, x_5, x_6); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = l_Lean_LocalDecl_type(x_25); -lean_dec(x_25); -lean_inc(x_5); -lean_inc(x_27); -x_28 = l_Lean_Meta_isClassQuick___main(x_27, x_5, x_26); -if (lean_obj_tag(x_28) == 0) -{ -lean_object* x_29; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -switch (lean_obj_tag(x_29)) { -case 0: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; -lean_dec(x_27); -lean_dec(x_23); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_4, x_31); -lean_dec(x_4); -x_4 = x_32; -x_6 = x_30; -goto _start; -} -case 1: -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; -lean_dec(x_27); -x_34 = lean_ctor_get(x_28, 1); -lean_inc(x_34); -lean_dec(x_28); -x_35 = lean_ctor_get(x_29, 0); -lean_inc(x_35); -lean_dec(x_29); -x_36 = lean_unsigned_to_nat(1u); -x_37 = lean_nat_add(x_4, x_36); -lean_dec(x_4); -x_38 = !lean_is_exclusive(x_5); -if (x_38 == 0) -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_39 = lean_ctor_get(x_5, 2); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_23); -x_41 = lean_array_push(x_39, x_40); -lean_ctor_set(x_5, 2, x_41); -x_4 = x_37; -x_6 = x_34; -goto _start; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_43 = lean_ctor_get(x_5, 0); -x_44 = lean_ctor_get(x_5, 1); -x_45 = lean_ctor_get(x_5, 2); -lean_inc(x_45); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_5); -x_46 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_46, 0, x_35); -lean_ctor_set(x_46, 1, x_23); -x_47 = lean_array_push(x_45, x_46); -x_48 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_48, 0, x_43); -lean_ctor_set(x_48, 1, x_44); -lean_ctor_set(x_48, 2, x_47); -x_4 = x_37; -x_5 = x_48; -x_6 = x_34; -goto _start; -} -} -default: -{ -lean_object* x_50; lean_object* x_51; -x_50 = lean_ctor_get(x_28, 1); -lean_inc(x_50); -lean_dec(x_28); -lean_inc(x_5); -x_51 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_check___spec__11(x_27, x_5, x_50); -if (lean_obj_tag(x_51) == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -if (lean_obj_tag(x_52) == 0) -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; -lean_dec(x_23); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -lean_dec(x_51); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_4, x_54); -lean_dec(x_4); -x_4 = x_55; -x_6 = x_53; -goto _start; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; -x_57 = lean_ctor_get(x_51, 1); -lean_inc(x_57); -lean_dec(x_51); -x_58 = lean_ctor_get(x_52, 0); -lean_inc(x_58); -lean_dec(x_52); -x_59 = lean_unsigned_to_nat(1u); -x_60 = lean_nat_add(x_4, x_59); -lean_dec(x_4); -x_61 = !lean_is_exclusive(x_5); -if (x_61 == 0) -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_62 = lean_ctor_get(x_5, 2); -x_63 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_63, 0, x_58); -lean_ctor_set(x_63, 1, x_23); -x_64 = lean_array_push(x_62, x_63); -lean_ctor_set(x_5, 2, x_64); -x_4 = x_60; -x_6 = x_57; -goto _start; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_5, 0); -x_67 = lean_ctor_get(x_5, 1); -x_68 = lean_ctor_get(x_5, 2); -lean_inc(x_68); -lean_inc(x_67); -lean_inc(x_66); -lean_dec(x_5); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_58); -lean_ctor_set(x_69, 1, x_23); -x_70 = lean_array_push(x_68, x_69); -x_71 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_71, 0, x_66); -lean_ctor_set(x_71, 1, x_67); -lean_ctor_set(x_71, 2, x_70); -x_4 = x_60; -x_5 = x_71; -x_6 = x_57; -goto _start; -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_73 = !lean_is_exclusive(x_51); -if (x_73 == 0) -{ -return x_51; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_51, 0); -x_75 = lean_ctor_get(x_51, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_51); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_27); -lean_dec(x_23); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_77 = !lean_is_exclusive(x_28); -if (x_77 == 0) -{ -return x_28; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_28, 0); -x_79 = lean_ctor_get(x_28, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_28); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -else -{ -uint8_t x_81; -lean_dec(x_23); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_81 = !lean_is_exclusive(x_24); -if (x_81 == 0) -{ -return x_24; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_82 = lean_ctor_get(x_24, 0); -x_83 = lean_ctor_get(x_24, 1); -lean_inc(x_83); -lean_inc(x_82); -lean_dec(x_24); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_82); -lean_ctor_set(x_84, 1, x_83); -return x_84; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__20(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_22 = lean_ctor_get(x_6, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_6, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 2); -lean_inc(x_24); -x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); -lean_dec(x_6); -x_26 = lean_array_get_size(x_4); -lean_inc(x_4); -x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); -lean_dec(x_26); -lean_dec(x_23); -x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -x_31 = (uint8_t)((x_25 << 24) >> 61); -lean_inc(x_29); -x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); -x_33 = l_Lean_mkFVar(x_29); -x_34 = lean_array_push(x_4, x_33); -if (lean_obj_tag(x_2) == 0) -{ -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -else -{ -lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_36 = lean_ctor_get(x_2, 0); -lean_inc(x_36); -x_37 = lean_array_get_size(x_34); -x_38 = lean_nat_dec_lt(x_37, x_36); -lean_dec(x_36); -if (x_38 == 0) -{ -lean_object* x_39; uint8_t x_40; -lean_dec(x_2); -lean_inc(x_34); -x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); -lean_dec(x_37); -lean_dec(x_24); -x_40 = !lean_is_exclusive(x_7); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_7, 1); -lean_dec(x_41); -lean_ctor_set(x_7, 1, x_32); -x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__23(x_34, x_39, x_34, x_5, x_7, x_30); -lean_dec(x_34); -return x_42; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_7, 0); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_32); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__23(x_34, x_39, x_34, x_5, x_45, x_30); -lean_dec(x_34); -return x_46; -} -} -else -{ -lean_dec(x_37); -x_3 = x_32; -x_4 = x_34; -x_6 = x_24; -x_8 = x_30; -goto _start; -} -} -} -else -{ -lean_object* x_48; -x_48 = lean_box(0); -x_9 = x_48; -goto block_21; -} -block_21: -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -x_12 = !lean_is_exclusive(x_7); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_7, 1); -lean_dec(x_13); -lean_inc(x_3); -lean_ctor_set(x_7, 1, x_3); -if (x_1 == 0) -{ -lean_object* x_14; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__21(x_4, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_4); -return x_14; -} -else -{ -lean_object* x_15; -lean_inc(x_5); -lean_inc(x_4); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_15; -} -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_7, 0); -x_17 = lean_ctor_get(x_7, 2); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_7); -lean_inc(x_3); -x_18 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_3); -lean_ctor_set(x_18, 2, x_17); -if (x_1 == 0) -{ -lean_object* x_19; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -x_19 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__21(x_4, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_4); -return x_19; -} -else -{ -lean_object* x_20; -lean_inc(x_5); -lean_inc(x_4); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_20; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___at_Lean_Meta_check___spec__18(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_4 = lean_ctor_get(x_3, 2); -lean_inc(x_4); -x_5 = lean_ctor_get(x_2, 1); -lean_inc(x_5); -x_6 = lean_box(0); -x_7 = 0; -x_8 = l_Array_empty___closed__1; -x_9 = lean_unsigned_to_nat(0u); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__20(x_7, x_6, x_5, x_8, x_9, x_1, x_2, x_3); -if (lean_obj_tag(x_10) == 0) -{ -uint8_t x_11; -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) -{ -lean_object* x_12; uint8_t x_13; -x_12 = lean_ctor_get(x_10, 1); -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_12, 2); -lean_dec(x_14); -lean_ctor_set(x_12, 2, x_4); -return x_10; -} -else -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_15 = lean_ctor_get(x_12, 0); -x_16 = lean_ctor_get(x_12, 1); -x_17 = lean_ctor_get(x_12, 3); -x_18 = lean_ctor_get(x_12, 4); -x_19 = lean_ctor_get(x_12, 5); -lean_inc(x_19); -lean_inc(x_18); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_12); -x_20 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_20, 0, x_15); -lean_ctor_set(x_20, 1, x_16); -lean_ctor_set(x_20, 2, x_4); -lean_ctor_set(x_20, 3, x_17); -lean_ctor_set(x_20, 4, x_18); -lean_ctor_set(x_20, 5, x_19); -lean_ctor_set(x_10, 1, x_20); -return x_10; -} -} -else -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_21 = lean_ctor_get(x_10, 1); -x_22 = lean_ctor_get(x_10, 0); -lean_inc(x_21); -lean_inc(x_22); -lean_dec(x_10); -x_23 = lean_ctor_get(x_21, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_21, 1); -lean_inc(x_24); -x_25 = lean_ctor_get(x_21, 3); -lean_inc(x_25); -x_26 = lean_ctor_get(x_21, 4); -lean_inc(x_26); -x_27 = lean_ctor_get(x_21, 5); -lean_inc(x_27); -if (lean_is_exclusive(x_21)) { - lean_ctor_release(x_21, 0); - lean_ctor_release(x_21, 1); - lean_ctor_release(x_21, 2); - lean_ctor_release(x_21, 3); - lean_ctor_release(x_21, 4); - lean_ctor_release(x_21, 5); - x_28 = x_21; -} else { - lean_dec_ref(x_21); - x_28 = lean_box(0); -} -if (lean_is_scalar(x_28)) { - x_29 = lean_alloc_ctor(0, 6, 0); -} else { - x_29 = x_28; -} -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_4); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -lean_ctor_set(x_29, 5, x_27); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_22); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -else -{ -uint8_t x_31; -x_31 = !lean_is_exclusive(x_10); -if (x_31 == 0) -{ -lean_object* x_32; uint8_t x_33; -x_32 = lean_ctor_get(x_10, 1); -x_33 = !lean_is_exclusive(x_32); -if (x_33 == 0) -{ -lean_object* x_34; -x_34 = lean_ctor_get(x_32, 2); -lean_dec(x_34); -lean_ctor_set(x_32, 2, x_4); -return x_10; -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_35 = lean_ctor_get(x_32, 0); -x_36 = lean_ctor_get(x_32, 1); -x_37 = lean_ctor_get(x_32, 3); -x_38 = lean_ctor_get(x_32, 4); -x_39 = lean_ctor_get(x_32, 5); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_dec(x_32); -x_40 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_36); -lean_ctor_set(x_40, 2, x_4); -lean_ctor_set(x_40, 3, x_37); -lean_ctor_set(x_40, 4, x_38); -lean_ctor_set(x_40, 5, x_39); -lean_ctor_set(x_10, 1, x_40); -return x_10; -} -} -else -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_41 = lean_ctor_get(x_10, 1); -x_42 = lean_ctor_get(x_10, 0); -lean_inc(x_41); -lean_inc(x_42); -lean_dec(x_10); -x_43 = lean_ctor_get(x_41, 0); -lean_inc(x_43); -x_44 = lean_ctor_get(x_41, 1); -lean_inc(x_44); -x_45 = lean_ctor_get(x_41, 3); -lean_inc(x_45); -x_46 = lean_ctor_get(x_41, 4); -lean_inc(x_46); -x_47 = lean_ctor_get(x_41, 5); -lean_inc(x_47); -if (lean_is_exclusive(x_41)) { - lean_ctor_release(x_41, 0); - lean_ctor_release(x_41, 1); - lean_ctor_release(x_41, 2); - lean_ctor_release(x_41, 3); - lean_ctor_release(x_41, 4); - lean_ctor_release(x_41, 5); - x_48 = x_41; -} else { - lean_dec_ref(x_41); - x_48 = lean_box(0); -} -if (lean_is_scalar(x_48)) { - x_49 = lean_alloc_ctor(0, 6, 0); -} else { - x_49 = x_48; -} -lean_ctor_set(x_49, 0, x_43); -lean_ctor_set(x_49, 1, x_44); -lean_ctor_set(x_49, 2, x_4); -lean_ctor_set(x_49, 3, x_45); -lean_ctor_set(x_49, 4, x_46); -lean_ctor_set(x_49, 5, x_47); -x_50 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_50, 0, x_42); -lean_ctor_set(x_50, 1, x_49); -return x_50; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -switch (lean_obj_tag(x_1)) { -case 4: -{ -lean_object* x_4; lean_object* x_5; lean_object* x_6; -x_4 = lean_ctor_get(x_1, 0); -lean_inc(x_4); -x_5 = lean_ctor_get(x_1, 1); -lean_inc(x_5); -lean_dec(x_1); -x_6 = l___private_Init_Lean_Meta_Check_4__checkConstant(x_4, x_5, x_2, x_3); -lean_dec(x_2); -return x_6; -} -case 5: -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = lean_ctor_get(x_1, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_1, 1); -lean_inc(x_8); -lean_dec(x_1); -x_9 = l___private_Init_Lean_Meta_Check_5__checkApp___at_Lean_Meta_check___spec__3(x_7, x_8, x_2, x_3); -return x_9; -} -case 6: -{ -lean_object* x_10; -x_10 = l_Lean_Meta_lambdaTelescope___at_Lean_Meta_check___spec__8(x_1, x_2, x_3); -return x_10; -} -case 7: -{ -lean_object* x_11; -x_11 = l___private_Init_Lean_Meta_Check_3__checkForall___at_Lean_Meta_check___spec__18(x_1, x_2, x_3); -return x_11; -} -case 8: -{ -lean_object* x_12; -x_12 = l_Lean_Meta_lambdaTelescope___at_Lean_Meta_check___spec__8(x_1, x_2, x_3); -return x_12; -} -case 10: -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_1, 1); -lean_inc(x_13); -lean_dec(x_1); -x_1 = x_13; -goto _start; -} -case 11: -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_1, 2); -lean_inc(x_15); -lean_dec(x_1); -x_1 = x_15; -goto _start; -} -default: -{ -lean_object* x_17; lean_object* x_18; -lean_dec(x_2); -lean_dec(x_1); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_3); -return x_18; -} -} -} -} -lean_object* l_Lean_Meta_checkAux___at_Lean_Meta_check___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -uint8_t x_4; -x_4 = !lean_is_exclusive(x_2); -if (x_4 == 0) -{ -lean_object* x_5; uint8_t x_6; -x_5 = lean_ctor_get(x_2, 0); -x_6 = !lean_is_exclusive(x_5); -if (x_6 == 0) -{ -uint8_t x_7; lean_object* x_8; -x_7 = 0; -lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 4, x_7); -x_8 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_1, x_2, x_3); -return x_8; -} -else -{ -lean_object* x_9; uint8_t x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; -x_9 = lean_ctor_get(x_5, 0); -x_10 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); -x_11 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); -x_12 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); -x_13 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); -lean_inc(x_9); -lean_dec(x_5); -x_14 = 0; -x_15 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_15, 0, x_9); -lean_ctor_set_uint8(x_15, sizeof(void*)*1, x_10); -lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 1, x_11); -lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 2, x_12); -lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 3, x_13); -lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 4, x_14); -lean_ctor_set(x_2, 0, x_15); -x_16 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_1, x_2, x_3); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; lean_object* x_25; uint8_t x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_17 = lean_ctor_get(x_2, 0); -x_18 = lean_ctor_get(x_2, 1); -x_19 = lean_ctor_get(x_2, 2); -lean_inc(x_19); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_2); -x_20 = lean_ctor_get(x_17, 0); -lean_inc(x_20); -x_21 = lean_ctor_get_uint8(x_17, sizeof(void*)*1); -x_22 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 1); -x_23 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 2); -x_24 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_17)) { - lean_ctor_release(x_17, 0); - x_25 = x_17; -} else { - lean_dec_ref(x_17); - x_25 = lean_box(0); -} -x_26 = 0; -if (lean_is_scalar(x_25)) { - x_27 = lean_alloc_ctor(0, 1, 5); -} else { - x_27 = x_25; -} -lean_ctor_set(x_27, 0, x_20); -lean_ctor_set_uint8(x_27, sizeof(void*)*1, x_21); -lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 1, x_22); -lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 2, x_23); -lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 3, x_24); -lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 4, x_26); -x_28 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_28, 0, x_27); -lean_ctor_set(x_28, 1, x_18); -lean_ctor_set(x_28, 2, x_19); -x_29 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main___at_Lean_Meta_check___spec__2(x_1, x_28, x_3); -return x_29; -} -} -} -lean_object* l_Lean_Meta_check(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_checkAux___at_Lean_Meta_check___spec__1(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Array_forMAux___main___at_Lean_Meta_check___spec__7(x_1, x_2, x_3, x_4); -lean_dec(x_1); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__14___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__14(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_2); -lean_dec(x_2); -x_11 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___lambda__1(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_1); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_1); -lean_dec(x_1); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__15(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -return x_14; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__16___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -x_6 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__16(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_2); -lean_dec(x_1); -return x_6; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -uint8_t x_9; lean_object* x_10; -x_9 = lean_unbox(x_1); -lean_dec(x_1); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__13(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__17___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__17(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -lean_dec(x_1); -return x_7; -} -} -lean_object* l_Array_forMAux___main___at_Lean_Meta_check___spec__19___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Array_forMAux___main___at_Lean_Meta_check___spec__19(x_1, x_2, x_3, x_4); -lean_dec(x_1); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__21___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__21(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -lean_dec(x_1); -return x_7; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_3); -lean_dec(x_3); -x_11 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___lambda__1(x_1, x_2, x_10, x_4, x_5, x_6, x_7, x_8, x_9); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_1); -lean_dec(x_1); -x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__22(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -return x_14; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__23___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_check___spec__23(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -lean_dec(x_1); -return x_7; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__20___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -uint8_t x_9; lean_object* x_10; -x_9 = lean_unbox(x_1); -lean_dec(x_1); -x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_check___spec__20(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l_Lean_Meta_isTypeCorrectAux___at_Lean_Meta_isTypeCorrect___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_checkAux___at_Lean_Meta_check___spec__1(x_1, x_2, x_3); -if (lean_obj_tag(x_4) == 0) -{ -uint8_t x_5; -x_5 = !lean_is_exclusive(x_4); -if (x_5 == 0) -{ -lean_object* x_6; uint8_t x_7; lean_object* x_8; -x_6 = lean_ctor_get(x_4, 0); -lean_dec(x_6); -x_7 = 1; -x_8 = lean_box(x_7); -lean_ctor_set(x_4, 0, x_8); -return x_4; -} -else -{ -lean_object* x_9; uint8_t x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_4, 1); -lean_inc(x_9); -lean_dec(x_4); -x_10 = 1; -x_11 = lean_box(x_10); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_9); -return x_12; -} -} -else -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_4); -if (x_13 == 0) -{ -lean_object* x_14; uint8_t x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_4, 0); -lean_dec(x_14); -x_15 = 0; -x_16 = lean_box(x_15); -lean_ctor_set_tag(x_4, 0); -lean_ctor_set(x_4, 0, x_16); -return x_4; -} -else -{ -lean_object* x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; -x_17 = lean_ctor_get(x_4, 1); -lean_inc(x_17); -lean_dec(x_4); -x_18 = 0; -x_19 = lean_box(x_18); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_19); -lean_ctor_set(x_20, 1, x_17); -return x_20; -} -} -} -} -lean_object* l_Lean_Meta_isTypeCorrect(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -lean_object* x_4; -x_4 = l_Lean_Meta_isTypeCorrectAux___at_Lean_Meta_isTypeCorrect___spec__1(x_1, x_2, x_3); -return x_4; -} -} lean_object* initialize_Init_Lean_Meta_Basic(lean_object*); +lean_object* initialize_Init_Lean_Meta_LevelDefEq(lean_object*); lean_object* initialize_Init_Lean_Meta_WHNF(lean_object*); lean_object* initialize_Init_Lean_Meta_InferType(lean_object*); lean_object* initialize_Init_Lean_Meta_FunInfo(lean_object*); -lean_object* initialize_Init_Lean_Meta_LevelDefEq(lean_object*); lean_object* initialize_Init_Lean_Meta_ExprDefEq(lean_object*); static bool _G_initialized = false; lean_object* initialize_Init_Lean_Meta(lean_object* w) { @@ -31885,6 +27,9 @@ _G_initialized = true; res = initialize_Init_Lean_Meta_Basic(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +res = initialize_Init_Lean_Meta_LevelDefEq(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); res = initialize_Init_Lean_Meta_WHNF(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); @@ -31894,20 +39,9 @@ lean_dec_ref(res); res = initialize_Init_Lean_Meta_FunInfo(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -res = initialize_Init_Lean_Meta_LevelDefEq(lean_io_mk_world()); -if (lean_io_result_is_error(res)) return res; -lean_dec_ref(res); res = initialize_Init_Lean_Meta_ExprDefEq(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___closed__1 = _init_l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___closed__1(); -lean_mark_persistent(l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_3__auxFixpoint___main___spec__39___closed__1); -l___private_Init_Lean_Meta_3__auxFixpoint___main___closed__1 = _init_l___private_Init_Lean_Meta_3__auxFixpoint___main___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_3__auxFixpoint___main___closed__1); -l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1 = _init_l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1(); -lean_mark_persistent(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isProp___spec__11___closed__1); -l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4___closed__1 = _init_l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_getFunInfo___spec__4___closed__1); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/library/Init/Lean/Meta/Basic.c b/stage0/library/Init/Lean/Meta/Basic.c index 2f42e4bbfb..7f47202eb4 100644 --- a/stage0/library/Init/Lean/Meta/Basic.c +++ b/stage0/library/Init/Lean/Meta/Basic.c @@ -13,22 +13,29 @@ #ifdef __cplusplus extern "C" { #endif +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_MetaM_inhabited(lean_object*, lean_object*); size_t l_Lean_Meta_InfoCacheKey_Hashable(lean_object*); lean_object* l_Lean_Meta_getLCtx___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___closed__4; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshId___boxed(lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___closed__2; size_t l_Lean_Meta_TransparencyMode_hash(uint8_t); -lean_object* l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkSynthPendingRef___lambda__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___closed__1; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVarId___rarg(lean_object*); +lean_object* l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_unreachable_x21___rarg(lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClassExpensive___main(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_throwBug(lean_object*); lean_object* l_Lean_MetavarContext_instantiateMVars(lean_object*, lean_object*); lean_object* l_Lean_Meta_dbgTrace___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceAll_x3f(lean_object*, lean_object*); lean_object* l_Lean_Meta_InfoCacheKey_Inhabited; lean_object* l_Lean_Meta_getEnv(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_addLevelMVarDecl(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux(lean_object*); extern lean_object* l_EIO_Monad___closed__1; @@ -39,11 +46,19 @@ lean_object* l_ReaderT_bind___rarg(lean_object*, lean_object*, lean_object*, lea lean_object* l_Lean_Meta_liftStateMCtx(lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_3__getTraceState___boxed(lean_object*); lean_object* l_Lean_Meta_getExprMVarAssignment___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1; lean_object* l_Lean_Meta_isClassQuick___main(lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; +lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_lambdaTelescope(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_dbg_trace(lean_object*, lean_object*); +lean_object* lean_io_mk_ref(lean_object*, lean_object*); lean_object* l_Lean_Meta_forallTelescope(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_io_ref_get(lean_object*, lean_object*); lean_object* l_Option_hash___at_Lean_Meta_InfoCacheKey_Hashable___spec__1___boxed(lean_object*); lean_object* l_Lean_Meta_instantiateLevelMVars(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_forallBoundedTelescope(lean_object*); @@ -51,14 +66,21 @@ lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); lean_object* l_Lean_Meta_getEnv___boxed(lean_object*); lean_object* l_Lean_Meta_isReducible___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateLevelMVars___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_forallTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_forallTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__2(lean_object*, lean_object*, lean_object*); +extern lean_object* l_String_splitAux___main___closed__1; lean_object* lean_environment_find(lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getConst(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isReadOnlyOrSyntheticExprMVar___boxed(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_Exception_Inhabited___closed__1; lean_object* l_Lean_Meta_throwBug___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isReadOnlyLevelMVar___boxed(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux(lean_object*); uint8_t l_Lean_isReducible(lean_object*, lean_object*); @@ -66,172 +88,260 @@ lean_object* l_Lean_Meta_InfoCacheKey_Hashable___boxed(lean_object*); lean_object* l_Lean_Meta_getConstNoEx(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_MetaM_inhabited___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getConst___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); lean_object* l_Lean_Meta_forallTelescopeReducing(lean_object*); lean_object* l_Lean_Meta_usingAtLeastTransparency(lean_object*); lean_object* l_Lean_Meta_MetaM_inhabited___rarg(lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_TransparencyMode_Hashable___closed__1; lean_object* l_Lean_Meta_getEnv___rarg(lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_metavar_ctx_find_decl(lean_object*, lean_object*); lean_object* l_Lean_Meta_getConfig___boxed(lean_object*, lean_object*); uint8_t lean_metavar_ctx_is_expr_assigned(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClass(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClass(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewLocalInstances___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewLocalInstance___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_throwEx___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_dbgTrace___rarg___closed__1; +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallBoundedTelescope___spec__1(lean_object*); +lean_object* l_Lean_Meta_mkMetaExtension(lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isClassExpensive___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fget(lean_object*, lean_object*); lean_object* l_Lean_Meta_InfoCacheKey_Inhabited___closed__1; -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_instantiate_rev_range(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_Inhabited___closed__1; uint8_t lean_nat_dec_eq(lean_object*, lean_object*); size_t l_Option_hash___at_Lean_Meta_InfoCacheKey_Hashable___spec__1(lean_object*); +lean_object* l_Lean_Meta_mkSynthPendingRef(lean_object*); lean_object* l_Lean_Meta_TransparencyMode_lt___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_getExprMVarAssignment(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkWHNFRef___lambda__1___closed__1; lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2(lean_object*); +lean_object* l_Lean_Meta_mkWHNFRef___lambda__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_EStateM_bind___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceAll_x3f___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Meta_InfoCacheKey_HasBeq(lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_instantiateLevelMVars___main(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkWHNFRef___lambda__1___closed__2; +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2; lean_object* l_Lean_Meta_isClassQuickConst___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getConstNoEx___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkMetaExtension___closed__2; +lean_object* l_Lean_Meta_mkMetaExtension___closed__1; +lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1___closed__1; lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main(lean_object*); lean_object* l_Lean_Meta_TransparencyMode_Hashable; lean_object* l_Lean_Meta_dbgTrace___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_fvarId_x21(lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkSynthPendingRef___lambda__1(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4(lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_3__getTraceState___rarg(lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main___closed__1; lean_object* l_Lean_Meta_ParamInfo_inhabited___closed__1; lean_object* l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVarId(lean_object*); lean_object* l_Lean_Meta_isExprMVarAssigned___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_tracer___closed__3; lean_object* l_Lean_Meta_tracer; +lean_object* l_Lean_Meta_metaExt___closed__2; lean_object* l_Lean_Meta_savingCache___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferTypeRef; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___lambda__1(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Meta_TransparencyMode_Inhabited; lean_object* l_Lean_Meta_throwEx(lean_object*); size_t l_Lean_Expr_hash(lean_object*); +lean_object* l_Lean_Meta_metaExt___closed__1; +lean_object* l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1(lean_object*); lean_object* l_Lean_Meta_InfoCacheKey_HasBeq___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkSynthPendingRef___closed__1; lean_object* lean_metavar_ctx_assign_expr(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallBoundedTelescope___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_TransparencyMode_HasBeq___closed__1; lean_object* l_Lean_Meta_withNewLocalInstances(lean_object*); lean_object* l_Lean_Meta_withNewLocalInstances___main(lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__2___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Meta_TransparencyMode_beq(uint8_t, uint8_t); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Init_Lean_Environment_5__envExtensionsRef; +extern lean_object* l_Lean_registerEnvExtensionUnsafe___rarg___closed__1; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewLocalInstances___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_findLevelDepth(lean_object*, lean_object*); lean_object* l_Lean_Meta_assignLevelMVar(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Array_isEmpty___rarg(lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_IO_Prim_Ref_get___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshId___rarg(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5(lean_object*); lean_object* l_Lean_Meta_tracer___closed__4; -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_isForall(lean_object*); +lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkFVar(lean_object*); uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); lean_object* l_Lean_Meta_liftStateMCtx___rarg(lean_object*, lean_object*, lean_object*); size_t lean_usize_of_nat(lean_object*); +lean_object* l_Lean_Meta_mkMetaExtension___lambda__1(lean_object*, lean_object*); lean_object* l_Lean_Meta_usingTransparency(lean_object*); lean_object* l_Lean_Meta_usingAtLeastTransparency___rarg(uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMVarDecl___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMCtx___boxed(lean_object*); lean_object* l_Lean_Meta_isClassQuick(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef(lean_object*); lean_object* l_Lean_LocalDecl_type(lean_object*); lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__1; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef___closed__1; lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux(lean_object*); +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__2; lean_object* l_Lean_Meta_withNewLocalInstances___main___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_ParamInfo_inhabited; +lean_object* l_Lean_Meta_metaExt; lean_object* l_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); uint8_t lean_expr_eqv(lean_object*, lean_object*); -lean_object* l_Lean_Meta_usingDefault(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_liftStateMCtx___rarg___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_tracer___lambda__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_usingAtLeastTransparency___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_hasMVar(lean_object*); +lean_object* l_Lean_Meta_whnfUsingDefault(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_tracer___closed__2; +lean_object* l_Lean_Meta_synthPendingRef; lean_object* l_Lean_Meta_getConstAux(lean_object*, uint8_t, lean_object*, lean_object*); lean_object* lean_metavar_ctx_assign_level(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_throwEx___rarg___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_1__whenDebugging___rarg(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnfRef; +lean_object* l_Lean_Meta_synthPending(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___closed__3; +lean_object* l_Lean_Meta_isExprDefEqAuxRef; lean_object* l_Lean_Meta_TransparencyMode_HasBeq; lean_object* l_Lean_Meta_throwBug___rarg___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_dbgTrace___rarg___lambda__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_tracer___closed__1; -lean_object* l_Lean_Meta_lambdaTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_lambdaTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_4__liftMkBindingM___rarg(lean_object*, lean_object*, lean_object*); +lean_object* lean_io_ref_reset(lean_object*, lean_object*); lean_object* l_Lean_Meta_assignLevelMVar___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isExprMVarAssigned(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_tracer___lambda__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isReducible(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_registerEnvExtensionUnsafe___rarg___closed__2; lean_object* l_Lean_Meta_withNewLocalInstances___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_dbgTrace(lean_object*); lean_object* l_Lean_Meta_mkFreshId(lean_object*); lean_object* l_Lean_Meta_usingTransparency___rarg(uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceReducibleOnly_x3f___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_TransparencyMode_beq___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Meta_metaExt___elambda__1(lean_object*); lean_object* l_Lean_Meta_getTransparency___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateMVars___boxed(lean_object*, lean_object*, lean_object*); +lean_object* lean_io_ref_set(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4(lean_object*); +lean_object* l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1(lean_object*, lean_object*); uint8_t l_Lean_Meta_TransparencyMode_lt(uint8_t, uint8_t); lean_object* l_Lean_Meta_assignExprMVar___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkInferTypeRef(lean_object*); lean_object* l_Lean_Meta_mkLambda(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getTransparency(lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateMVars(lean_object*, lean_object*, lean_object*); size_t lean_usize_mix_hash(size_t, size_t); +lean_object* l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1(lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_io_initializing(lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_2__getOptions(lean_object*, lean_object*); lean_object* l_Lean_Meta_isClassQuickConst(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_EnvExtension_getStateUnsafe___rarg(lean_object*, lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited; lean_object* l_Lean_Meta_getMCtx___rarg(lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main(lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_4__liftMkBindingM(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2(lean_object*); +lean_object* l_Lean_Meta_mkWHNFRef___closed__1; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3(lean_object*); +lean_object* l_Lean_Meta_mkMetaExtension___closed__3; lean_object* l_Lean_Meta_isClassQuick___main___closed__1; lean_object* lean_metavar_ctx_get_expr_assignment(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_2__getOptions___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2(lean_object*); +lean_object* l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__2; lean_object* l_Lean_Meta_TransparencyMode_hash___boxed(lean_object*); lean_object* l_Lean_Meta_resettingTypeClassCache(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getMCtx(lean_object*); +lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_3__getTraceState(lean_object*); +lean_object* l_Lean_Meta_isSyntheticExprMVar(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVarId___boxed(lean_object*); extern lean_object* l_HashMap_Inhabited___closed__1; +lean_object* l_Lean_Meta_mkInferTypeRef___closed__1; lean_object* l_Lean_Meta_isReadOnlyLevelMVar(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkWHNFRef___lambda__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withNewLocalInstance(lean_object*); +lean_object* l_Lean_Meta_mkWHNFRef(lean_object*); lean_object* l___private_Init_Lean_Meta_Basic_1__whenDebugging(lean_object*); lean_object* l_Lean_Meta_usingTransparency___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_local_ctx_find(lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_MkBinding_mkBinding___at_Lean_MetavarContext_mkBinding___spec__1(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getConfig(lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getLCtx(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClassExpensive(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_reduceReducibleOnly_x3f(lean_object*, lean_object*); lean_object* l_Lean_Meta_resettingTypeClassCache___rarg(lean_object*, lean_object*, lean_object*); lean_object* lean_name_mk_numeral(lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4(lean_object*, lean_object*); uint8_t lean_is_class(lean_object*, lean_object*); -lean_object* l_Lean_Meta_forallTelescopeReducing___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_forallBoundedTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5(lean_object*); +lean_object* l_Lean_Meta_forallTelescopeReducing___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_forallBoundedTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isSyntheticExprMVar___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__1; lean_object* l_Lean_Meta_getFVarLocalDecl___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3(lean_object*, lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_Lean_Meta_getConstAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3(lean_object*); uint8_t _init_l_Lean_Meta_TransparencyMode_Inhabited() { _start: { @@ -748,6 +858,859 @@ lean_dec(x_1); return x_2; } } +lean_object* _init_l_Lean_Meta_mkWHNFRef___lambda__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("whnf implementation was not set"); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_mkWHNFRef___lambda__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_mkWHNFRef___lambda__1___closed__1; +x_2 = lean_alloc_ctor(15, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_Lean_Meta_mkWHNFRef___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l_Lean_Meta_mkWHNFRef___lambda__1___closed__2; +x_5 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_5, 0, x_4); +lean_ctor_set(x_5, 1, x_3); +return x_5; +} +} +lean_object* _init_l_Lean_Meta_mkWHNFRef___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_mkWHNFRef___lambda__1___boxed), 3, 0); +return x_1; +} +} +lean_object* l_Lean_Meta_mkWHNFRef(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = l_Lean_Meta_mkWHNFRef___closed__1; +x_3 = lean_io_mk_ref(x_2, x_1); +return x_3; +} +} +lean_object* l_Lean_Meta_mkWHNFRef___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_mkWHNFRef___lambda__1(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* _init_l_Lean_Meta_mkInferTypeRef___lambda__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("inferType implementation was not set"); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_mkInferTypeRef___lambda__1___closed__1; +x_2 = lean_alloc_ctor(15, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2; +x_5 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_5, 0, x_4); +lean_ctor_set(x_5, 1, x_3); +return x_5; +} +} +lean_object* _init_l_Lean_Meta_mkInferTypeRef___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_mkInferTypeRef___lambda__1___boxed), 3, 0); +return x_1; +} +} +lean_object* l_Lean_Meta_mkInferTypeRef(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = l_Lean_Meta_mkInferTypeRef___closed__1; +x_3 = lean_io_mk_ref(x_2, x_1); +return x_3; +} +} +lean_object* l_Lean_Meta_mkInferTypeRef___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_mkInferTypeRef___lambda__1(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* _init_l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("isDefEq implementation was not set"); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__1; +x_2 = lean_alloc_ctor(15, 1, 0); +lean_ctor_set(x_2, 0, x_1); +return x_2; +} +} +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; +x_5 = l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__2; +x_6 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_6, 0, x_5); +lean_ctor_set(x_6, 1, x_4); +return x_6; +} +} +lean_object* _init_l_Lean_Meta_mkIsExprDefEqAuxRef___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___boxed), 4, 0); +return x_1; +} +} +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = l_Lean_Meta_mkIsExprDefEqAuxRef___closed__1; +x_3 = lean_io_mk_ref(x_2, x_1); +return x_3; +} +} +lean_object* l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1(x_1, x_2, x_3, x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_5; +} +} +lean_object* l_Lean_Meta_mkSynthPendingRef___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; lean_object* x_5; lean_object* x_6; +x_4 = 0; +x_5 = lean_box(x_4); +x_6 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_6, 0, x_5); +lean_ctor_set(x_6, 1, x_3); +return x_6; +} +} +lean_object* _init_l_Lean_Meta_mkSynthPendingRef___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_mkSynthPendingRef___lambda__1___boxed), 3, 0); +return x_1; +} +} +lean_object* l_Lean_Meta_mkSynthPendingRef(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = l_Lean_Meta_mkSynthPendingRef___closed__1; +x_3 = lean_io_mk_ref(x_2, x_1); +return x_3; +} +} +lean_object* l_Lean_Meta_mkSynthPendingRef___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_mkSynthPendingRef___lambda__1(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_4, 0, x_1); +lean_ctor_set(x_4, 1, x_3); +return x_4; +} +} +lean_object* l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg___boxed), 3, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; +x_5 = l_Lean_Meta_Exception_Inhabited___closed__1; +x_6 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_6, 0, x_5); +lean_ctor_set(x_6, 1, x_4); +return x_6; +} +} +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l_Lean_Meta_Exception_Inhabited___closed__1; +x_5 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_5, 0, x_4); +lean_ctor_set(x_5, 1, x_3); +return x_5; +} +} +lean_object* _init_l_Lean_Meta_MetaExtState_inhabited___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg___boxed), 3, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_MetaExtState_inhabited___closed__2() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_MetaExtState_inhabited___lambda__1___boxed), 4, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_MetaExtState_inhabited___closed__3() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_MetaExtState_inhabited___lambda__2___boxed), 3, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_MetaExtState_inhabited___closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_1 = l_Lean_Meta_MetaExtState_inhabited___closed__1; +x_2 = l_Lean_Meta_MetaExtState_inhabited___closed__2; +x_3 = l_Lean_Meta_MetaExtState_inhabited___closed__3; +x_4 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_4, 0, x_1); +lean_ctor_set(x_4, 1, x_1); +lean_ctor_set(x_4, 2, x_2); +lean_ctor_set(x_4, 3, x_3); +return x_4; +} +} +lean_object* _init_l_Lean_Meta_MetaExtState_inhabited() { +_start: +{ +lean_object* x_1; +x_1 = l_Lean_Meta_MetaExtState_inhabited___closed__4; +return x_1; +} +} +lean_object* l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Meta_MetaExtState_inhabited___lambda__1(x_1, x_2, x_3, x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_5; +} +} +lean_object* l_Lean_Meta_MetaExtState_inhabited___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_MetaExtState_inhabited___lambda__2(x_1, x_2, x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_4; +} +} +lean_object* _init_l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_ReaderT_pure___at_Lean_Meta_MetaExtState_inhabited___spec__1___rarg___boxed), 3, 0); +return x_1; +} +} +lean_object* _init_l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_1 = l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__1; +x_2 = l_Lean_Meta_MetaExtState_inhabited___closed__2; +x_3 = l_Lean_Meta_MetaExtState_inhabited___closed__3; +x_4 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_4, 0, x_1); +lean_ctor_set(x_4, 1, x_1); +lean_ctor_set(x_4, 2, x_2); +lean_ctor_set(x_4, 3, x_3); +return x_4; +} +} +lean_object* l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = lean_io_initializing(x_2); +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_4; uint8_t x_5; +x_4 = lean_ctor_get(x_3, 0); +lean_inc(x_4); +x_5 = lean_unbox(x_4); +lean_dec(x_4); +if (x_5 == 0) +{ +uint8_t x_6; +lean_dec(x_1); +x_6 = !lean_is_exclusive(x_3); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; +x_7 = lean_ctor_get(x_3, 0); +lean_dec(x_7); +x_8 = l_Lean_registerEnvExtensionUnsafe___rarg___closed__1; +lean_ctor_set_tag(x_3, 1); +lean_ctor_set(x_3, 0, x_8); +return x_3; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_3, 1); +lean_inc(x_9); +lean_dec(x_3); +x_10 = l_Lean_registerEnvExtensionUnsafe___rarg___closed__1; +x_11 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_9); +return x_11; +} +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_3, 1); +lean_inc(x_12); +lean_dec(x_3); +x_13 = l___private_Init_Lean_Environment_5__envExtensionsRef; +x_14 = lean_io_ref_get(x_13, x_12); +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_14, 1); +lean_inc(x_16); +lean_dec(x_14); +x_17 = lean_array_get_size(x_15); +lean_dec(x_15); +x_18 = l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__2; +x_19 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_1); +lean_ctor_set(x_19, 2, x_18); +x_20 = lean_io_ref_get(x_13, x_16); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = lean_io_ref_reset(x_13, x_22); +if (lean_obj_tag(x_23) == 0) +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_24 = lean_ctor_get(x_23, 1); +lean_inc(x_24); +lean_dec(x_23); +x_25 = l_Lean_registerEnvExtensionUnsafe___rarg___closed__2; +lean_inc(x_19); +x_26 = x_19; +x_27 = lean_array_push(x_21, x_26); +x_28 = lean_io_ref_set(x_13, x_27, x_24); +if (lean_obj_tag(x_28) == 0) +{ +uint8_t x_29; +x_29 = !lean_is_exclusive(x_28); +if (x_29 == 0) +{ +lean_object* x_30; +x_30 = lean_ctor_get(x_28, 0); +lean_dec(x_30); +lean_ctor_set(x_28, 0, x_19); +return x_28; +} +else +{ +lean_object* x_31; lean_object* x_32; +x_31 = lean_ctor_get(x_28, 1); +lean_inc(x_31); +lean_dec(x_28); +x_32 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_32, 0, x_19); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +else +{ +uint8_t x_33; +lean_dec(x_19); +x_33 = !lean_is_exclusive(x_28); +if (x_33 == 0) +{ +return x_28; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = lean_ctor_get(x_28, 0); +x_35 = lean_ctor_get(x_28, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_28); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +} +else +{ +uint8_t x_37; +lean_dec(x_21); +lean_dec(x_19); +x_37 = !lean_is_exclusive(x_23); +if (x_37 == 0) +{ +return x_23; +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_23, 0); +x_39 = lean_ctor_get(x_23, 1); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_23); +x_40 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_40, 0, x_38); +lean_ctor_set(x_40, 1, x_39); +return x_40; +} +} +} +else +{ +uint8_t x_41; +lean_dec(x_19); +x_41 = !lean_is_exclusive(x_20); +if (x_41 == 0) +{ +return x_20; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_20, 0); +x_43 = lean_ctor_get(x_20, 1); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_20); +x_44 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_44, 0, x_42); +lean_ctor_set(x_44, 1, x_43); +return x_44; +} +} +} +else +{ +uint8_t x_45; +lean_dec(x_1); +x_45 = !lean_is_exclusive(x_14); +if (x_45 == 0) +{ +return x_14; +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_46 = lean_ctor_get(x_14, 0); +x_47 = lean_ctor_get(x_14, 1); +lean_inc(x_47); +lean_inc(x_46); +lean_dec(x_14); +x_48 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_48, 0, x_46); +lean_ctor_set(x_48, 1, x_47); +return x_48; +} +} +} +} +else +{ +uint8_t x_49; +lean_dec(x_1); +x_49 = !lean_is_exclusive(x_3); +if (x_49 == 0) +{ +return x_3; +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_50 = lean_ctor_get(x_3, 0); +x_51 = lean_ctor_get(x_3, 1); +lean_inc(x_51); +lean_inc(x_50); +lean_dec(x_3); +x_52 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_52, 0, x_50); +lean_ctor_set(x_52, 1, x_51); +return x_52; +} +} +} +} +lean_object* l_Lean_Meta_mkMetaExtension___lambda__1(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; +x_3 = l_Lean_Meta_inferTypeRef; +x_4 = lean_io_ref_get(x_3, x_2); +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_4, 1); +lean_inc(x_6); +lean_dec(x_4); +x_7 = l_Lean_Meta_isExprDefEqAuxRef; +x_8 = lean_io_ref_get(x_7, x_6); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +lean_dec(x_8); +x_11 = l_Lean_Meta_synthPendingRef; +x_12 = lean_io_ref_get(x_11, x_10); +if (lean_obj_tag(x_12) == 0) +{ +uint8_t x_13; +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_12, 0); +x_15 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_15, 0, x_1); +lean_ctor_set(x_15, 1, x_5); +lean_ctor_set(x_15, 2, x_9); +lean_ctor_set(x_15, 3, x_14); +lean_ctor_set(x_12, 0, x_15); +return x_12; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_12, 0); +x_17 = lean_ctor_get(x_12, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_12); +x_18 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_18, 0, x_1); +lean_ctor_set(x_18, 1, x_5); +lean_ctor_set(x_18, 2, x_9); +lean_ctor_set(x_18, 3, x_16); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_18); +lean_ctor_set(x_19, 1, x_17); +return x_19; +} +} +else +{ +uint8_t x_20; +lean_dec(x_9); +lean_dec(x_5); +lean_dec(x_1); +x_20 = !lean_is_exclusive(x_12); +if (x_20 == 0) +{ +return x_12; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_12, 0); +x_22 = lean_ctor_get(x_12, 1); +lean_inc(x_22); +lean_inc(x_21); +lean_dec(x_12); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_21); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +} +else +{ +uint8_t x_24; +lean_dec(x_5); +lean_dec(x_1); +x_24 = !lean_is_exclusive(x_8); +if (x_24 == 0) +{ +return x_8; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_8, 0); +x_26 = lean_ctor_get(x_8, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_8); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +else +{ +uint8_t x_28; +lean_dec(x_1); +x_28 = !lean_is_exclusive(x_4); +if (x_28 == 0) +{ +return x_4; +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_4, 0); +x_30 = lean_ctor_get(x_4, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_4); +x_31 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +} +} +lean_object* _init_l_Lean_Meta_mkMetaExtension___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Lean_Meta_whnfRef; +x_2 = lean_alloc_closure((void*)(l_IO_Prim_Ref_get___boxed), 3, 2); +lean_closure_set(x_2, 0, lean_box(0)); +lean_closure_set(x_2, 1, x_1); +return x_2; +} +} +lean_object* _init_l_Lean_Meta_mkMetaExtension___closed__2() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_mkMetaExtension___lambda__1), 2, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_mkMetaExtension___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Meta_mkMetaExtension___closed__1; +x_2 = l_Lean_Meta_mkMetaExtension___closed__2; +x_3 = lean_alloc_closure((void*)(l_EStateM_bind___rarg), 3, 2); +lean_closure_set(x_3, 0, x_1); +lean_closure_set(x_3, 1, x_2); +return x_3; +} +} +lean_object* l_Lean_Meta_mkMetaExtension(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = l_Lean_Meta_mkMetaExtension___closed__3; +x_3 = l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1(x_2, x_1); +return x_3; +} +} +lean_object* l_Lean_Meta_metaExt___elambda__1(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; +x_2 = l_String_splitAux___main___closed__1; +x_3 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_3, 0, x_2); +lean_ctor_set(x_3, 1, x_1); +return x_3; +} +} +lean_object* _init_l_Lean_Meta_metaExt___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_metaExt___elambda__1), 1, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_metaExt___closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_1 = lean_unsigned_to_nat(0u); +x_2 = l_Lean_Meta_metaExt___closed__1; +x_3 = l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__2; +x_4 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_4, 0, x_1); +lean_ctor_set(x_4, 1, x_2); +lean_ctor_set(x_4, 2, x_3); +return x_4; +} +} +lean_object* l_Lean_Meta_whnf(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_4 = lean_ctor_get(x_3, 0); +lean_inc(x_4); +x_5 = l_Lean_Meta_metaExt; +x_6 = l_Lean_EnvExtension_getStateUnsafe___rarg(x_5, x_4); +lean_dec(x_4); +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_3(x_7, x_1, x_2, x_3); +return x_8; +} +} +lean_object* l_Lean_Meta_inferType(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_4 = lean_ctor_get(x_3, 0); +lean_inc(x_4); +x_5 = l_Lean_Meta_metaExt; +x_6 = l_Lean_EnvExtension_getStateUnsafe___rarg(x_5, x_4); +lean_dec(x_4); +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_3(x_7, x_1, x_2, x_3); +return x_8; +} +} +lean_object* l_Lean_Meta_isExprDefEqAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = l_Lean_Meta_metaExt; +x_7 = l_Lean_EnvExtension_getStateUnsafe___rarg(x_6, x_5); +lean_dec(x_5); +x_8 = lean_ctor_get(x_7, 2); +lean_inc(x_8); +lean_dec(x_7); +x_9 = lean_apply_4(x_8, x_1, x_2, x_3, x_4); +return x_9; +} +} +lean_object* l_Lean_Meta_synthPending(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_4 = lean_ctor_get(x_3, 0); +lean_inc(x_4); +x_5 = l_Lean_Meta_metaExt; +x_6 = l_Lean_EnvExtension_getStateUnsafe___rarg(x_5, x_4); +lean_dec(x_4); +x_7 = lean_ctor_get(x_6, 3); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_3(x_7, x_1, x_2, x_3); +return x_8; +} +} lean_object* l_Lean_Meta_throwEx___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -800,7 +1763,7 @@ x_7 = lean_alloc_ctor(0, 3, 0); lean_ctor_set(x_7, 0, x_4); lean_ctor_set(x_7, 1, x_5); lean_ctor_set(x_7, 2, x_6); -x_8 = lean_alloc_ctor(13, 2, 0); +x_8 = lean_alloc_ctor(14, 2, 0); lean_ctor_set(x_8, 0, x_1); lean_ctor_set(x_8, 1, x_7); x_9 = lean_alloc_ctor(1, 2, 0); @@ -832,7 +1795,7 @@ _start: lean_object* x_4; uint8_t x_5; x_4 = lean_ctor_get(x_2, 0); lean_inc(x_4); -x_5 = lean_ctor_get_uint8(x_4, sizeof(void*)*1 + 3); +x_5 = lean_ctor_get_uint8(x_4, sizeof(void*)*1 + 4); lean_dec(x_4); if (x_5 == 0) { @@ -1036,7 +1999,7 @@ _start: { lean_object* x_3; uint8_t x_4; uint8_t x_5; uint8_t x_6; lean_object* x_7; lean_object* x_8; x_3 = lean_ctor_get(x_1, 0); -x_4 = lean_ctor_get_uint8(x_3, sizeof(void*)*1 + 4); +x_4 = lean_ctor_get_uint8(x_3, sizeof(void*)*1 + 5); x_5 = 0; x_6 = l_Lean_Meta_TransparencyMode_beq(x_4, x_5); x_7 = lean_box(x_6); @@ -1060,7 +2023,7 @@ _start: { lean_object* x_3; uint8_t x_4; uint8_t x_5; uint8_t x_6; lean_object* x_7; lean_object* x_8; x_3 = lean_ctor_get(x_1, 0); -x_4 = lean_ctor_get_uint8(x_3, sizeof(void*)*1 + 4); +x_4 = lean_ctor_get_uint8(x_3, sizeof(void*)*1 + 5); x_5 = 2; x_6 = l_Lean_Meta_TransparencyMode_beq(x_4, x_5); x_7 = lean_box(x_6); @@ -1084,7 +2047,7 @@ _start: { lean_object* x_3; uint8_t x_4; lean_object* x_5; lean_object* x_6; x_3 = lean_ctor_get(x_1, 0); -x_4 = lean_ctor_get_uint8(x_3, sizeof(void*)*1 + 4); +x_4 = lean_ctor_get_uint8(x_3, sizeof(void*)*1 + 5); x_5 = lean_box(x_4); x_6 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_6, 0, x_5); @@ -1159,72 +2122,76 @@ x_7 = !lean_is_exclusive(x_6); if (x_7 == 0) { lean_object* x_8; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_1); +lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 5, x_1); x_8 = lean_apply_2(x_2, x_3, x_4); return x_8; } else { -lean_object* x_9; uint8_t x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; +lean_object* x_9; uint8_t x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; x_9 = lean_ctor_get(x_6, 0); x_10 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); x_11 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); x_12 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); x_13 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); +x_14 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 4); lean_inc(x_9); lean_dec(x_6); -x_14 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_14, 0, x_9); -lean_ctor_set_uint8(x_14, sizeof(void*)*1, x_10); -lean_ctor_set_uint8(x_14, sizeof(void*)*1 + 1, x_11); -lean_ctor_set_uint8(x_14, sizeof(void*)*1 + 2, x_12); -lean_ctor_set_uint8(x_14, sizeof(void*)*1 + 3, x_13); -lean_ctor_set_uint8(x_14, sizeof(void*)*1 + 4, x_1); -lean_ctor_set(x_3, 0, x_14); -x_15 = lean_apply_2(x_2, x_3, x_4); -return x_15; +x_15 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_15, 0, x_9); +lean_ctor_set_uint8(x_15, sizeof(void*)*1, x_10); +lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 1, x_11); +lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 2, x_12); +lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 3, x_13); +lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 4, x_14); +lean_ctor_set_uint8(x_15, sizeof(void*)*1 + 5, x_1); +lean_ctor_set(x_3, 0, x_15); +x_16 = lean_apply_2(x_2, x_3, x_4); +return x_16; } } else { -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; uint8_t x_20; uint8_t x_21; uint8_t x_22; uint8_t x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_16 = lean_ctor_get(x_3, 0); -x_17 = lean_ctor_get(x_3, 1); -x_18 = lean_ctor_get(x_3, 2); +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_17 = lean_ctor_get(x_3, 0); +x_18 = lean_ctor_get(x_3, 1); +x_19 = lean_ctor_get(x_3, 2); +lean_inc(x_19); lean_inc(x_18); lean_inc(x_17); -lean_inc(x_16); lean_dec(x_3); -x_19 = lean_ctor_get(x_16, 0); -lean_inc(x_19); -x_20 = lean_ctor_get_uint8(x_16, sizeof(void*)*1); -x_21 = lean_ctor_get_uint8(x_16, sizeof(void*)*1 + 1); -x_22 = lean_ctor_get_uint8(x_16, sizeof(void*)*1 + 2); -x_23 = lean_ctor_get_uint8(x_16, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - x_24 = x_16; +x_20 = lean_ctor_get(x_17, 0); +lean_inc(x_20); +x_21 = lean_ctor_get_uint8(x_17, sizeof(void*)*1); +x_22 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 1); +x_23 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 2); +x_24 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 3); +x_25 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 4); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + x_26 = x_17; } else { - lean_dec_ref(x_16); - x_24 = lean_box(0); + lean_dec_ref(x_17); + x_26 = lean_box(0); } -if (lean_is_scalar(x_24)) { - x_25 = lean_alloc_ctor(0, 1, 5); +if (lean_is_scalar(x_26)) { + x_27 = lean_alloc_ctor(0, 1, 6); } else { - x_25 = x_24; + x_27 = x_26; } -lean_ctor_set(x_25, 0, x_19); -lean_ctor_set_uint8(x_25, sizeof(void*)*1, x_20); -lean_ctor_set_uint8(x_25, sizeof(void*)*1 + 1, x_21); -lean_ctor_set_uint8(x_25, sizeof(void*)*1 + 2, x_22); -lean_ctor_set_uint8(x_25, sizeof(void*)*1 + 3, x_23); -lean_ctor_set_uint8(x_25, sizeof(void*)*1 + 4, x_1); -x_26 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_26, 0, x_25); -lean_ctor_set(x_26, 1, x_17); -lean_ctor_set(x_26, 2, x_18); -x_27 = lean_apply_2(x_2, x_26, x_4); -return x_27; +lean_ctor_set(x_27, 0, x_20); +lean_ctor_set_uint8(x_27, sizeof(void*)*1, x_21); +lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 1, x_22); +lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 2, x_23); +lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 3, x_24); +lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 4, x_25); +lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 5, x_1); +x_28 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_28, 0, x_27); +lean_ctor_set(x_28, 1, x_18); +lean_ctor_set(x_28, 2, x_19); +x_29 = lean_apply_2(x_2, x_28, x_4); +return x_29; } } } @@ -1259,7 +2226,7 @@ x_7 = !lean_is_exclusive(x_6); if (x_7 == 0) { uint8_t x_8; uint8_t x_9; -x_8 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 4); +x_8 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 5); x_9 = l_Lean_Meta_TransparencyMode_lt(x_8, x_1); if (x_9 == 0) { @@ -1270,119 +2237,125 @@ return x_10; else { lean_object* x_11; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_1); +lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 5, x_1); x_11 = lean_apply_2(x_2, x_3, x_4); return x_11; } } else { -lean_object* x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; uint8_t x_16; uint8_t x_17; uint8_t x_18; +lean_object* x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; uint8_t x_16; uint8_t x_17; uint8_t x_18; uint8_t x_19; x_12 = lean_ctor_get(x_6, 0); x_13 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); x_14 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); x_15 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); x_16 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); x_17 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 4); +x_18 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 5); lean_inc(x_12); lean_dec(x_6); -x_18 = l_Lean_Meta_TransparencyMode_lt(x_17, x_1); -if (x_18 == 0) +x_19 = l_Lean_Meta_TransparencyMode_lt(x_18, x_1); +if (x_19 == 0) { -lean_object* x_19; lean_object* x_20; -x_19 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_19, 0, x_12); -lean_ctor_set_uint8(x_19, sizeof(void*)*1, x_13); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 1, x_14); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 2, x_15); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 3, x_16); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 4, x_17); -lean_ctor_set(x_3, 0, x_19); -x_20 = lean_apply_2(x_2, x_3, x_4); -return x_20; +lean_object* x_20; lean_object* x_21; +x_20 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_20, 0, x_12); +lean_ctor_set_uint8(x_20, sizeof(void*)*1, x_13); +lean_ctor_set_uint8(x_20, sizeof(void*)*1 + 1, x_14); +lean_ctor_set_uint8(x_20, sizeof(void*)*1 + 2, x_15); +lean_ctor_set_uint8(x_20, sizeof(void*)*1 + 3, x_16); +lean_ctor_set_uint8(x_20, sizeof(void*)*1 + 4, x_17); +lean_ctor_set_uint8(x_20, sizeof(void*)*1 + 5, x_18); +lean_ctor_set(x_3, 0, x_20); +x_21 = lean_apply_2(x_2, x_3, x_4); +return x_21; } else { -lean_object* x_21; lean_object* x_22; -x_21 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_21, 0, x_12); -lean_ctor_set_uint8(x_21, sizeof(void*)*1, x_13); -lean_ctor_set_uint8(x_21, sizeof(void*)*1 + 1, x_14); -lean_ctor_set_uint8(x_21, sizeof(void*)*1 + 2, x_15); -lean_ctor_set_uint8(x_21, sizeof(void*)*1 + 3, x_16); -lean_ctor_set_uint8(x_21, sizeof(void*)*1 + 4, x_1); -lean_ctor_set(x_3, 0, x_21); -x_22 = lean_apply_2(x_2, x_3, x_4); -return x_22; +lean_object* x_22; lean_object* x_23; +x_22 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_22, 0, x_12); +lean_ctor_set_uint8(x_22, sizeof(void*)*1, x_13); +lean_ctor_set_uint8(x_22, sizeof(void*)*1 + 1, x_14); +lean_ctor_set_uint8(x_22, sizeof(void*)*1 + 2, x_15); +lean_ctor_set_uint8(x_22, sizeof(void*)*1 + 3, x_16); +lean_ctor_set_uint8(x_22, sizeof(void*)*1 + 4, x_17); +lean_ctor_set_uint8(x_22, sizeof(void*)*1 + 5, x_1); +lean_ctor_set(x_3, 0, x_22); +x_23 = lean_apply_2(x_2, x_3, x_4); +return x_23; } } } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; uint8_t x_28; uint8_t x_29; uint8_t x_30; uint8_t x_31; lean_object* x_32; uint8_t x_33; -x_23 = lean_ctor_get(x_3, 0); -x_24 = lean_ctor_get(x_3, 1); -x_25 = lean_ctor_get(x_3, 2); +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; uint8_t x_28; uint8_t x_29; uint8_t x_30; uint8_t x_31; uint8_t x_32; uint8_t x_33; lean_object* x_34; uint8_t x_35; +x_24 = lean_ctor_get(x_3, 0); +x_25 = lean_ctor_get(x_3, 1); +x_26 = lean_ctor_get(x_3, 2); +lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); -lean_inc(x_23); lean_dec(x_3); -x_26 = lean_ctor_get(x_23, 0); -lean_inc(x_26); -x_27 = lean_ctor_get_uint8(x_23, sizeof(void*)*1); -x_28 = lean_ctor_get_uint8(x_23, sizeof(void*)*1 + 1); -x_29 = lean_ctor_get_uint8(x_23, sizeof(void*)*1 + 2); -x_30 = lean_ctor_get_uint8(x_23, sizeof(void*)*1 + 3); -x_31 = lean_ctor_get_uint8(x_23, sizeof(void*)*1 + 4); -if (lean_is_exclusive(x_23)) { - lean_ctor_release(x_23, 0); - x_32 = x_23; +x_27 = lean_ctor_get(x_24, 0); +lean_inc(x_27); +x_28 = lean_ctor_get_uint8(x_24, sizeof(void*)*1); +x_29 = lean_ctor_get_uint8(x_24, sizeof(void*)*1 + 1); +x_30 = lean_ctor_get_uint8(x_24, sizeof(void*)*1 + 2); +x_31 = lean_ctor_get_uint8(x_24, sizeof(void*)*1 + 3); +x_32 = lean_ctor_get_uint8(x_24, sizeof(void*)*1 + 4); +x_33 = lean_ctor_get_uint8(x_24, sizeof(void*)*1 + 5); +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + x_34 = x_24; } else { - lean_dec_ref(x_23); - x_32 = lean_box(0); + lean_dec_ref(x_24); + x_34 = lean_box(0); } -x_33 = l_Lean_Meta_TransparencyMode_lt(x_31, x_1); -if (x_33 == 0) +x_35 = l_Lean_Meta_TransparencyMode_lt(x_33, x_1); +if (x_35 == 0) { -lean_object* x_34; lean_object* x_35; lean_object* x_36; -if (lean_is_scalar(x_32)) { - x_34 = lean_alloc_ctor(0, 1, 5); +lean_object* x_36; lean_object* x_37; lean_object* x_38; +if (lean_is_scalar(x_34)) { + x_36 = lean_alloc_ctor(0, 1, 6); } else { - x_34 = x_32; + x_36 = x_34; } -lean_ctor_set(x_34, 0, x_26); -lean_ctor_set_uint8(x_34, sizeof(void*)*1, x_27); -lean_ctor_set_uint8(x_34, sizeof(void*)*1 + 1, x_28); -lean_ctor_set_uint8(x_34, sizeof(void*)*1 + 2, x_29); -lean_ctor_set_uint8(x_34, sizeof(void*)*1 + 3, x_30); -lean_ctor_set_uint8(x_34, sizeof(void*)*1 + 4, x_31); -x_35 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_35, 0, x_34); -lean_ctor_set(x_35, 1, x_24); -lean_ctor_set(x_35, 2, x_25); -x_36 = lean_apply_2(x_2, x_35, x_4); -return x_36; +lean_ctor_set(x_36, 0, x_27); +lean_ctor_set_uint8(x_36, sizeof(void*)*1, x_28); +lean_ctor_set_uint8(x_36, sizeof(void*)*1 + 1, x_29); +lean_ctor_set_uint8(x_36, sizeof(void*)*1 + 2, x_30); +lean_ctor_set_uint8(x_36, sizeof(void*)*1 + 3, x_31); +lean_ctor_set_uint8(x_36, sizeof(void*)*1 + 4, x_32); +lean_ctor_set_uint8(x_36, sizeof(void*)*1 + 5, x_33); +x_37 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_37, 0, x_36); +lean_ctor_set(x_37, 1, x_25); +lean_ctor_set(x_37, 2, x_26); +x_38 = lean_apply_2(x_2, x_37, x_4); +return x_38; } else { -lean_object* x_37; lean_object* x_38; lean_object* x_39; -if (lean_is_scalar(x_32)) { - x_37 = lean_alloc_ctor(0, 1, 5); +lean_object* x_39; lean_object* x_40; lean_object* x_41; +if (lean_is_scalar(x_34)) { + x_39 = lean_alloc_ctor(0, 1, 6); } else { - x_37 = x_32; + x_39 = x_34; } -lean_ctor_set(x_37, 0, x_26); -lean_ctor_set_uint8(x_37, sizeof(void*)*1, x_27); -lean_ctor_set_uint8(x_37, sizeof(void*)*1 + 1, x_28); -lean_ctor_set_uint8(x_37, sizeof(void*)*1 + 2, x_29); -lean_ctor_set_uint8(x_37, sizeof(void*)*1 + 3, x_30); -lean_ctor_set_uint8(x_37, sizeof(void*)*1 + 4, x_1); -x_38 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_38, 0, x_37); -lean_ctor_set(x_38, 1, x_24); -lean_ctor_set(x_38, 2, x_25); -x_39 = lean_apply_2(x_2, x_38, x_4); -return x_39; +lean_ctor_set(x_39, 0, x_27); +lean_ctor_set_uint8(x_39, sizeof(void*)*1, x_28); +lean_ctor_set_uint8(x_39, sizeof(void*)*1 + 1, x_29); +lean_ctor_set_uint8(x_39, sizeof(void*)*1 + 2, x_30); +lean_ctor_set_uint8(x_39, sizeof(void*)*1 + 3, x_31); +lean_ctor_set_uint8(x_39, sizeof(void*)*1 + 4, x_32); +lean_ctor_set_uint8(x_39, sizeof(void*)*1 + 5, x_1); +x_40 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_40, 0, x_39); +lean_ctor_set(x_40, 1, x_25); +lean_ctor_set(x_40, 2, x_26); +x_41 = lean_apply_2(x_2, x_40, x_4); +return x_41; } } } @@ -1405,6 +2378,62 @@ x_6 = l_Lean_Meta_usingAtLeastTransparency___rarg(x_5, x_2, x_3, x_4); return x_6; } } +lean_object* l_Lean_Meta_isSyntheticExprMVar(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; +x_4 = lean_ctor_get(x_3, 0); +lean_inc(x_4); +x_5 = lean_ctor_get(x_3, 1); +lean_inc(x_5); +lean_inc(x_1); +lean_inc(x_5); +x_6 = lean_metavar_ctx_find_decl(x_5, x_1); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_7 = lean_ctor_get(x_2, 1); +lean_inc(x_7); +x_8 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_8, 0, x_4); +lean_ctor_set(x_8, 1, x_5); +lean_ctor_set(x_8, 2, x_7); +x_9 = lean_alloc_ctor(2, 2, 0); +lean_ctor_set(x_9, 0, x_1); +lean_ctor_set(x_9, 1, x_8); +x_10 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_3); +return x_10; +} +else +{ +lean_object* x_11; uint8_t x_12; lean_object* x_13; lean_object* x_14; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_11 = lean_ctor_get(x_6, 0); +lean_inc(x_11); +lean_dec(x_6); +x_12 = lean_ctor_get_uint8(x_11, sizeof(void*)*4); +lean_dec(x_11); +x_13 = lean_box(x_12); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_3); +return x_14; +} +} +} +lean_object* l_Lean_Meta_isSyntheticExprMVar___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_isSyntheticExprMVar(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} lean_object* l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -1621,7 +2650,7 @@ _start: { lean_object* x_5; lean_object* x_22; uint8_t x_23; x_22 = lean_ctor_get(x_3, 0); -x_23 = lean_ctor_get_uint8(x_22, sizeof(void*)*1 + 3); +x_23 = lean_ctor_get_uint8(x_22, sizeof(void*)*1 + 4); if (x_23 == 0) { x_5 = x_4; @@ -1958,7 +2987,7 @@ lean_dec(x_13); lean_dec(x_5); lean_dec(x_1); x_14 = lean_ctor_get(x_3, 0); -x_15 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 4); +x_15 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 5); x_16 = 0; x_17 = l_Lean_Meta_TransparencyMode_beq(x_15, x_16); if (x_17 == 0) @@ -1985,7 +3014,7 @@ else lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; lean_dec(x_13); x_21 = lean_ctor_get(x_3, 0); -x_22 = lean_ctor_get_uint8(x_21, sizeof(void*)*1 + 4); +x_22 = lean_ctor_get_uint8(x_21, sizeof(void*)*1 + 5); x_23 = 2; x_24 = l_Lean_Meta_TransparencyMode_beq(x_22, x_23); if (x_24 == 0) @@ -4296,251 +5325,245 @@ lean_dec(x_2); return x_7; } } -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, uint8_t x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { _start: { -uint8_t x_13; -x_13 = l_Lean_Expr_isForall(x_10); -if (x_13 == 0) +uint8_t x_12; +x_12 = l_Lean_Expr_isForall(x_9); +if (x_12 == 0) { -lean_object* x_14; -lean_dec(x_10); +lean_object* x_13; lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); -lean_dec(x_5); +lean_dec(x_6); lean_dec(x_4); -x_14 = lean_apply_4(x_1, x_2, x_3, x_11, x_12); +x_13 = lean_apply_4(x_1, x_2, x_3, x_10, x_11); +return x_13; +} +else +{ +lean_object* x_14; +lean_dec(x_3); +x_14 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_4, x_5, x_6, x_1, x_7, x_2, x_8, x_9, x_10, x_11); return x_14; } -else -{ -lean_object* x_15; -lean_dec(x_3); -x_15 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_4, x_5, x_6, x_7, x_1, x_8, x_2, x_9, x_10, x_11, x_12); -return x_15; } } -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { _start: { -lean_object* x_12; -if (lean_obj_tag(x_9) == 7) +lean_object* x_11; +if (lean_obj_tag(x_8) == 7) { -lean_object* x_37; lean_object* x_38; lean_object* x_39; uint64_t x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_37 = lean_ctor_get(x_9, 0); +lean_object* x_36; lean_object* x_37; lean_object* x_38; uint64_t x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; uint8_t x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_36 = lean_ctor_get(x_8, 0); +lean_inc(x_36); +x_37 = lean_ctor_get(x_8, 1); lean_inc(x_37); -x_38 = lean_ctor_get(x_9, 1); +x_38 = lean_ctor_get(x_8, 2); lean_inc(x_38); -x_39 = lean_ctor_get(x_9, 2); -lean_inc(x_39); -x_40 = lean_ctor_get_uint64(x_9, sizeof(void*)*3); -lean_dec(x_9); -x_41 = lean_array_get_size(x_7); -lean_inc(x_7); -x_42 = lean_expr_instantiate_rev_range(x_38, x_8, x_41, x_7); -lean_dec(x_41); -lean_dec(x_38); -x_43 = l_Lean_Meta_mkFreshId___rarg(x_11); -x_44 = lean_ctor_get(x_43, 0); +x_39 = lean_ctor_get_uint64(x_8, sizeof(void*)*3); +lean_dec(x_8); +x_40 = lean_array_get_size(x_6); +lean_inc(x_6); +x_41 = lean_expr_instantiate_rev_range(x_37, x_7, x_40, x_6); +lean_dec(x_40); +lean_dec(x_37); +x_42 = l_Lean_Meta_mkFreshId___rarg(x_10); +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_42, 1); lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -lean_dec(x_43); -x_46 = (uint8_t)((x_40 << 24) >> 61); -lean_inc(x_44); -x_47 = lean_local_ctx_mk_local_decl(x_6, x_44, x_37, x_42, x_46); -x_48 = l_Lean_mkFVar(x_44); -x_49 = lean_array_push(x_7, x_48); -if (lean_obj_tag(x_4) == 0) +lean_dec(x_42); +x_45 = (uint8_t)((x_39 << 24) >> 61); +lean_inc(x_43); +x_46 = lean_local_ctx_mk_local_decl(x_5, x_43, x_36, x_41, x_45); +x_47 = l_Lean_mkFVar(x_43); +x_48 = lean_array_push(x_6, x_47); +if (lean_obj_tag(x_3) == 0) { -x_6 = x_47; -x_7 = x_49; -x_9 = x_39; -x_11 = x_45; +x_5 = x_46; +x_6 = x_48; +x_8 = x_38; +x_10 = x_44; goto _start; } else { -lean_object* x_51; lean_object* x_52; uint8_t x_53; -x_51 = lean_ctor_get(x_4, 0); -lean_inc(x_51); -x_52 = lean_array_get_size(x_49); -x_53 = lean_nat_dec_lt(x_52, x_51); +lean_object* x_50; lean_object* x_51; uint8_t x_52; +x_50 = lean_ctor_get(x_3, 0); +lean_inc(x_50); +x_51 = lean_array_get_size(x_48); +x_52 = lean_nat_dec_lt(x_51, x_50); +lean_dec(x_50); +if (x_52 == 0) +{ +lean_object* x_53; lean_object* x_54; uint8_t x_55; +lean_dec(x_3); +lean_inc(x_48); +x_53 = lean_expr_instantiate_rev_range(x_38, x_7, x_51, x_48); lean_dec(x_51); -if (x_53 == 0) +lean_dec(x_38); +lean_inc(x_48); +x_54 = lean_apply_2(x_4, x_48, x_53); +x_55 = !lean_is_exclusive(x_9); +if (x_55 == 0) { -lean_object* x_54; lean_object* x_55; uint8_t x_56; -lean_dec(x_4); -lean_dec(x_1); -lean_inc(x_49); -x_54 = lean_expr_instantiate_rev_range(x_39, x_8, x_52, x_49); -lean_dec(x_52); -lean_dec(x_39); -lean_inc(x_49); -x_55 = lean_apply_2(x_5, x_49, x_54); -x_56 = !lean_is_exclusive(x_10); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; -x_57 = lean_ctor_get(x_10, 1); -lean_dec(x_57); -lean_ctor_set(x_10, 1, x_47); -x_58 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_2, x_49, x_8, x_55, x_10, x_45); -lean_dec(x_49); -return x_58; +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_9, 1); +lean_dec(x_56); +lean_ctor_set(x_9, 1, x_46); +x_57 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_48, x_7, x_54, x_9, x_44); +lean_dec(x_48); +return x_57; } else { -lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_59 = lean_ctor_get(x_10, 0); -x_60 = lean_ctor_get(x_10, 2); -lean_inc(x_60); +lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_58 = lean_ctor_get(x_9, 0); +x_59 = lean_ctor_get(x_9, 2); lean_inc(x_59); -lean_dec(x_10); -x_61 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_61, 0, x_59); -lean_ctor_set(x_61, 1, x_47); -lean_ctor_set(x_61, 2, x_60); -x_62 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_2, x_49, x_8, x_55, x_61, x_45); -lean_dec(x_49); -return x_62; +lean_inc(x_58); +lean_dec(x_9); +x_60 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_60, 0, x_58); +lean_ctor_set(x_60, 1, x_46); +lean_ctor_set(x_60, 2, x_59); +x_61 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_48, x_7, x_54, x_60, x_44); +lean_dec(x_48); +return x_61; } } else { -lean_dec(x_52); -x_6 = x_47; -x_7 = x_49; -x_9 = x_39; -x_11 = x_45; +lean_dec(x_51); +x_5 = x_46; +x_6 = x_48; +x_8 = x_38; +x_10 = x_44; goto _start; } } } else { -lean_object* x_64; -x_64 = lean_box(0); -x_12 = x_64; -goto block_36; +lean_object* x_63; +x_63 = lean_box(0); +x_11 = x_63; +goto block_35; } -block_36: +block_35: { -lean_object* x_13; lean_object* x_14; uint8_t x_15; +lean_object* x_12; lean_object* x_13; uint8_t x_14; +lean_dec(x_11); +x_12 = lean_array_get_size(x_6); +lean_inc(x_6); +x_13 = lean_expr_instantiate_rev_range(x_8, x_7, x_12, x_6); +lean_dec(x_8); +x_14 = !lean_is_exclusive(x_9); +if (x_14 == 0) +{ +lean_object* x_15; +x_15 = lean_ctor_get(x_9, 1); +lean_dec(x_15); +lean_inc(x_5); +lean_ctor_set(x_9, 1, x_5); +if (x_2 == 0) +{ +lean_object* x_16; lean_object* x_17; lean_dec(x_12); -x_13 = lean_array_get_size(x_7); -lean_inc(x_7); -x_14 = lean_expr_instantiate_rev_range(x_9, x_8, x_13, x_7); -lean_dec(x_9); -x_15 = !lean_is_exclusive(x_10); -if (x_15 == 0) -{ -lean_object* x_16; -x_16 = lean_ctor_get(x_10, 1); -lean_dec(x_16); +lean_dec(x_5); +lean_dec(x_3); lean_inc(x_6); -lean_ctor_set(x_10, 1, x_6); -if (x_3 == 0) -{ -lean_object* x_17; lean_object* x_18; -lean_dec(x_13); +x_16 = lean_apply_2(x_4, x_6, x_13); +x_17 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_6, x_7, x_16, x_9, x_10); lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_1); -lean_inc(x_7); -x_17 = lean_apply_2(x_5, x_7, x_14); -x_18 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_2, x_7, x_8, x_17, x_10, x_11); -lean_dec(x_7); -return x_18; +return x_17; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_inc(x_13); +x_18 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_18, 0, x_13); +x_19 = lean_box(x_2); lean_inc(x_1); -lean_inc(x_14); -x_19 = lean_apply_1(x_1, x_14); -x_20 = lean_box(x_3); -lean_inc(x_2); -lean_inc(x_7); -x_21 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed), 12, 9); -lean_closure_set(x_21, 0, x_5); -lean_closure_set(x_21, 1, x_7); -lean_closure_set(x_21, 2, x_14); -lean_closure_set(x_21, 3, x_1); -lean_closure_set(x_21, 4, x_2); -lean_closure_set(x_21, 5, x_20); -lean_closure_set(x_21, 6, x_4); -lean_closure_set(x_21, 7, x_6); -lean_closure_set(x_21, 8, x_13); -x_22 = l_EIO_Monad___closed__1; -x_23 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_23, 0, x_22); -lean_closure_set(x_23, 1, lean_box(0)); -lean_closure_set(x_23, 2, lean_box(0)); -lean_closure_set(x_23, 3, x_19); -lean_closure_set(x_23, 4, x_21); -x_24 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_2, x_7, x_8, x_23, x_10, x_11); -lean_dec(x_7); -return x_24; +lean_inc(x_6); +x_20 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed), 11, 8); +lean_closure_set(x_20, 0, x_4); +lean_closure_set(x_20, 1, x_6); +lean_closure_set(x_20, 2, x_13); +lean_closure_set(x_20, 3, x_1); +lean_closure_set(x_20, 4, x_19); +lean_closure_set(x_20, 5, x_3); +lean_closure_set(x_20, 6, x_5); +lean_closure_set(x_20, 7, x_12); +x_21 = l_EIO_Monad___closed__1; +x_22 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_22, 0, x_21); +lean_closure_set(x_22, 1, lean_box(0)); +lean_closure_set(x_22, 2, lean_box(0)); +lean_closure_set(x_22, 3, x_18); +lean_closure_set(x_22, 4, x_20); +x_23 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_6, x_7, x_22, x_9, x_10); +lean_dec(x_6); +return x_23; } } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_10, 0); -x_26 = lean_ctor_get(x_10, 2); -lean_inc(x_26); +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_9, 0); +x_25 = lean_ctor_get(x_9, 2); lean_inc(x_25); -lean_dec(x_10); -lean_inc(x_6); -x_27 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_6); -lean_ctor_set(x_27, 2, x_26); -if (x_3 == 0) +lean_inc(x_24); +lean_dec(x_9); +lean_inc(x_5); +x_26 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_5); +lean_ctor_set(x_26, 2, x_25); +if (x_2 == 0) { -lean_object* x_28; lean_object* x_29; -lean_dec(x_13); +lean_object* x_27; lean_object* x_28; +lean_dec(x_12); +lean_dec(x_5); +lean_dec(x_3); +lean_inc(x_6); +x_27 = lean_apply_2(x_4, x_6, x_13); +x_28 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_6, x_7, x_27, x_26, x_10); lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_1); -lean_inc(x_7); -x_28 = lean_apply_2(x_5, x_7, x_14); -x_29 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_2, x_7, x_8, x_28, x_27, x_11); -lean_dec(x_7); -return x_29; +return x_28; } else { -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +lean_inc(x_13); +x_29 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_29, 0, x_13); +x_30 = lean_box(x_2); lean_inc(x_1); -lean_inc(x_14); -x_30 = lean_apply_1(x_1, x_14); -x_31 = lean_box(x_3); -lean_inc(x_2); -lean_inc(x_7); -x_32 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed), 12, 9); -lean_closure_set(x_32, 0, x_5); -lean_closure_set(x_32, 1, x_7); -lean_closure_set(x_32, 2, x_14); -lean_closure_set(x_32, 3, x_1); -lean_closure_set(x_32, 4, x_2); -lean_closure_set(x_32, 5, x_31); -lean_closure_set(x_32, 6, x_4); -lean_closure_set(x_32, 7, x_6); -lean_closure_set(x_32, 8, x_13); -x_33 = l_EIO_Monad___closed__1; -x_34 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_34, 0, x_33); -lean_closure_set(x_34, 1, lean_box(0)); -lean_closure_set(x_34, 2, lean_box(0)); -lean_closure_set(x_34, 3, x_30); -lean_closure_set(x_34, 4, x_32); -x_35 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_2, x_7, x_8, x_34, x_27, x_11); -lean_dec(x_7); -return x_35; +lean_inc(x_6); +x_31 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed), 11, 8); +lean_closure_set(x_31, 0, x_4); +lean_closure_set(x_31, 1, x_6); +lean_closure_set(x_31, 2, x_13); +lean_closure_set(x_31, 3, x_1); +lean_closure_set(x_31, 4, x_30); +lean_closure_set(x_31, 5, x_3); +lean_closure_set(x_31, 6, x_5); +lean_closure_set(x_31, 7, x_12); +x_32 = l_EIO_Monad___closed__1; +x_33 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_33, 0, x_32); +lean_closure_set(x_33, 1, lean_box(0)); +lean_closure_set(x_33, 2, lean_box(0)); +lean_closure_set(x_33, 3, x_29); +lean_closure_set(x_33, 4, x_31); +x_34 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_1, x_6, x_7, x_33, x_26, x_10); +lean_dec(x_6); +return x_34; } } } @@ -4550,302 +5573,299 @@ lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux__ _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___boxed), 11, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___boxed), 10, 0); return x_2; } } -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { -_start: -{ -uint8_t x_13; lean_object* x_14; -x_13 = lean_unbox(x_6); -lean_dec(x_6); -x_14 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1(x_1, x_2, x_3, x_4, x_5, x_13, x_7, x_8, x_9, x_10, x_11, x_12); -return x_14; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { _start: { uint8_t x_12; lean_object* x_13; -x_12 = lean_unbox(x_3); -lean_dec(x_3); -x_13 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_2, x_12, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11); +x_12 = lean_unbox(x_5); +lean_dec(x_5); +x_13 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___lambda__1(x_1, x_2, x_3, x_4, x_12, x_6, x_7, x_8, x_9, x_10, x_11); return x_13; } } -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { _start: { -lean_object* x_12; -x_12 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11); +uint8_t x_11; lean_object* x_12; +x_11 = lean_unbox(x_2); +lean_dec(x_2); +x_12 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_11, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); return x_12; } } +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +lean_object* x_11; +x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +return x_11; +} +} lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg___boxed), 11, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg___boxed), 10, 0); return x_2; } } -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { _start: { -uint8_t x_12; lean_object* x_13; -x_12 = lean_unbox(x_3); -lean_dec(x_3); -x_13 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg(x_1, x_2, x_12, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11); -return x_13; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -lean_inc(x_1); -lean_inc(x_6); -lean_inc(x_3); -x_8 = lean_apply_3(x_1, x_3, x_6, x_7); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -x_10 = lean_ctor_get(x_8, 1); -lean_inc(x_10); -lean_dec(x_8); -x_11 = l_Lean_Expr_isForall(x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -lean_dec(x_9); -lean_dec(x_4); +uint8_t x_11; lean_object* x_12; +x_11 = lean_unbox(x_2); lean_dec(x_2); -lean_dec(x_1); -x_12 = l_Array_empty___closed__1; -x_13 = lean_apply_4(x_5, x_12, x_3, x_6, x_10); -return x_13; +x_12 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___rarg(x_1, x_11, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +return x_12; } -else +} +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: { -lean_object* x_14; lean_object* x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +lean_object* x_7; +lean_inc(x_5); +lean_inc(x_2); +x_7 = l_Lean_Meta_whnf(x_2, x_5, x_6); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +lean_dec(x_7); +x_10 = l_Lean_Expr_isForall(x_8); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +lean_dec(x_8); lean_dec(x_3); -x_14 = lean_ctor_get(x_10, 2); -lean_inc(x_14); -x_15 = lean_ctor_get(x_6, 1); -lean_inc(x_15); -x_16 = 1; -x_17 = l_Array_empty___closed__1; -x_18 = lean_unsigned_to_nat(0u); -x_19 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_2, x_16, x_4, x_5, x_15, x_17, x_18, x_9, x_6, x_10); -if (lean_obj_tag(x_19) == 0) -{ -uint8_t x_20; -x_20 = !lean_is_exclusive(x_19); -if (x_20 == 0) -{ -lean_object* x_21; uint8_t x_22; -x_21 = lean_ctor_get(x_19, 1); -x_22 = !lean_is_exclusive(x_21); -if (x_22 == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_21, 2); -lean_dec(x_23); -lean_ctor_set(x_21, 2, x_14); -return x_19; +lean_dec(x_1); +x_11 = l_Array_empty___closed__1; +x_12 = lean_apply_4(x_4, x_11, x_2, x_5, x_9); +return x_12; } else { -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_24 = lean_ctor_get(x_21, 0); -x_25 = lean_ctor_get(x_21, 1); -x_26 = lean_ctor_get(x_21, 3); -x_27 = lean_ctor_get(x_21, 4); -x_28 = lean_ctor_get(x_21, 5); -lean_inc(x_28); +lean_object* x_13; lean_object* x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +lean_dec(x_2); +x_13 = lean_ctor_get(x_9, 2); +lean_inc(x_13); +x_14 = lean_ctor_get(x_5, 1); +lean_inc(x_14); +x_15 = 1; +x_16 = l_Array_empty___closed__1; +x_17 = lean_unsigned_to_nat(0u); +x_18 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_15, x_3, x_4, x_14, x_16, x_17, x_8, x_5, x_9); +if (lean_obj_tag(x_18) == 0) +{ +uint8_t x_19; +x_19 = !lean_is_exclusive(x_18); +if (x_19 == 0) +{ +lean_object* x_20; uint8_t x_21; +x_20 = lean_ctor_get(x_18, 1); +x_21 = !lean_is_exclusive(x_20); +if (x_21 == 0) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_20, 2); +lean_dec(x_22); +lean_ctor_set(x_20, 2, x_13); +return x_18; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_23 = lean_ctor_get(x_20, 0); +x_24 = lean_ctor_get(x_20, 1); +x_25 = lean_ctor_get(x_20, 3); +x_26 = lean_ctor_get(x_20, 4); +x_27 = lean_ctor_get(x_20, 5); lean_inc(x_27); lean_inc(x_26); lean_inc(x_25); lean_inc(x_24); -lean_dec(x_21); -x_29 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_29, 0, x_24); -lean_ctor_set(x_29, 1, x_25); -lean_ctor_set(x_29, 2, x_14); -lean_ctor_set(x_29, 3, x_26); -lean_ctor_set(x_29, 4, x_27); -lean_ctor_set(x_29, 5, x_28); -lean_ctor_set(x_19, 1, x_29); -return x_19; +lean_inc(x_23); +lean_dec(x_20); +x_28 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_28, 0, x_23); +lean_ctor_set(x_28, 1, x_24); +lean_ctor_set(x_28, 2, x_13); +lean_ctor_set(x_28, 3, x_25); +lean_ctor_set(x_28, 4, x_26); +lean_ctor_set(x_28, 5, x_27); +lean_ctor_set(x_18, 1, x_28); +return x_18; } } else { -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_30 = lean_ctor_get(x_19, 1); -x_31 = lean_ctor_get(x_19, 0); +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_29 = lean_ctor_get(x_18, 1); +x_30 = lean_ctor_get(x_18, 0); +lean_inc(x_29); lean_inc(x_30); +lean_dec(x_18); +x_31 = lean_ctor_get(x_29, 0); lean_inc(x_31); -lean_dec(x_19); -x_32 = lean_ctor_get(x_30, 0); +x_32 = lean_ctor_get(x_29, 1); lean_inc(x_32); -x_33 = lean_ctor_get(x_30, 1); +x_33 = lean_ctor_get(x_29, 3); lean_inc(x_33); -x_34 = lean_ctor_get(x_30, 3); +x_34 = lean_ctor_get(x_29, 4); lean_inc(x_34); -x_35 = lean_ctor_get(x_30, 4); +x_35 = lean_ctor_get(x_29, 5); lean_inc(x_35); -x_36 = lean_ctor_get(x_30, 5); -lean_inc(x_36); -if (lean_is_exclusive(x_30)) { - lean_ctor_release(x_30, 0); - lean_ctor_release(x_30, 1); - lean_ctor_release(x_30, 2); - lean_ctor_release(x_30, 3); - lean_ctor_release(x_30, 4); - lean_ctor_release(x_30, 5); - x_37 = x_30; +if (lean_is_exclusive(x_29)) { + lean_ctor_release(x_29, 0); + lean_ctor_release(x_29, 1); + lean_ctor_release(x_29, 2); + lean_ctor_release(x_29, 3); + lean_ctor_release(x_29, 4); + lean_ctor_release(x_29, 5); + x_36 = x_29; } else { - lean_dec_ref(x_30); - x_37 = lean_box(0); + lean_dec_ref(x_29); + x_36 = lean_box(0); } -if (lean_is_scalar(x_37)) { - x_38 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_36)) { + x_37 = lean_alloc_ctor(0, 6, 0); } else { - x_38 = x_37; + x_37 = x_36; } -lean_ctor_set(x_38, 0, x_32); -lean_ctor_set(x_38, 1, x_33); -lean_ctor_set(x_38, 2, x_14); -lean_ctor_set(x_38, 3, x_34); -lean_ctor_set(x_38, 4, x_35); -lean_ctor_set(x_38, 5, x_36); -x_39 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_39, 0, x_31); -lean_ctor_set(x_39, 1, x_38); -return x_39; +lean_ctor_set(x_37, 0, x_31); +lean_ctor_set(x_37, 1, x_32); +lean_ctor_set(x_37, 2, x_13); +lean_ctor_set(x_37, 3, x_33); +lean_ctor_set(x_37, 4, x_34); +lean_ctor_set(x_37, 5, x_35); +x_38 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_38, 0, x_30); +lean_ctor_set(x_38, 1, x_37); +return x_38; } } else { -uint8_t x_40; -x_40 = !lean_is_exclusive(x_19); -if (x_40 == 0) +uint8_t x_39; +x_39 = !lean_is_exclusive(x_18); +if (x_39 == 0) { -lean_object* x_41; uint8_t x_42; -x_41 = lean_ctor_get(x_19, 1); -x_42 = !lean_is_exclusive(x_41); -if (x_42 == 0) +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_18, 1); +x_41 = !lean_is_exclusive(x_40); +if (x_41 == 0) { -lean_object* x_43; -x_43 = lean_ctor_get(x_41, 2); -lean_dec(x_43); -lean_ctor_set(x_41, 2, x_14); -return x_19; +lean_object* x_42; +x_42 = lean_ctor_get(x_40, 2); +lean_dec(x_42); +lean_ctor_set(x_40, 2, x_13); +return x_18; } else { -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_44 = lean_ctor_get(x_41, 0); -x_45 = lean_ctor_get(x_41, 1); -x_46 = lean_ctor_get(x_41, 3); -x_47 = lean_ctor_get(x_41, 4); -x_48 = lean_ctor_get(x_41, 5); -lean_inc(x_48); +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_40, 0); +x_44 = lean_ctor_get(x_40, 1); +x_45 = lean_ctor_get(x_40, 3); +x_46 = lean_ctor_get(x_40, 4); +x_47 = lean_ctor_get(x_40, 5); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); lean_inc(x_44); -lean_dec(x_41); -x_49 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_49, 0, x_44); -lean_ctor_set(x_49, 1, x_45); -lean_ctor_set(x_49, 2, x_14); -lean_ctor_set(x_49, 3, x_46); -lean_ctor_set(x_49, 4, x_47); -lean_ctor_set(x_49, 5, x_48); -lean_ctor_set(x_19, 1, x_49); -return x_19; +lean_inc(x_43); +lean_dec(x_40); +x_48 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_44); +lean_ctor_set(x_48, 2, x_13); +lean_ctor_set(x_48, 3, x_45); +lean_ctor_set(x_48, 4, x_46); +lean_ctor_set(x_48, 5, x_47); +lean_ctor_set(x_18, 1, x_48); +return x_18; } } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_50 = lean_ctor_get(x_19, 1); -x_51 = lean_ctor_get(x_19, 0); +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_49 = lean_ctor_get(x_18, 1); +x_50 = lean_ctor_get(x_18, 0); +lean_inc(x_49); lean_inc(x_50); +lean_dec(x_18); +x_51 = lean_ctor_get(x_49, 0); lean_inc(x_51); -lean_dec(x_19); -x_52 = lean_ctor_get(x_50, 0); +x_52 = lean_ctor_get(x_49, 1); lean_inc(x_52); -x_53 = lean_ctor_get(x_50, 1); +x_53 = lean_ctor_get(x_49, 3); lean_inc(x_53); -x_54 = lean_ctor_get(x_50, 3); +x_54 = lean_ctor_get(x_49, 4); lean_inc(x_54); -x_55 = lean_ctor_get(x_50, 4); +x_55 = lean_ctor_get(x_49, 5); lean_inc(x_55); -x_56 = lean_ctor_get(x_50, 5); -lean_inc(x_56); -if (lean_is_exclusive(x_50)) { - lean_ctor_release(x_50, 0); - lean_ctor_release(x_50, 1); - lean_ctor_release(x_50, 2); - lean_ctor_release(x_50, 3); - lean_ctor_release(x_50, 4); - lean_ctor_release(x_50, 5); - x_57 = x_50; +if (lean_is_exclusive(x_49)) { + lean_ctor_release(x_49, 0); + lean_ctor_release(x_49, 1); + lean_ctor_release(x_49, 2); + lean_ctor_release(x_49, 3); + lean_ctor_release(x_49, 4); + lean_ctor_release(x_49, 5); + x_56 = x_49; } else { - lean_dec_ref(x_50); - x_57 = lean_box(0); + lean_dec_ref(x_49); + x_56 = lean_box(0); } -if (lean_is_scalar(x_57)) { - x_58 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(0, 6, 0); } else { - x_58 = x_57; + x_57 = x_56; } -lean_ctor_set(x_58, 0, x_52); -lean_ctor_set(x_58, 1, x_53); -lean_ctor_set(x_58, 2, x_14); -lean_ctor_set(x_58, 3, x_54); -lean_ctor_set(x_58, 4, x_55); -lean_ctor_set(x_58, 5, x_56); -x_59 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_59, 0, x_51); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_57, 0, x_51); +lean_ctor_set(x_57, 1, x_52); +lean_ctor_set(x_57, 2, x_13); +lean_ctor_set(x_57, 3, x_53); +lean_ctor_set(x_57, 4, x_54); +lean_ctor_set(x_57, 5, x_55); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_50); +lean_ctor_set(x_58, 1, x_57); +return x_58; } } } } else { -uint8_t x_60; -lean_dec(x_6); +uint8_t x_59; lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_60 = !lean_is_exclusive(x_8); -if (x_60 == 0) +x_59 = !lean_is_exclusive(x_7); +if (x_59 == 0) { -return x_8; +return x_7; } else { -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_8, 0); -x_62 = lean_ctor_get(x_8, 1); -lean_inc(x_62); +lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_60 = lean_ctor_get(x_7, 0); +x_61 = lean_ctor_get(x_7, 1); lean_inc(x_61); -lean_dec(x_8); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_61); -lean_ctor_set(x_63, 1, x_62); -return x_63; +lean_inc(x_60); +lean_dec(x_7); +x_62 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_62, 0, x_60); +lean_ctor_set(x_62, 1, x_61); +return x_62; } } } @@ -4854,469 +5874,318 @@ lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux(lean _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg), 7, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg), 6, 0); return x_2; } } -lean_object* l_Lean_Meta_isClassExpensive___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_6; -x_6 = l_Lean_Expr_getAppFn___main(x_3); -if (lean_obj_tag(x_6) == 4) -{ -lean_object* x_7; lean_object* x_8; uint8_t x_9; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_2); +x_7 = lean_nat_dec_lt(x_3, x_6); lean_dec(x_6); -x_8 = lean_ctor_get(x_5, 0); -lean_inc(x_8); -lean_inc(x_7); -x_9 = lean_is_class(x_8, x_7); -if (x_9 == 0) +if (x_7 == 0) { -lean_object* x_10; -lean_dec(x_7); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_1); -lean_ctor_set(x_10, 1, x_5); -return x_10; -} -else +lean_object* x_8; +lean_dec(x_4); +lean_dec(x_3); +x_8 = l_Lean_Expr_getAppFn___main(x_1); +if (lean_obj_tag(x_8) == 4) { -lean_object* x_11; lean_object* x_12; -lean_dec(x_1); -x_11 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_11, 0, x_7); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_5); -return x_12; -} -} -else +lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +lean_dec(x_8); +x_10 = lean_ctor_get(x_5, 0); +lean_inc(x_10); +lean_inc(x_9); +x_11 = lean_is_class(x_10, x_9); +if (x_11 == 0) { -lean_object* x_13; -lean_dec(x_6); +lean_object* x_12; lean_object* x_13; +lean_dec(x_9); +x_12 = lean_box(0); x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_1); +lean_ctor_set(x_13, 0, x_12); lean_ctor_set(x_13, 1, x_5); return x_13; } -} -} -lean_object* _init_l_Lean_Meta_isClassExpensive___main___closed__1() { -_start: +else { -lean_object* x_1; lean_object* x_2; -x_1 = lean_box(0); -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive___main___lambda__1___boxed), 5, 1); -lean_closure_set(x_2, 0, x_1); -return x_2; +lean_object* x_14; lean_object* x_15; +x_14 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_14, 0, x_9); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_5); +return x_15; } } -lean_object* l_Lean_Meta_isClassExpensive___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; uint8_t x_7; -lean_inc(x_1); -x_5 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive___main), 4, 1); -lean_closure_set(x_5, 0, x_1); -x_6 = lean_box(0); -x_7 = !lean_is_exclusive(x_3); -if (x_7 == 0) -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_ctor_get(x_3, 0); -x_9 = !lean_is_exclusive(x_8); -if (x_9 == 0) -{ -uint8_t x_10; lean_object* x_11; lean_object* x_12; -x_10 = 2; -lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 4, x_10); -x_11 = l_Lean_Meta_isClassExpensive___main___closed__1; -x_12 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(x_1, x_5, x_2, x_6, x_11, x_3, x_4); -return x_12; -} else { -lean_object* x_13; uint8_t x_14; uint8_t x_15; uint8_t x_16; uint8_t x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_13 = lean_ctor_get(x_8, 0); -x_14 = lean_ctor_get_uint8(x_8, sizeof(void*)*1); -x_15 = lean_ctor_get_uint8(x_8, sizeof(void*)*1 + 1); -x_16 = lean_ctor_get_uint8(x_8, sizeof(void*)*1 + 2); -x_17 = lean_ctor_get_uint8(x_8, sizeof(void*)*1 + 3); -lean_inc(x_13); +lean_object* x_16; lean_object* x_17; lean_dec(x_8); -x_18 = 2; -x_19 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_19, 0, x_13); -lean_ctor_set_uint8(x_19, sizeof(void*)*1, x_14); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 1, x_15); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 2, x_16); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 3, x_17); -lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 4, x_18); -lean_ctor_set(x_3, 0, x_19); -x_20 = l_Lean_Meta_isClassExpensive___main___closed__1; -x_21 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(x_1, x_5, x_2, x_6, x_20, x_3, x_4); -return x_21; +x_16 = lean_box(0); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_16); +lean_ctor_set(x_17, 1, x_5); +return x_17; } } else { -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; uint8_t x_27; uint8_t x_28; uint8_t x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_22 = lean_ctor_get(x_3, 0); -x_23 = lean_ctor_get(x_3, 1); -x_24 = lean_ctor_get(x_3, 2); -lean_inc(x_24); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_3); -x_25 = lean_ctor_get(x_22, 0); -lean_inc(x_25); -x_26 = lean_ctor_get_uint8(x_22, sizeof(void*)*1); -x_27 = lean_ctor_get_uint8(x_22, sizeof(void*)*1 + 1); -x_28 = lean_ctor_get_uint8(x_22, sizeof(void*)*1 + 2); -x_29 = lean_ctor_get_uint8(x_22, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_22)) { - lean_ctor_release(x_22, 0); - x_30 = x_22; -} else { - lean_dec_ref(x_22); - x_30 = lean_box(0); -} -x_31 = 2; -if (lean_is_scalar(x_30)) { - x_32 = lean_alloc_ctor(0, 1, 5); -} else { - x_32 = x_30; -} -lean_ctor_set(x_32, 0, x_25); -lean_ctor_set_uint8(x_32, sizeof(void*)*1, x_26); -lean_ctor_set_uint8(x_32, sizeof(void*)*1 + 1, x_27); -lean_ctor_set_uint8(x_32, sizeof(void*)*1 + 2, x_28); -lean_ctor_set_uint8(x_32, sizeof(void*)*1 + 3, x_29); -lean_ctor_set_uint8(x_32, sizeof(void*)*1 + 4, x_31); -x_33 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_33, 0, x_32); -lean_ctor_set(x_33, 1, x_23); -lean_ctor_set(x_33, 2, x_24); -x_34 = l_Lean_Meta_isClassExpensive___main___closed__1; -x_35 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(x_1, x_5, x_2, x_6, x_34, x_33, x_4); -return x_35; -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___main___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: +lean_object* x_18; lean_object* x_19; +x_18 = lean_array_fget(x_2, x_3); +lean_inc(x_4); +x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); +if (lean_obj_tag(x_19) == 0) { -lean_object* x_6; -x_6 = l_Lean_Meta_isClassExpensive___main___lambda__1(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -return x_6; -} -} -lean_object* l_Lean_Meta_isClassExpensive(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Meta_isClassExpensive___main(x_1, x_2, x_3, x_4); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; -x_10 = lean_array_get_size(x_3); -lean_inc(x_3); -x_11 = lean_expr_instantiate_rev_range(x_5, x_4, x_10, x_3); -lean_dec(x_10); -x_12 = lean_array_get_size(x_6); -x_13 = lean_nat_dec_lt(x_7, x_12); -lean_dec(x_12); -if (x_13 == 0) -{ -lean_object* x_14; -lean_dec(x_7); -lean_dec(x_1); -x_14 = lean_apply_4(x_2, x_3, x_11, x_8, x_9); -return x_14; -} -else -{ -lean_object* x_15; lean_object* x_16; -lean_dec(x_11); -x_15 = lean_array_fget(x_6, x_7); -lean_inc(x_8); -x_16 = l_Lean_Meta_getFVarLocalDecl(x_15, x_8, x_9); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -x_19 = l_Lean_LocalDecl_type(x_17); -lean_dec(x_17); -lean_inc(x_8); -lean_inc(x_19); -x_20 = l_Lean_Meta_isClassQuick___main(x_19, x_8, x_18); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; -x_21 = lean_ctor_get(x_20, 0); +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_19, 1); lean_inc(x_21); -switch (lean_obj_tag(x_21)) { +lean_dec(x_19); +x_22 = l_Lean_LocalDecl_type(x_20); +lean_dec(x_20); +lean_inc(x_4); +lean_inc(x_22); +x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); +if (lean_obj_tag(x_23) == 0) +{ +lean_object* x_24; +x_24 = lean_ctor_get(x_23, 0); +lean_inc(x_24); +switch (lean_obj_tag(x_24)) { case 0: { -lean_object* x_22; lean_object* x_23; lean_object* x_24; -lean_dec(x_19); -lean_dec(x_15); -x_22 = lean_ctor_get(x_20, 1); -lean_inc(x_22); -lean_dec(x_20); -x_23 = lean_unsigned_to_nat(1u); -x_24 = lean_nat_add(x_7, x_23); -lean_dec(x_7); -x_7 = x_24; -x_9 = x_22; +lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_dec(x_22); +lean_dec(x_18); +x_25 = lean_ctor_get(x_23, 1); +lean_inc(x_25); +lean_dec(x_23); +x_26 = lean_unsigned_to_nat(1u); +x_27 = lean_nat_add(x_3, x_26); +lean_dec(x_3); +x_3 = x_27; +x_5 = x_25; goto _start; } case 1: { -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; -lean_dec(x_19); -x_26 = lean_ctor_get(x_20, 1); -lean_inc(x_26); -lean_dec(x_20); -x_27 = lean_ctor_get(x_21, 0); -lean_inc(x_27); -lean_dec(x_21); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_7, x_28); -lean_dec(x_7); -x_30 = !lean_is_exclusive(x_8); -if (x_30 == 0) +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; +lean_dec(x_22); +x_29 = lean_ctor_get(x_23, 1); +lean_inc(x_29); +lean_dec(x_23); +x_30 = lean_ctor_get(x_24, 0); +lean_inc(x_30); +lean_dec(x_24); +x_31 = lean_unsigned_to_nat(1u); +x_32 = lean_nat_add(x_3, x_31); +lean_dec(x_3); +x_33 = !lean_is_exclusive(x_4); +if (x_33 == 0) { -lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_31 = lean_ctor_get(x_8, 2); -x_32 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_32, 0, x_27); -lean_ctor_set(x_32, 1, x_15); -x_33 = lean_array_push(x_31, x_32); -lean_ctor_set(x_8, 2, x_33); -x_7 = x_29; -x_9 = x_26; +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = lean_ctor_get(x_4, 2); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_30); +lean_ctor_set(x_35, 1, x_18); +x_36 = lean_array_push(x_34, x_35); +lean_ctor_set(x_4, 2, x_36); +x_3 = x_32; +x_5 = x_29; goto _start; } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_35 = lean_ctor_get(x_8, 0); -x_36 = lean_ctor_get(x_8, 1); -x_37 = lean_ctor_get(x_8, 2); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_dec(x_8); -x_38 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_38, 0, x_27); -lean_ctor_set(x_38, 1, x_15); -x_39 = lean_array_push(x_37, x_38); -x_40 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_36); -lean_ctor_set(x_40, 2, x_39); -x_7 = x_29; -x_8 = x_40; -x_9 = x_26; +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_38 = lean_ctor_get(x_4, 0); +x_39 = lean_ctor_get(x_4, 1); +x_40 = lean_ctor_get(x_4, 2); +lean_inc(x_40); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_4); +x_41 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_41, 0, x_30); +lean_ctor_set(x_41, 1, x_18); +x_42 = lean_array_push(x_40, x_41); +x_43 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_43, 0, x_38); +lean_ctor_set(x_43, 1, x_39); +lean_ctor_set(x_43, 2, x_42); +x_3 = x_32; +x_4 = x_43; +x_5 = x_29; goto _start; } } default: { -lean_object* x_42; lean_object* x_43; -x_42 = lean_ctor_get(x_20, 1); -lean_inc(x_42); -lean_dec(x_20); -lean_inc(x_8); -lean_inc(x_1); -x_43 = l_Lean_Meta_isClassExpensive___main(x_1, x_19, x_8, x_42); -if (lean_obj_tag(x_43) == 0) -{ -lean_object* x_44; -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -if (lean_obj_tag(x_44) == 0) -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -lean_dec(x_15); -x_45 = lean_ctor_get(x_43, 1); +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_23, 1); lean_inc(x_45); -lean_dec(x_43); -x_46 = lean_unsigned_to_nat(1u); -x_47 = lean_nat_add(x_7, x_46); -lean_dec(x_7); -x_7 = x_47; -x_9 = x_45; -goto _start; -} -else +lean_dec(x_23); +lean_inc(x_4); +x_46 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_45); +if (lean_obj_tag(x_46) == 0) { -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; uint8_t x_53; -x_49 = lean_ctor_get(x_43, 1); -lean_inc(x_49); -lean_dec(x_43); -x_50 = lean_ctor_get(x_44, 0); -lean_inc(x_50); -lean_dec(x_44); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_7, x_51); -lean_dec(x_7); -x_53 = !lean_is_exclusive(x_8); -if (x_53 == 0) +lean_object* x_47; +x_47 = lean_ctor_get(x_46, 0); +lean_inc(x_47); +if (lean_obj_tag(x_47) == 0) { -lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_8, 2); -x_55 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_55, 0, x_50); -lean_ctor_set(x_55, 1, x_15); -x_56 = lean_array_push(x_54, x_55); -lean_ctor_set(x_8, 2, x_56); -x_7 = x_52; -x_9 = x_49; -goto _start; -} -else -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_58 = lean_ctor_get(x_8, 0); -x_59 = lean_ctor_get(x_8, 1); -x_60 = lean_ctor_get(x_8, 2); -lean_inc(x_60); -lean_inc(x_59); -lean_inc(x_58); -lean_dec(x_8); -x_61 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_61, 0, x_50); -lean_ctor_set(x_61, 1, x_15); -x_62 = lean_array_push(x_60, x_61); -x_63 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_63, 0, x_58); -lean_ctor_set(x_63, 1, x_59); -lean_ctor_set(x_63, 2, x_62); -x_7 = x_52; -x_8 = x_63; -x_9 = x_49; -goto _start; -} -} -} -else -{ -uint8_t x_65; -lean_dec(x_15); -lean_dec(x_8); -lean_dec(x_7); +lean_object* x_48; lean_object* x_49; lean_object* x_50; +lean_dec(x_18); +x_48 = lean_ctor_get(x_46, 1); +lean_inc(x_48); +lean_dec(x_46); +x_49 = lean_unsigned_to_nat(1u); +x_50 = lean_nat_add(x_3, x_49); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_65 = !lean_is_exclusive(x_43); -if (x_65 == 0) -{ -return x_43; +x_3 = x_50; +x_5 = x_48; +goto _start; } else { -lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_66 = lean_ctor_get(x_43, 0); -x_67 = lean_ctor_get(x_43, 1); -lean_inc(x_67); -lean_inc(x_66); -lean_dec(x_43); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_66); -lean_ctor_set(x_68, 1, x_67); -return x_68; -} -} -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_19); -lean_dec(x_15); -lean_dec(x_8); -lean_dec(x_7); +lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; +x_52 = lean_ctor_get(x_46, 1); +lean_inc(x_52); +lean_dec(x_46); +x_53 = lean_ctor_get(x_47, 0); +lean_inc(x_53); +lean_dec(x_47); +x_54 = lean_unsigned_to_nat(1u); +x_55 = lean_nat_add(x_3, x_54); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_69 = !lean_is_exclusive(x_20); -if (x_69 == 0) +x_56 = !lean_is_exclusive(x_4); +if (x_56 == 0) { -return x_20; +lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_57 = lean_ctor_get(x_4, 2); +x_58 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_58, 0, x_53); +lean_ctor_set(x_58, 1, x_18); +x_59 = lean_array_push(x_57, x_58); +lean_ctor_set(x_4, 2, x_59); +x_3 = x_55; +x_5 = x_52; +goto _start; } else { -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_20, 0); -x_71 = lean_ctor_get(x_20, 1); -lean_inc(x_71); +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_61 = lean_ctor_get(x_4, 0); +x_62 = lean_ctor_get(x_4, 1); +x_63 = lean_ctor_get(x_4, 2); +lean_inc(x_63); +lean_inc(x_62); +lean_inc(x_61); +lean_dec(x_4); +x_64 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_64, 0, x_53); +lean_ctor_set(x_64, 1, x_18); +x_65 = lean_array_push(x_63, x_64); +x_66 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_66, 0, x_61); +lean_ctor_set(x_66, 1, x_62); +lean_ctor_set(x_66, 2, x_65); +x_3 = x_55; +x_4 = x_66; +x_5 = x_52; +goto _start; +} +} +} +else +{ +uint8_t x_68; +lean_dec(x_18); +lean_dec(x_4); +lean_dec(x_3); +x_68 = !lean_is_exclusive(x_46); +if (x_68 == 0) +{ +return x_46; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_46, 0); +x_70 = lean_ctor_get(x_46, 1); lean_inc(x_70); -lean_dec(x_20); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; +lean_inc(x_69); +lean_dec(x_46); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} } } } else { -uint8_t x_73; -lean_dec(x_15); -lean_dec(x_8); -lean_dec(x_7); +uint8_t x_72; +lean_dec(x_22); +lean_dec(x_18); +lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_73 = !lean_is_exclusive(x_16); -if (x_73 == 0) +x_72 = !lean_is_exclusive(x_23); +if (x_72 == 0) { -return x_16; +return x_23; } else { -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_16, 0); -x_75 = lean_ctor_get(x_16, 1); -lean_inc(x_75); +lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_73 = lean_ctor_get(x_23, 0); +x_74 = lean_ctor_get(x_23, 1); lean_inc(x_74); -lean_dec(x_16); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; +lean_inc(x_73); +lean_dec(x_23); +x_75 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +return x_75; } } } -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2(lean_object* x_1) { -_start: +else { -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg___boxed), 9, 0); -return x_2; +uint8_t x_76; +lean_dec(x_18); +lean_dec(x_4); +lean_dec(x_3); +x_76 = !lean_is_exclusive(x_19); +if (x_76 == 0) +{ +return x_19; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_19, 0); +x_78 = lean_ctor_get(x_19, 1); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_19); +x_79 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_79, 0, x_77); +lean_ctor_set(x_79, 1, x_78); +return x_79; } } -lean_object* l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +} +} +} +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; @@ -5359,397 +6228,444 @@ return x_12; } } } -lean_object* l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3(lean_object* x_1, lean_object* x_2) { +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; -x_3 = lean_alloc_closure((void*)(l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg), 4, 0); +x_3 = lean_alloc_closure((void*)(l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg), 4, 0); return x_3; } } -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___lambda__1(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { -uint8_t x_12; -x_12 = l_Lean_Expr_isForall(x_9); -if (x_12 == 0) +uint8_t x_10; +x_10 = l_Lean_Expr_isForall(x_7); +if (x_10 == 0) { -lean_object* x_13; -lean_dec(x_9); +lean_object* x_11; lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); -lean_dec(x_4); -x_13 = lean_apply_4(x_1, x_2, x_3, x_10, x_11); -return x_13; -} -else -{ -lean_object* x_14; -lean_dec(x_3); -x_14 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(x_4, x_1, x_5, x_6, x_7, x_2, x_8, x_9, x_10, x_11); -return x_14; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13, lean_object* x_14) { -_start: -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; -lean_inc(x_1); -lean_inc(x_10); -x_15 = lean_apply_1(x_1, x_10); -x_16 = lean_box(x_3); -lean_inc(x_9); -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_1); -lean_inc(x_10); -lean_inc(x_6); -lean_inc(x_2); -x_17 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___lambda__1___boxed), 11, 8); -lean_closure_set(x_17, 0, x_2); -lean_closure_set(x_17, 1, x_6); -lean_closure_set(x_17, 2, x_10); -lean_closure_set(x_17, 3, x_1); -lean_closure_set(x_17, 4, x_16); -lean_closure_set(x_17, 5, x_4); -lean_closure_set(x_17, 6, x_5); -lean_closure_set(x_17, 7, x_9); -x_18 = lean_array_get_size(x_11); -x_19 = lean_nat_dec_lt(x_12, x_18); -lean_dec(x_18); -if (x_19 == 0) -{ -lean_object* x_20; -lean_dec(x_12); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_20 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_15, x_17, x_13, x_14); -return x_20; +lean_dec(x_3); +x_11 = l_Lean_Expr_getAppFn___main(x_1); +if (lean_obj_tag(x_11) == 4) +{ +lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +lean_dec(x_11); +x_13 = lean_ctor_get(x_9, 0); +lean_inc(x_13); +lean_inc(x_12); +x_14 = lean_is_class(x_13, x_12); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; +lean_dec(x_12); +x_15 = lean_box(0); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_9); +return x_16; } else { -lean_object* x_21; lean_object* x_22; -lean_dec(x_17); +lean_object* x_17; lean_object* x_18; +x_17 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_17, 0, x_12); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_17); +lean_ctor_set(x_18, 1, x_9); +return x_18; +} +} +else +{ +lean_object* x_19; lean_object* x_20; +lean_dec(x_11); +x_19 = lean_box(0); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_9); +return x_20; +} +} +else +{ +lean_object* x_21; +x_21 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2(x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +return x_21; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; +lean_inc(x_8); +x_13 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_13, 0, x_8); +x_14 = lean_box(x_1); +lean_inc(x_7); +lean_inc(x_4); +lean_inc(x_3); +lean_inc(x_2); +lean_inc(x_8); +x_15 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___lambda__1___boxed), 9, 6); +lean_closure_set(x_15, 0, x_8); +lean_closure_set(x_15, 1, x_14); +lean_closure_set(x_15, 2, x_2); +lean_closure_set(x_15, 3, x_3); +lean_closure_set(x_15, 4, x_4); +lean_closure_set(x_15, 5, x_7); +x_16 = lean_array_get_size(x_9); +x_17 = lean_nat_dec_lt(x_10, x_16); +lean_dec(x_16); +if (x_17 == 0) +{ +lean_object* x_18; +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_18 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_13, x_15, x_11, x_12); +return x_18; +} +else +{ +lean_object* x_19; lean_object* x_20; lean_dec(x_15); -x_21 = lean_array_fget(x_11, x_12); -lean_inc(x_13); -x_22 = l_Lean_Meta_getFVarLocalDecl(x_21, x_13, x_14); -if (lean_obj_tag(x_22) == 0) +lean_dec(x_13); +x_19 = lean_array_fget(x_9, x_10); +lean_inc(x_11); +x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_11, x_12); +if (lean_obj_tag(x_20) == 0) { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_23 = lean_ctor_get(x_22, 0); +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = l_Lean_LocalDecl_type(x_21); +lean_dec(x_21); +lean_inc(x_11); lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = l_Lean_LocalDecl_type(x_23); -lean_dec(x_23); -lean_inc(x_13); -lean_inc(x_25); -x_26 = l_Lean_Meta_isClassQuick___main(x_25, x_13, x_24); -if (lean_obj_tag(x_26) == 0) +x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_11, x_22); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_27; -x_27 = lean_ctor_get(x_26, 0); -lean_inc(x_27); -switch (lean_obj_tag(x_27)) { +lean_object* x_25; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +switch (lean_obj_tag(x_25)) { case 0: { -lean_object* x_28; lean_object* x_29; lean_object* x_30; -lean_dec(x_25); -lean_dec(x_21); -x_28 = lean_ctor_get(x_26, 1); -lean_inc(x_28); -lean_dec(x_26); -x_29 = lean_unsigned_to_nat(1u); -x_30 = lean_nat_add(x_12, x_29); -lean_dec(x_12); -x_12 = x_30; -x_14 = x_28; +lean_object* x_26; lean_object* x_27; lean_object* x_28; +lean_dec(x_23); +lean_dec(x_19); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_10, x_27); +lean_dec(x_10); +x_10 = x_28; +x_12 = x_26; goto _start; } case 1: { -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_dec(x_23); +x_30 = lean_ctor_get(x_24, 1); +lean_inc(x_30); +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 0); +lean_inc(x_31); lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 1); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_ctor_get(x_27, 0); -lean_inc(x_33); -lean_dec(x_27); -x_34 = lean_unsigned_to_nat(1u); -x_35 = lean_nat_add(x_12, x_34); -lean_dec(x_12); -x_36 = !lean_is_exclusive(x_13); -if (x_36 == 0) +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_10, x_32); +lean_dec(x_10); +x_34 = !lean_is_exclusive(x_11); +if (x_34 == 0) { -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_13, 2); -x_38 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_21); -x_39 = lean_array_push(x_37, x_38); -lean_ctor_set(x_13, 2, x_39); -x_12 = x_35; -x_14 = x_32; +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_11, 2); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_31); +lean_ctor_set(x_36, 1, x_19); +x_37 = lean_array_push(x_35, x_36); +lean_ctor_set(x_11, 2, x_37); +x_10 = x_33; +x_12 = x_30; goto _start; } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_41 = lean_ctor_get(x_13, 0); -x_42 = lean_ctor_get(x_13, 1); -x_43 = lean_ctor_get(x_13, 2); -lean_inc(x_43); -lean_inc(x_42); +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_39 = lean_ctor_get(x_11, 0); +x_40 = lean_ctor_get(x_11, 1); +x_41 = lean_ctor_get(x_11, 2); lean_inc(x_41); -lean_dec(x_13); -x_44 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_44, 0, x_33); -lean_ctor_set(x_44, 1, x_21); -x_45 = lean_array_push(x_43, x_44); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_41); -lean_ctor_set(x_46, 1, x_42); -lean_ctor_set(x_46, 2, x_45); -x_12 = x_35; -x_13 = x_46; -x_14 = x_32; +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_11); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_31); +lean_ctor_set(x_42, 1, x_19); +x_43 = lean_array_push(x_41, x_42); +x_44 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_40); +lean_ctor_set(x_44, 2, x_43); +x_10 = x_33; +x_11 = x_44; +x_12 = x_30; goto _start; } } default: { -lean_object* x_48; lean_object* x_49; -x_48 = lean_ctor_get(x_26, 1); +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_24, 1); +lean_inc(x_46); +lean_dec(x_24); +lean_inc(x_11); +x_47 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_46); +if (lean_obj_tag(x_47) == 0) +{ +lean_object* x_48; +x_48 = lean_ctor_get(x_47, 0); lean_inc(x_48); -lean_dec(x_26); -lean_inc(x_13); -lean_inc(x_1); -x_49 = l_Lean_Meta_isClassExpensive___main(x_1, x_25, x_13, x_48); -if (lean_obj_tag(x_49) == 0) +if (lean_obj_tag(x_48) == 0) { -lean_object* x_50; -x_50 = lean_ctor_get(x_49, 0); -lean_inc(x_50); -if (lean_obj_tag(x_50) == 0) +lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_19); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +lean_dec(x_47); +x_50 = lean_unsigned_to_nat(1u); +x_51 = lean_nat_add(x_10, x_50); +lean_dec(x_10); +x_10 = x_51; +x_12 = x_49; +goto _start; +} +else { -lean_object* x_51; lean_object* x_52; lean_object* x_53; -lean_dec(x_21); -x_51 = lean_ctor_get(x_49, 1); -lean_inc(x_51); -lean_dec(x_49); -x_52 = lean_unsigned_to_nat(1u); -x_53 = lean_nat_add(x_12, x_52); -lean_dec(x_12); +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; +x_53 = lean_ctor_get(x_47, 1); +lean_inc(x_53); +lean_dec(x_47); +x_54 = lean_ctor_get(x_48, 0); +lean_inc(x_54); +lean_dec(x_48); +x_55 = lean_unsigned_to_nat(1u); +x_56 = lean_nat_add(x_10, x_55); +lean_dec(x_10); +x_57 = !lean_is_exclusive(x_11); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_11, 2); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_19); +x_60 = lean_array_push(x_58, x_59); +lean_ctor_set(x_11, 2, x_60); +x_10 = x_56; x_12 = x_53; -x_14 = x_51; goto _start; } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; uint8_t x_59; -x_55 = lean_ctor_get(x_49, 1); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_ctor_get(x_50, 0); -lean_inc(x_56); -lean_dec(x_50); -x_57 = lean_unsigned_to_nat(1u); -x_58 = lean_nat_add(x_12, x_57); -lean_dec(x_12); -x_59 = !lean_is_exclusive(x_13); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_60 = lean_ctor_get(x_13, 2); -x_61 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_61, 0, x_56); -lean_ctor_set(x_61, 1, x_21); -x_62 = lean_array_push(x_60, x_61); -lean_ctor_set(x_13, 2, x_62); -x_12 = x_58; -x_14 = x_55; -goto _start; -} -else -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_64 = lean_ctor_get(x_13, 0); -x_65 = lean_ctor_get(x_13, 1); -x_66 = lean_ctor_get(x_13, 2); -lean_inc(x_66); -lean_inc(x_65); +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_62 = lean_ctor_get(x_11, 0); +x_63 = lean_ctor_get(x_11, 1); +x_64 = lean_ctor_get(x_11, 2); lean_inc(x_64); -lean_dec(x_13); -x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_56); -lean_ctor_set(x_67, 1, x_21); -x_68 = lean_array_push(x_66, x_67); -x_69 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_69, 0, x_64); -lean_ctor_set(x_69, 1, x_65); -lean_ctor_set(x_69, 2, x_68); -x_12 = x_58; -x_13 = x_69; -x_14 = x_55; +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_11); +x_65 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_65, 0, x_54); +lean_ctor_set(x_65, 1, x_19); +x_66 = lean_array_push(x_64, x_65); +x_67 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_63); +lean_ctor_set(x_67, 2, x_66); +x_10 = x_56; +x_11 = x_67; +x_12 = x_53; goto _start; } } } else { -uint8_t x_71; -lean_dec(x_21); -lean_dec(x_13); -lean_dec(x_12); +uint8_t x_69; +lean_dec(x_19); +lean_dec(x_11); lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_71 = !lean_is_exclusive(x_49); -if (x_71 == 0) -{ -return x_49; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_49, 0); -x_73 = lean_ctor_get(x_49, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_49); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_25); -lean_dec(x_21); -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_75 = !lean_is_exclusive(x_26); -if (x_75 == 0) -{ -return x_26; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_26, 0); -x_77 = lean_ctor_get(x_26, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_26); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -else -{ -uint8_t x_79; -lean_dec(x_21); -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_79 = !lean_is_exclusive(x_22); -if (x_79 == 0) -{ -return x_22; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_22, 0); -x_81 = lean_ctor_get(x_22, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_22); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___boxed), 14, 0); -return x_2; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; -lean_inc(x_6); -x_11 = l_Lean_mkFVar(x_6); -lean_inc(x_3); -x_12 = lean_array_push(x_3, x_11); -x_13 = lean_array_get_size(x_12); -lean_inc(x_12); -x_14 = lean_expr_instantiate_rev_range(x_5, x_4, x_13, x_12); -lean_dec(x_13); -x_15 = lean_array_get_size(x_7); -x_16 = lean_nat_dec_lt(x_8, x_15); -lean_dec(x_15); -if (x_16 == 0) -{ -lean_object* x_17; lean_dec(x_8); -lean_dec(x_6); +lean_dec(x_7); +lean_dec(x_4); lean_dec(x_3); -lean_dec(x_1); -x_17 = lean_apply_4(x_2, x_12, x_14, x_9, x_10); +lean_dec(x_2); +x_69 = !lean_is_exclusive(x_47); +if (x_69 == 0) +{ +return x_47; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_47, 0); +x_71 = lean_ctor_get(x_47, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_47); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_23); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_73 = !lean_is_exclusive(x_24); +if (x_73 == 0) +{ +return x_24; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_24, 0); +x_75 = lean_ctor_get(x_24, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_24); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_20); +if (x_77 == 0) +{ +return x_20; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_20, 0); +x_79 = lean_ctor_get(x_20, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_20); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_array_get_size(x_2); +x_7 = lean_nat_dec_lt(x_3, x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +lean_object* x_8; +lean_dec(x_4); +lean_dec(x_3); +x_8 = l_Lean_Expr_getAppFn___main(x_1); +if (lean_obj_tag(x_8) == 4) +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +lean_dec(x_8); +x_10 = lean_ctor_get(x_5, 0); +lean_inc(x_10); +lean_inc(x_9); +x_11 = lean_is_class(x_10, x_9); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; +lean_dec(x_9); +x_12 = lean_box(0); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_5); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_14, 0, x_9); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_5); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; +lean_dec(x_8); +x_16 = lean_box(0); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_16); +lean_ctor_set(x_17, 1, x_5); return x_17; } +} else { lean_object* x_18; lean_object* x_19; -lean_dec(x_14); -lean_dec(x_12); -x_18 = lean_array_fget(x_7, x_8); -lean_inc(x_9); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_9, x_10); +x_18 = lean_array_fget(x_2, x_3); +lean_inc(x_4); +x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_4, x_5); if (lean_obj_tag(x_19) == 0) { lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; @@ -5760,9 +6676,9 @@ lean_inc(x_21); lean_dec(x_19); x_22 = l_Lean_LocalDecl_type(x_20); lean_dec(x_20); -lean_inc(x_9); +lean_inc(x_4); lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_9, x_21); +x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_4, x_21); if (lean_obj_tag(x_23) == 0) { lean_object* x_24; @@ -5778,10 +6694,10 @@ x_25 = lean_ctor_get(x_23, 1); lean_inc(x_25); lean_dec(x_23); x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_8, x_26); -lean_dec(x_8); -x_8 = x_27; -x_10 = x_25; +x_27 = lean_nat_add(x_3, x_26); +lean_dec(x_3); +x_3 = x_27; +x_5 = x_25; goto _start; } case 1: @@ -5795,32 +6711,32 @@ x_30 = lean_ctor_get(x_24, 0); lean_inc(x_30); lean_dec(x_24); x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_8, x_31); -lean_dec(x_8); -x_33 = !lean_is_exclusive(x_9); +x_32 = lean_nat_add(x_3, x_31); +lean_dec(x_3); +x_33 = !lean_is_exclusive(x_4); if (x_33 == 0) { lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_9, 2); +x_34 = lean_ctor_get(x_4, 2); x_35 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_35, 0, x_30); lean_ctor_set(x_35, 1, x_18); x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_9, 2, x_36); -x_8 = x_32; -x_10 = x_29; +lean_ctor_set(x_4, 2, x_36); +x_3 = x_32; +x_5 = x_29; goto _start; } else { lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_9, 0); -x_39 = lean_ctor_get(x_9, 1); -x_40 = lean_ctor_get(x_9, 2); +x_38 = lean_ctor_get(x_4, 0); +x_39 = lean_ctor_get(x_4, 1); +x_40 = lean_ctor_get(x_4, 2); lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); -lean_dec(x_9); +lean_dec(x_4); x_41 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_41, 0, x_30); lean_ctor_set(x_41, 1, x_18); @@ -5829,9 +6745,9 @@ x_43 = lean_alloc_ctor(0, 3, 0); lean_ctor_set(x_43, 0, x_38); lean_ctor_set(x_43, 1, x_39); lean_ctor_set(x_43, 2, x_42); -x_8 = x_32; -x_9 = x_43; -x_10 = x_29; +x_3 = x_32; +x_4 = x_43; +x_5 = x_29; goto _start; } } @@ -5841,9 +6757,8 @@ lean_object* x_45; lean_object* x_46; x_45 = lean_ctor_get(x_23, 1); lean_inc(x_45); lean_dec(x_23); -lean_inc(x_9); -lean_inc(x_1); -x_46 = l_Lean_Meta_isClassExpensive___main(x_1, x_22, x_9, x_45); +lean_inc(x_4); +x_46 = l_Lean_Meta_isClassExpensive___main(x_22, x_4, x_45); if (lean_obj_tag(x_46) == 0) { lean_object* x_47; @@ -5857,10 +6772,10 @@ x_48 = lean_ctor_get(x_46, 1); lean_inc(x_48); lean_dec(x_46); x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_8, x_49); -lean_dec(x_8); -x_8 = x_50; -x_10 = x_48; +x_50 = lean_nat_add(x_3, x_49); +lean_dec(x_3); +x_3 = x_50; +x_5 = x_48; goto _start; } else @@ -5873,32 +6788,32 @@ x_53 = lean_ctor_get(x_47, 0); lean_inc(x_53); lean_dec(x_47); x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_8, x_54); -lean_dec(x_8); -x_56 = !lean_is_exclusive(x_9); +x_55 = lean_nat_add(x_3, x_54); +lean_dec(x_3); +x_56 = !lean_is_exclusive(x_4); if (x_56 == 0) { lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_9, 2); +x_57 = lean_ctor_get(x_4, 2); x_58 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_58, 0, x_53); lean_ctor_set(x_58, 1, x_18); x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_9, 2, x_59); -x_8 = x_55; -x_10 = x_52; +lean_ctor_set(x_4, 2, x_59); +x_3 = x_55; +x_5 = x_52; goto _start; } else { lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_9, 0); -x_62 = lean_ctor_get(x_9, 1); -x_63 = lean_ctor_get(x_9, 2); +x_61 = lean_ctor_get(x_4, 0); +x_62 = lean_ctor_get(x_4, 1); +x_63 = lean_ctor_get(x_4, 2); lean_inc(x_63); lean_inc(x_62); lean_inc(x_61); -lean_dec(x_9); +lean_dec(x_4); x_64 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_64, 0, x_53); lean_ctor_set(x_64, 1, x_18); @@ -5907,9 +6822,9 @@ x_66 = lean_alloc_ctor(0, 3, 0); lean_ctor_set(x_66, 0, x_61); lean_ctor_set(x_66, 1, x_62); lean_ctor_set(x_66, 2, x_65); -x_8 = x_55; -x_9 = x_66; -x_10 = x_52; +x_3 = x_55; +x_4 = x_66; +x_5 = x_52; goto _start; } } @@ -5918,12 +6833,8 @@ else { uint8_t x_68; lean_dec(x_18); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_6); +lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); x_68 = !lean_is_exclusive(x_46); if (x_68 == 0) { @@ -5951,12 +6862,8 @@ else uint8_t x_72; lean_dec(x_22); lean_dec(x_18); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_6); +lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); x_72 = !lean_is_exclusive(x_23); if (x_72 == 0) { @@ -5981,12 +6888,8 @@ else { uint8_t x_76; lean_dec(x_18); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_6); +lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); x_76 = !lean_is_exclusive(x_19); if (x_76 == 0) { @@ -6009,634 +6912,11 @@ return x_79; } } } -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg___boxed), 10, 0); -return x_2; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -lean_object* x_11; -if (lean_obj_tag(x_8) == 7) -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; uint64_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_24 = lean_ctor_get(x_8, 0); -lean_inc(x_24); -x_25 = lean_ctor_get(x_8, 1); -lean_inc(x_25); -x_26 = lean_ctor_get(x_8, 2); -lean_inc(x_26); -x_27 = lean_ctor_get_uint64(x_8, sizeof(void*)*3); -lean_dec(x_8); -x_28 = lean_array_get_size(x_6); -lean_inc(x_6); -x_29 = lean_expr_instantiate_rev_range(x_25, x_7, x_28, x_6); -lean_dec(x_28); -lean_dec(x_25); -x_30 = l_Lean_Meta_mkFreshId___rarg(x_10); -x_31 = lean_ctor_get(x_30, 0); -lean_inc(x_31); -x_32 = lean_ctor_get(x_30, 1); -lean_inc(x_32); -lean_dec(x_30); -x_33 = (uint8_t)((x_27 << 24) >> 61); -lean_inc(x_31); -x_34 = lean_local_ctx_mk_local_decl(x_5, x_31, x_24, x_29, x_33); -lean_inc(x_31); -x_35 = l_Lean_mkFVar(x_31); -lean_inc(x_6); -x_36 = lean_array_push(x_6, x_35); -if (lean_obj_tag(x_4) == 0) -{ -lean_dec(x_31); -lean_dec(x_6); -x_5 = x_34; -x_6 = x_36; -x_8 = x_26; -x_10 = x_32; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; uint8_t x_40; -x_38 = lean_ctor_get(x_4, 0); -lean_inc(x_38); -x_39 = lean_array_get_size(x_36); -x_40 = lean_nat_dec_lt(x_39, x_38); -lean_dec(x_38); -lean_dec(x_39); -if (x_40 == 0) -{ -uint8_t x_41; -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_9); -if (x_41 == 0) -{ -lean_object* x_42; lean_object* x_43; -x_42 = lean_ctor_get(x_9, 1); -lean_dec(x_42); -lean_ctor_set(x_9, 1, x_34); -lean_inc(x_7); -x_43 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg(x_1, x_2, x_6, x_7, x_26, x_31, x_36, x_7, x_9, x_32); -lean_dec(x_36); -lean_dec(x_26); -lean_dec(x_7); -return x_43; -} -else -{ -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_44 = lean_ctor_get(x_9, 0); -x_45 = lean_ctor_get(x_9, 2); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_9); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_34); -lean_ctor_set(x_46, 2, x_45); -lean_inc(x_7); -x_47 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg(x_1, x_2, x_6, x_7, x_26, x_31, x_36, x_7, x_46, x_32); -lean_dec(x_36); -lean_dec(x_26); -lean_dec(x_7); -return x_47; -} -} -else -{ -lean_dec(x_31); -lean_dec(x_6); -x_5 = x_34; -x_6 = x_36; -x_8 = x_26; -x_10 = x_32; -goto _start; -} -} -} -else -{ -lean_object* x_49; -x_49 = lean_box(0); -x_11 = x_49; -goto block_23; -} -block_23: -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -lean_dec(x_11); -x_12 = lean_array_get_size(x_6); -lean_inc(x_6); -x_13 = lean_expr_instantiate_rev_range(x_8, x_7, x_12, x_6); -x_14 = !lean_is_exclusive(x_9); -if (x_14 == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_9, 1); -lean_dec(x_15); -lean_inc(x_5); -lean_ctor_set(x_9, 1, x_5); -if (x_3 == 0) -{ -lean_object* x_16; -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_5); -lean_dec(x_4); -lean_inc(x_7); -lean_inc(x_6); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_6, x_7, x_8, x_6, x_7, x_9, x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -return x_16; -} -else -{ -lean_object* x_17; -lean_inc(x_7); -lean_inc(x_6); -x_17 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_12, x_13, x_6, x_7, x_9, x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -return x_17; -} -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_9, 0); -x_19 = lean_ctor_get(x_9, 2); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_9); -lean_inc(x_5); -x_20 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_5); -lean_ctor_set(x_20, 2, x_19); -if (x_3 == 0) -{ -lean_object* x_21; -lean_dec(x_13); -lean_dec(x_12); -lean_dec(x_5); -lean_dec(x_4); -lean_inc(x_7); -lean_inc(x_6); -x_21 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_6, x_7, x_8, x_6, x_7, x_20, x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -return x_21; -} -else -{ -lean_object* x_22; -lean_inc(x_7); -lean_inc(x_6); -x_22 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_12, x_13, x_6, x_7, x_20, x_10); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -return x_22; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg___boxed), 10, 0); -return x_2; -} -} -lean_object* l_Lean_Meta_forallTelescope___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_6 = lean_ctor_get(x_5, 2); -lean_inc(x_6); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -x_8 = lean_box(0); -x_9 = 0; -x_10 = l_Array_empty___closed__1; -x_11 = lean_unsigned_to_nat(0u); -x_12 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(x_1, x_3, x_9, x_8, x_7, x_10, x_11, x_2, x_4, x_5); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; uint8_t x_15; -x_14 = lean_ctor_get(x_12, 1); -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) -{ -lean_object* x_16; -x_16 = lean_ctor_get(x_14, 2); -lean_dec(x_16); -lean_ctor_set(x_14, 2, x_6); -return x_12; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_17 = lean_ctor_get(x_14, 0); -x_18 = lean_ctor_get(x_14, 1); -x_19 = lean_ctor_get(x_14, 3); -x_20 = lean_ctor_get(x_14, 4); -x_21 = lean_ctor_get(x_14, 5); -lean_inc(x_21); -lean_inc(x_20); -lean_inc(x_19); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_14); -x_22 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_22, 0, x_17); -lean_ctor_set(x_22, 1, x_18); -lean_ctor_set(x_22, 2, x_6); -lean_ctor_set(x_22, 3, x_19); -lean_ctor_set(x_22, 4, x_20); -lean_ctor_set(x_22, 5, x_21); -lean_ctor_set(x_12, 1, x_22); -return x_12; -} -} -else -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_23 = lean_ctor_get(x_12, 1); -x_24 = lean_ctor_get(x_12, 0); -lean_inc(x_23); -lean_inc(x_24); -lean_dec(x_12); -x_25 = lean_ctor_get(x_23, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_23, 1); -lean_inc(x_26); -x_27 = lean_ctor_get(x_23, 3); -lean_inc(x_27); -x_28 = lean_ctor_get(x_23, 4); -lean_inc(x_28); -x_29 = lean_ctor_get(x_23, 5); -lean_inc(x_29); -if (lean_is_exclusive(x_23)) { - lean_ctor_release(x_23, 0); - lean_ctor_release(x_23, 1); - lean_ctor_release(x_23, 2); - lean_ctor_release(x_23, 3); - lean_ctor_release(x_23, 4); - lean_ctor_release(x_23, 5); - x_30 = x_23; -} else { - lean_dec_ref(x_23); - x_30 = lean_box(0); -} -if (lean_is_scalar(x_30)) { - x_31 = lean_alloc_ctor(0, 6, 0); -} else { - x_31 = x_30; -} -lean_ctor_set(x_31, 0, x_25); -lean_ctor_set(x_31, 1, x_26); -lean_ctor_set(x_31, 2, x_6); -lean_ctor_set(x_31, 3, x_27); -lean_ctor_set(x_31, 4, x_28); -lean_ctor_set(x_31, 5, x_29); -x_32 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_32, 0, x_24); -lean_ctor_set(x_32, 1, x_31); -return x_32; -} -} -else -{ -uint8_t x_33; -x_33 = !lean_is_exclusive(x_12); -if (x_33 == 0) -{ -lean_object* x_34; uint8_t x_35; -x_34 = lean_ctor_get(x_12, 1); -x_35 = !lean_is_exclusive(x_34); -if (x_35 == 0) -{ -lean_object* x_36; -x_36 = lean_ctor_get(x_34, 2); -lean_dec(x_36); -lean_ctor_set(x_34, 2, x_6); -return x_12; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_34, 0); -x_38 = lean_ctor_get(x_34, 1); -x_39 = lean_ctor_get(x_34, 3); -x_40 = lean_ctor_get(x_34, 4); -x_41 = lean_ctor_get(x_34, 5); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_34); -x_42 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_42, 0, x_37); -lean_ctor_set(x_42, 1, x_38); -lean_ctor_set(x_42, 2, x_6); -lean_ctor_set(x_42, 3, x_39); -lean_ctor_set(x_42, 4, x_40); -lean_ctor_set(x_42, 5, x_41); -lean_ctor_set(x_12, 1, x_42); -return x_12; -} -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_43 = lean_ctor_get(x_12, 1); -x_44 = lean_ctor_get(x_12, 0); -lean_inc(x_43); -lean_inc(x_44); -lean_dec(x_12); -x_45 = lean_ctor_get(x_43, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_43, 1); -lean_inc(x_46); -x_47 = lean_ctor_get(x_43, 3); -lean_inc(x_47); -x_48 = lean_ctor_get(x_43, 4); -lean_inc(x_48); -x_49 = lean_ctor_get(x_43, 5); -lean_inc(x_49); -if (lean_is_exclusive(x_43)) { - lean_ctor_release(x_43, 0); - lean_ctor_release(x_43, 1); - lean_ctor_release(x_43, 2); - lean_ctor_release(x_43, 3); - lean_ctor_release(x_43, 4); - lean_ctor_release(x_43, 5); - x_50 = x_43; -} else { - lean_dec_ref(x_43); - x_50 = lean_box(0); -} -if (lean_is_scalar(x_50)) { - x_51 = lean_alloc_ctor(0, 6, 0); -} else { - x_51 = x_50; -} -lean_ctor_set(x_51, 0, x_45); -lean_ctor_set(x_51, 1, x_46); -lean_ctor_set(x_51, 2, x_6); -lean_ctor_set(x_51, 3, x_47); -lean_ctor_set(x_51, 4, x_48); -lean_ctor_set(x_51, 5, x_49); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_44); -lean_ctor_set(x_52, 1, x_51); -return x_52; -} -} -} -} -lean_object* l_Lean_Meta_forallTelescope(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_forallTelescope___rarg), 5, 0); -return x_2; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -x_10 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -return x_10; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { -_start: -{ -uint8_t x_12; lean_object* x_13; -x_12 = lean_unbox(x_5); -lean_dec(x_5); -x_13 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___lambda__1(x_1, x_2, x_3, x_4, x_12, x_6, x_7, x_8, x_9, x_10, x_11); -return x_13; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13, lean_object* x_14) { -_start: -{ -uint8_t x_15; lean_object* x_16; -x_15 = lean_unbox(x_3); -lean_dec(x_3); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_15, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13, x_14); -lean_dec(x_11); -lean_dec(x_8); -lean_dec(x_7); -return x_16; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -lean_object* x_11; -x_11 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); -return x_11; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -uint8_t x_11; lean_object* x_12; -x_11 = lean_unbox(x_3); -lean_dec(x_3); -x_12 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(x_1, x_2, x_11, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -return x_12; -} -} -lean_object* l_Lean_Meta_forallTelescopeReducing___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; -lean_inc(x_1); -x_6 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive), 4, 1); -lean_closure_set(x_6, 0, x_1); -x_7 = lean_box(0); -x_8 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(x_1, x_6, x_2, x_7, x_3, x_4, x_5); -return x_8; -} -} -lean_object* l_Lean_Meta_forallTelescopeReducing(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_forallTelescopeReducing___rarg), 5, 0); -return x_2; -} -} -lean_object* l_Lean_Meta_forallBoundedTelescope___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; lean_object* x_8; -lean_inc(x_1); -x_7 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive), 4, 1); -lean_closure_set(x_7, 0, x_1); -x_8 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___rarg(x_1, x_7, x_2, x_3, x_4, x_5, x_6); -return x_8; -} -} -lean_object* l_Lean_Meta_forallBoundedTelescope(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_forallBoundedTelescope___rarg), 6, 0); -return x_2; -} -} -lean_object* l_Lean_Meta_isClass(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -lean_inc(x_3); -lean_inc(x_2); -x_5 = l_Lean_Meta_isClassQuick___main(x_2, x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -lean_object* x_6; -x_6 = lean_ctor_get(x_5, 0); -lean_inc(x_6); -switch (lean_obj_tag(x_6)) { -case 0: -{ -uint8_t x_7; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_7 = !lean_is_exclusive(x_5); -if (x_7 == 0) -{ -lean_object* x_8; lean_object* x_9; -x_8 = lean_ctor_get(x_5, 0); -lean_dec(x_8); -x_9 = lean_box(0); -lean_ctor_set(x_5, 0, x_9); -return x_5; -} -else -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_5, 1); -lean_inc(x_10); -lean_dec(x_5); -x_11 = lean_box(0); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_10); -return x_12; -} -} -case 1: -{ -uint8_t x_13; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_13 = !lean_is_exclusive(x_5); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_5, 0); -lean_dec(x_14); -x_15 = lean_ctor_get(x_6, 0); -lean_inc(x_15); -lean_dec(x_6); -x_16 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_5, 0, x_16); -return x_5; -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_17 = lean_ctor_get(x_5, 1); -lean_inc(x_17); -lean_dec(x_5); -x_18 = lean_ctor_get(x_6, 0); -lean_inc(x_18); -lean_dec(x_6); -x_19 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_19, 0, x_18); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_19); -lean_ctor_set(x_20, 1, x_17); -return x_20; -} -} -default: -{ -lean_object* x_21; lean_object* x_22; -x_21 = lean_ctor_get(x_5, 1); -lean_inc(x_21); -lean_dec(x_5); -x_22 = l_Lean_Meta_isClassExpensive___main(x_1, x_2, x_3, x_21); -return x_22; -} -} -} -else -{ -uint8_t x_23; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_23 = !lean_is_exclusive(x_5); -if (x_23 == 0) -{ -return x_5; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_5, 0); -x_25 = lean_ctor_get(x_5, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_5); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { lean_object* x_9; -switch (lean_obj_tag(x_6)) { -case 6: +if (lean_obj_tag(x_6) == 7) { lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; x_22 = lean_ctor_get(x_6, 0); @@ -6663,94 +6943,5297 @@ lean_inc(x_29); x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); x_33 = l_Lean_mkFVar(x_29); x_34 = lean_array_push(x_4, x_33); +if (lean_obj_tag(x_2) == 0) +{ x_3 = x_32; x_4 = x_34; x_6 = x_24; x_8 = x_30; goto _start; } +else +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_2, 0); +lean_inc(x_36); +x_37 = lean_array_get_size(x_34); +x_38 = lean_nat_dec_lt(x_37, x_36); +lean_dec(x_36); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +lean_dec(x_2); +lean_inc(x_34); +x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); +lean_dec(x_37); +lean_dec(x_24); +x_40 = !lean_is_exclusive(x_7); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_7, 1); +lean_dec(x_41); +lean_ctor_set(x_7, 1, x_32); +x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_39, x_34, x_5, x_7, x_30); +lean_dec(x_34); +lean_dec(x_39); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_7, 0); +x_44 = lean_ctor_get(x_7, 2); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_7); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_32); +lean_ctor_set(x_45, 2, x_44); +x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_39, x_34, x_5, x_45, x_30); +lean_dec(x_34); +lean_dec(x_39); +return x_46; +} +} +else +{ +lean_dec(x_37); +x_3 = x_32; +x_4 = x_34; +x_6 = x_24; +x_8 = x_30; +goto _start; +} +} +} +else +{ +lean_object* x_48; +x_48 = lean_box(0); +x_9 = x_48; +goto block_21; +} +block_21: +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +lean_dec(x_9); +x_10 = lean_array_get_size(x_4); +lean_inc(x_4); +x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); +x_12 = !lean_is_exclusive(x_7); +if (x_12 == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_7, 1); +lean_dec(x_13); +lean_inc(x_3); +lean_ctor_set(x_7, 1, x_3); +if (x_1 == 0) +{ +lean_object* x_14; +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_11, x_4, x_5, x_7, x_8); +lean_dec(x_4); +lean_dec(x_11); +return x_14; +} +else +{ +lean_object* x_15; +lean_inc(x_5); +lean_inc(x_4); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_7, 0); +x_17 = lean_ctor_get(x_7, 2); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_7); +lean_inc(x_3); +x_18 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_3); +lean_ctor_set(x_18, 2, x_17); +if (x_1 == 0) +{ +lean_object* x_19; +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_19 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_11, x_4, x_5, x_18, x_8); +lean_dec(x_4); +lean_dec(x_11); +return x_19; +} +else +{ +lean_object* x_20; +lean_inc(x_5); +lean_inc(x_4); +x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_20; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isClassExpensive___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +lean_inc(x_1); +x_5 = l_Lean_Meta_whnf(x_1, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +uint8_t x_6; +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_7 = lean_ctor_get(x_5, 0); +x_8 = lean_ctor_get(x_5, 1); +x_9 = l_Lean_Expr_isForall(x_7); +if (x_9 == 0) +{ +lean_object* x_10; +lean_dec(x_7); +lean_dec(x_3); +lean_dec(x_2); +x_10 = l_Lean_Expr_getAppFn___main(x_1); +lean_dec(x_1); +if (lean_obj_tag(x_10) == 4) +{ +lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +lean_dec(x_10); +x_12 = lean_ctor_get(x_8, 0); +lean_inc(x_12); +lean_inc(x_11); +x_13 = lean_is_class(x_12, x_11); +if (x_13 == 0) +{ +lean_object* x_14; +lean_dec(x_11); +x_14 = lean_box(0); +lean_ctor_set(x_5, 0, x_14); +return x_5; +} +else +{ +lean_object* x_15; +x_15 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_15, 0, x_11); +lean_ctor_set(x_5, 0, x_15); +return x_5; +} +} +else +{ +lean_object* x_16; +lean_dec(x_10); +x_16 = lean_box(0); +lean_ctor_set(x_5, 0, x_16); +return x_5; +} +} +else +{ +lean_object* x_17; lean_object* x_18; uint8_t x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +lean_free_object(x_5); +lean_dec(x_1); +x_17 = lean_ctor_get(x_8, 2); +lean_inc(x_17); +x_18 = lean_ctor_get(x_3, 1); +lean_inc(x_18); +x_19 = 1; +x_20 = l_Array_empty___closed__1; +x_21 = lean_unsigned_to_nat(0u); +x_22 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2(x_19, x_2, x_18, x_20, x_21, x_7, x_3, x_8); +if (lean_obj_tag(x_22) == 0) +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +lean_object* x_24; uint8_t x_25; +x_24 = lean_ctor_get(x_22, 1); +x_25 = !lean_is_exclusive(x_24); +if (x_25 == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_24, 2); +lean_dec(x_26); +lean_ctor_set(x_24, 2, x_17); +return x_22; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_27 = lean_ctor_get(x_24, 0); +x_28 = lean_ctor_get(x_24, 1); +x_29 = lean_ctor_get(x_24, 3); +x_30 = lean_ctor_get(x_24, 4); +x_31 = lean_ctor_get(x_24, 5); +lean_inc(x_31); +lean_inc(x_30); +lean_inc(x_29); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_24); +x_32 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_32, 0, x_27); +lean_ctor_set(x_32, 1, x_28); +lean_ctor_set(x_32, 2, x_17); +lean_ctor_set(x_32, 3, x_29); +lean_ctor_set(x_32, 4, x_30); +lean_ctor_set(x_32, 5, x_31); +lean_ctor_set(x_22, 1, x_32); +return x_22; +} +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_33 = lean_ctor_get(x_22, 1); +x_34 = lean_ctor_get(x_22, 0); +lean_inc(x_33); +lean_inc(x_34); +lean_dec(x_22); +x_35 = lean_ctor_get(x_33, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_33, 1); +lean_inc(x_36); +x_37 = lean_ctor_get(x_33, 3); +lean_inc(x_37); +x_38 = lean_ctor_get(x_33, 4); +lean_inc(x_38); +x_39 = lean_ctor_get(x_33, 5); +lean_inc(x_39); +if (lean_is_exclusive(x_33)) { + lean_ctor_release(x_33, 0); + lean_ctor_release(x_33, 1); + lean_ctor_release(x_33, 2); + lean_ctor_release(x_33, 3); + lean_ctor_release(x_33, 4); + lean_ctor_release(x_33, 5); + x_40 = x_33; +} else { + lean_dec_ref(x_33); + x_40 = lean_box(0); +} +if (lean_is_scalar(x_40)) { + x_41 = lean_alloc_ctor(0, 6, 0); +} else { + x_41 = x_40; +} +lean_ctor_set(x_41, 0, x_35); +lean_ctor_set(x_41, 1, x_36); +lean_ctor_set(x_41, 2, x_17); +lean_ctor_set(x_41, 3, x_37); +lean_ctor_set(x_41, 4, x_38); +lean_ctor_set(x_41, 5, x_39); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_34); +lean_ctor_set(x_42, 1, x_41); +return x_42; +} +} +else +{ +uint8_t x_43; +x_43 = !lean_is_exclusive(x_22); +if (x_43 == 0) +{ +lean_object* x_44; uint8_t x_45; +x_44 = lean_ctor_get(x_22, 1); +x_45 = !lean_is_exclusive(x_44); +if (x_45 == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_44, 2); +lean_dec(x_46); +lean_ctor_set(x_44, 2, x_17); +return x_22; +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_47 = lean_ctor_get(x_44, 0); +x_48 = lean_ctor_get(x_44, 1); +x_49 = lean_ctor_get(x_44, 3); +x_50 = lean_ctor_get(x_44, 4); +x_51 = lean_ctor_get(x_44, 5); +lean_inc(x_51); +lean_inc(x_50); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_dec(x_44); +x_52 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_48); +lean_ctor_set(x_52, 2, x_17); +lean_ctor_set(x_52, 3, x_49); +lean_ctor_set(x_52, 4, x_50); +lean_ctor_set(x_52, 5, x_51); +lean_ctor_set(x_22, 1, x_52); +return x_22; +} +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_53 = lean_ctor_get(x_22, 1); +x_54 = lean_ctor_get(x_22, 0); +lean_inc(x_53); +lean_inc(x_54); +lean_dec(x_22); +x_55 = lean_ctor_get(x_53, 0); +lean_inc(x_55); +x_56 = lean_ctor_get(x_53, 1); +lean_inc(x_56); +x_57 = lean_ctor_get(x_53, 3); +lean_inc(x_57); +x_58 = lean_ctor_get(x_53, 4); +lean_inc(x_58); +x_59 = lean_ctor_get(x_53, 5); +lean_inc(x_59); +if (lean_is_exclusive(x_53)) { + lean_ctor_release(x_53, 0); + lean_ctor_release(x_53, 1); + lean_ctor_release(x_53, 2); + lean_ctor_release(x_53, 3); + lean_ctor_release(x_53, 4); + lean_ctor_release(x_53, 5); + x_60 = x_53; +} else { + lean_dec_ref(x_53); + x_60 = lean_box(0); +} +if (lean_is_scalar(x_60)) { + x_61 = lean_alloc_ctor(0, 6, 0); +} else { + x_61 = x_60; +} +lean_ctor_set(x_61, 0, x_55); +lean_ctor_set(x_61, 1, x_56); +lean_ctor_set(x_61, 2, x_17); +lean_ctor_set(x_61, 3, x_57); +lean_ctor_set(x_61, 4, x_58); +lean_ctor_set(x_61, 5, x_59); +x_62 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_62, 0, x_54); +lean_ctor_set(x_62, 1, x_61); +return x_62; +} +} +} +} +else +{ +lean_object* x_63; lean_object* x_64; uint8_t x_65; +x_63 = lean_ctor_get(x_5, 0); +x_64 = lean_ctor_get(x_5, 1); +lean_inc(x_64); +lean_inc(x_63); +lean_dec(x_5); +x_65 = l_Lean_Expr_isForall(x_63); +if (x_65 == 0) +{ +lean_object* x_66; +lean_dec(x_63); +lean_dec(x_3); +lean_dec(x_2); +x_66 = l_Lean_Expr_getAppFn___main(x_1); +lean_dec(x_1); +if (lean_obj_tag(x_66) == 4) +{ +lean_object* x_67; lean_object* x_68; uint8_t x_69; +x_67 = lean_ctor_get(x_66, 0); +lean_inc(x_67); +lean_dec(x_66); +x_68 = lean_ctor_get(x_64, 0); +lean_inc(x_68); +lean_inc(x_67); +x_69 = lean_is_class(x_68, x_67); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; +lean_dec(x_67); +x_70 = lean_box(0); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_70); +lean_ctor_set(x_71, 1, x_64); +return x_71; +} +else +{ +lean_object* x_72; lean_object* x_73; +x_72 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_72, 0, x_67); +x_73 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_73, 0, x_72); +lean_ctor_set(x_73, 1, x_64); +return x_73; +} +} +else +{ +lean_object* x_74; lean_object* x_75; +lean_dec(x_66); +x_74 = lean_box(0); +x_75 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_75, 0, x_74); +lean_ctor_set(x_75, 1, x_64); +return x_75; +} +} +else +{ +lean_object* x_76; lean_object* x_77; uint8_t x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; +lean_dec(x_1); +x_76 = lean_ctor_get(x_64, 2); +lean_inc(x_76); +x_77 = lean_ctor_get(x_3, 1); +lean_inc(x_77); +x_78 = 1; +x_79 = l_Array_empty___closed__1; +x_80 = lean_unsigned_to_nat(0u); +x_81 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2(x_78, x_2, x_77, x_79, x_80, x_63, x_3, x_64); +if (lean_obj_tag(x_81) == 0) +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_82 = lean_ctor_get(x_81, 1); +lean_inc(x_82); +x_83 = lean_ctor_get(x_81, 0); +lean_inc(x_83); +if (lean_is_exclusive(x_81)) { + lean_ctor_release(x_81, 0); + lean_ctor_release(x_81, 1); + x_84 = x_81; +} else { + lean_dec_ref(x_81); + x_84 = lean_box(0); +} +x_85 = lean_ctor_get(x_82, 0); +lean_inc(x_85); +x_86 = lean_ctor_get(x_82, 1); +lean_inc(x_86); +x_87 = lean_ctor_get(x_82, 3); +lean_inc(x_87); +x_88 = lean_ctor_get(x_82, 4); +lean_inc(x_88); +x_89 = lean_ctor_get(x_82, 5); +lean_inc(x_89); +if (lean_is_exclusive(x_82)) { + lean_ctor_release(x_82, 0); + lean_ctor_release(x_82, 1); + lean_ctor_release(x_82, 2); + lean_ctor_release(x_82, 3); + lean_ctor_release(x_82, 4); + lean_ctor_release(x_82, 5); + x_90 = x_82; +} else { + lean_dec_ref(x_82); + x_90 = lean_box(0); +} +if (lean_is_scalar(x_90)) { + x_91 = lean_alloc_ctor(0, 6, 0); +} else { + x_91 = x_90; +} +lean_ctor_set(x_91, 0, x_85); +lean_ctor_set(x_91, 1, x_86); +lean_ctor_set(x_91, 2, x_76); +lean_ctor_set(x_91, 3, x_87); +lean_ctor_set(x_91, 4, x_88); +lean_ctor_set(x_91, 5, x_89); +if (lean_is_scalar(x_84)) { + x_92 = lean_alloc_ctor(0, 2, 0); +} else { + x_92 = x_84; +} +lean_ctor_set(x_92, 0, x_83); +lean_ctor_set(x_92, 1, x_91); +return x_92; +} +else +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_93 = lean_ctor_get(x_81, 1); +lean_inc(x_93); +x_94 = lean_ctor_get(x_81, 0); +lean_inc(x_94); +if (lean_is_exclusive(x_81)) { + lean_ctor_release(x_81, 0); + lean_ctor_release(x_81, 1); + x_95 = x_81; +} else { + lean_dec_ref(x_81); + x_95 = lean_box(0); +} +x_96 = lean_ctor_get(x_93, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_93, 1); +lean_inc(x_97); +x_98 = lean_ctor_get(x_93, 3); +lean_inc(x_98); +x_99 = lean_ctor_get(x_93, 4); +lean_inc(x_99); +x_100 = lean_ctor_get(x_93, 5); +lean_inc(x_100); +if (lean_is_exclusive(x_93)) { + lean_ctor_release(x_93, 0); + lean_ctor_release(x_93, 1); + lean_ctor_release(x_93, 2); + lean_ctor_release(x_93, 3); + lean_ctor_release(x_93, 4); + lean_ctor_release(x_93, 5); + x_101 = x_93; +} else { + lean_dec_ref(x_93); + x_101 = lean_box(0); +} +if (lean_is_scalar(x_101)) { + x_102 = lean_alloc_ctor(0, 6, 0); +} else { + x_102 = x_101; +} +lean_ctor_set(x_102, 0, x_96); +lean_ctor_set(x_102, 1, x_97); +lean_ctor_set(x_102, 2, x_76); +lean_ctor_set(x_102, 3, x_98); +lean_ctor_set(x_102, 4, x_99); +lean_ctor_set(x_102, 5, x_100); +if (lean_is_scalar(x_95)) { + x_103 = lean_alloc_ctor(1, 2, 0); +} else { + x_103 = x_95; +} +lean_ctor_set(x_103, 0, x_94); +lean_ctor_set(x_103, 1, x_102); +return x_103; +} +} +} +} +else +{ +uint8_t x_104; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_104 = !lean_is_exclusive(x_5); +if (x_104 == 0) +{ +return x_5; +} +else +{ +lean_object* x_105; lean_object* x_106; lean_object* x_107; +x_105 = lean_ctor_get(x_5, 0); +x_106 = lean_ctor_get(x_5, 1); +lean_inc(x_106); +lean_inc(x_105); +lean_dec(x_5); +x_107 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_107, 0, x_105); +lean_ctor_set(x_107, 1, x_106); +return x_107; +} +} +} +} +lean_object* l_Lean_Meta_isClassExpensive___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; uint8_t x_5; +x_4 = lean_box(0); +x_5 = !lean_is_exclusive(x_2); +if (x_5 == 0) +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_2, 0); +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) +{ +uint8_t x_8; lean_object* x_9; +x_8 = 2; +lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 5, x_8); +x_9 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isClassExpensive___main___spec__1(x_1, x_4, x_2, x_3); +return x_9; +} +else +{ +lean_object* x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; +x_10 = lean_ctor_get(x_6, 0); +x_11 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); +x_12 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); +x_13 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); +x_14 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); +x_15 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 4); +lean_inc(x_10); +lean_dec(x_6); +x_16 = 2; +x_17 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_17, 0, x_10); +lean_ctor_set_uint8(x_17, sizeof(void*)*1, x_11); +lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 1, x_12); +lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 2, x_13); +lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 3, x_14); +lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 4, x_15); +lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 5, x_16); +lean_ctor_set(x_2, 0, x_17); +x_18 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isClassExpensive___main___spec__1(x_1, x_4, x_2, x_3); +return x_18; +} +} +else +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; uint8_t x_27; lean_object* x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_19 = lean_ctor_get(x_2, 0); +x_20 = lean_ctor_get(x_2, 1); +x_21 = lean_ctor_get(x_2, 2); +lean_inc(x_21); +lean_inc(x_20); +lean_inc(x_19); +lean_dec(x_2); +x_22 = lean_ctor_get(x_19, 0); +lean_inc(x_22); +x_23 = lean_ctor_get_uint8(x_19, sizeof(void*)*1); +x_24 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 1); +x_25 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 2); +x_26 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 3); +x_27 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 4); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + x_28 = x_19; +} else { + lean_dec_ref(x_19); + x_28 = lean_box(0); +} +x_29 = 2; +if (lean_is_scalar(x_28)) { + x_30 = lean_alloc_ctor(0, 1, 6); +} else { + x_30 = x_28; +} +lean_ctor_set(x_30, 0, x_22); +lean_ctor_set_uint8(x_30, sizeof(void*)*1, x_23); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 1, x_24); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 2, x_25); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 3, x_26); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 4, x_27); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 5, x_29); +x_31 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_31, 0, x_30); +lean_ctor_set(x_31, 1, x_20); +lean_ctor_set(x_31, 2, x_21); +x_32 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_isClassExpensive___main___spec__1(x_1, x_4, x_31, x_3); +return x_32; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__3(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___lambda__1(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_1); +return x_11; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +uint8_t x_13; lean_object* x_14; +x_13 = lean_unbox(x_1); +lean_dec(x_1); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__5(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +return x_14; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_isClassExpensive___main___spec__6(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_1); +lean_dec(x_1); +x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_isClassExpensive___main___spec__2(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_10; +} +} +lean_object* l_Lean_Meta_isClassExpensive(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_isClassExpensive___main(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_9 = lean_array_get_size(x_2); +lean_inc(x_2); +x_10 = lean_expr_instantiate_rev_range(x_4, x_3, x_9, x_2); +lean_dec(x_9); +x_11 = lean_array_get_size(x_5); +x_12 = lean_nat_dec_lt(x_6, x_11); +lean_dec(x_11); +if (x_12 == 0) +{ +lean_object* x_13; +lean_dec(x_6); +x_13 = lean_apply_4(x_1, x_2, x_10, x_7, x_8); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_10); +x_14 = lean_array_fget(x_5, x_6); +lean_inc(x_7); +x_15 = l_Lean_Meta_getFVarLocalDecl(x_14, x_7, x_8); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +x_18 = l_Lean_LocalDecl_type(x_16); +lean_dec(x_16); +lean_inc(x_7); +lean_inc(x_18); +x_19 = l_Lean_Meta_isClassQuick___main(x_18, x_7, x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +switch (lean_obj_tag(x_20)) { +case 0: +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_dec(x_18); +lean_dec(x_14); +x_21 = lean_ctor_get(x_19, 1); +lean_inc(x_21); +lean_dec(x_19); +x_22 = lean_unsigned_to_nat(1u); +x_23 = lean_nat_add(x_6, x_22); +lean_dec(x_6); +x_6 = x_23; +x_8 = x_21; +goto _start; +} +case 1: +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_dec(x_18); +x_25 = lean_ctor_get(x_19, 1); +lean_inc(x_25); +lean_dec(x_19); +x_26 = lean_ctor_get(x_20, 0); +lean_inc(x_26); +lean_dec(x_20); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_6, x_27); +lean_dec(x_6); +x_29 = !lean_is_exclusive(x_7); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_7, 2); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_26); +lean_ctor_set(x_31, 1, x_14); +x_32 = lean_array_push(x_30, x_31); +lean_ctor_set(x_7, 2, x_32); +x_6 = x_28; +x_8 = x_25; +goto _start; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_34 = lean_ctor_get(x_7, 0); +x_35 = lean_ctor_get(x_7, 1); +x_36 = lean_ctor_get(x_7, 2); +lean_inc(x_36); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_7); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_26); +lean_ctor_set(x_37, 1, x_14); +x_38 = lean_array_push(x_36, x_37); +x_39 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_39, 0, x_34); +lean_ctor_set(x_39, 1, x_35); +lean_ctor_set(x_39, 2, x_38); +x_6 = x_28; +x_7 = x_39; +x_8 = x_25; +goto _start; +} +} +default: +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_19, 1); +lean_inc(x_41); +lean_dec(x_19); +lean_inc(x_7); +x_42 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_41); +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_43; +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +lean_dec(x_14); +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +lean_dec(x_42); +x_45 = lean_unsigned_to_nat(1u); +x_46 = lean_nat_add(x_6, x_45); +lean_dec(x_6); +x_6 = x_46; +x_8 = x_44; +goto _start; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; uint8_t x_52; +x_48 = lean_ctor_get(x_42, 1); +lean_inc(x_48); +lean_dec(x_42); +x_49 = lean_ctor_get(x_43, 0); +lean_inc(x_49); +lean_dec(x_43); +x_50 = lean_unsigned_to_nat(1u); +x_51 = lean_nat_add(x_6, x_50); +lean_dec(x_6); +x_52 = !lean_is_exclusive(x_7); +if (x_52 == 0) +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_7, 2); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_49); +lean_ctor_set(x_54, 1, x_14); +x_55 = lean_array_push(x_53, x_54); +lean_ctor_set(x_7, 2, x_55); +x_6 = x_51; +x_8 = x_48; +goto _start; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_57 = lean_ctor_get(x_7, 0); +x_58 = lean_ctor_get(x_7, 1); +x_59 = lean_ctor_get(x_7, 2); +lean_inc(x_59); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_7); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_14); +x_61 = lean_array_push(x_59, x_60); +x_62 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_58); +lean_ctor_set(x_62, 2, x_61); +x_6 = x_51; +x_7 = x_62; +x_8 = x_48; +goto _start; +} +} +} +else +{ +uint8_t x_64; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_64 = !lean_is_exclusive(x_42); +if (x_64 == 0) +{ +return x_42; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_42, 0); +x_66 = lean_ctor_get(x_42, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_42); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; +} +} +} +} +} +else +{ +uint8_t x_68; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_68 = !lean_is_exclusive(x_19); +if (x_68 == 0) +{ +return x_19; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_19, 0); +x_70 = lean_ctor_get(x_19, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_19); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +uint8_t x_72; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_72 = !lean_is_exclusive(x_15); +if (x_72 == 0) +{ +return x_15; +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_73 = lean_ctor_get(x_15, 0); +x_74 = lean_ctor_get(x_15, 1); +lean_inc(x_74); +lean_inc(x_73); +lean_dec(x_15); +x_75 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +return x_75; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg___boxed), 8, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; +x_11 = l_Lean_Expr_isForall(x_8); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_12 = lean_apply_4(x_1, x_2, x_3, x_9, x_10); +return x_12; +} +else +{ +lean_object* x_13; +lean_dec(x_3); +x_13 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(x_1, x_4, x_5, x_6, x_2, x_7, x_8, x_9, x_10); +return x_13; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; +lean_inc(x_9); +x_14 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_14, 0, x_9); +x_15 = lean_box(x_2); +lean_inc(x_8); +lean_inc(x_4); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_5); +lean_inc(x_1); +x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___lambda__1___boxed), 10, 7); +lean_closure_set(x_16, 0, x_1); +lean_closure_set(x_16, 1, x_5); +lean_closure_set(x_16, 2, x_9); +lean_closure_set(x_16, 3, x_15); +lean_closure_set(x_16, 4, x_3); +lean_closure_set(x_16, 5, x_4); +lean_closure_set(x_16, 6, x_8); +x_17 = lean_array_get_size(x_10); +x_18 = lean_nat_dec_lt(x_11, x_17); +lean_dec(x_17); +if (x_18 == 0) +{ +lean_object* x_19; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_19 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_14, x_16, x_12, x_13); +return x_19; +} +else +{ +lean_object* x_20; lean_object* x_21; +lean_dec(x_16); +lean_dec(x_14); +x_20 = lean_array_fget(x_10, x_11); +lean_inc(x_12); +x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_12, x_13); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); +lean_inc(x_23); +lean_dec(x_21); +x_24 = l_Lean_LocalDecl_type(x_22); +lean_dec(x_22); +lean_inc(x_12); +lean_inc(x_24); +x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_12, x_23); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +switch (lean_obj_tag(x_26)) { +case 0: +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_dec(x_24); +lean_dec(x_20); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_11, x_28); +lean_dec(x_11); +x_11 = x_29; +x_13 = x_27; +goto _start; +} +case 1: +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 1); +lean_inc(x_31); +lean_dec(x_25); +x_32 = lean_ctor_get(x_26, 0); +lean_inc(x_32); +lean_dec(x_26); +x_33 = lean_unsigned_to_nat(1u); +x_34 = lean_nat_add(x_11, x_33); +lean_dec(x_11); +x_35 = !lean_is_exclusive(x_12); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_12, 2); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_32); +lean_ctor_set(x_37, 1, x_20); +x_38 = lean_array_push(x_36, x_37); +lean_ctor_set(x_12, 2, x_38); +x_11 = x_34; +x_13 = x_31; +goto _start; +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_40 = lean_ctor_get(x_12, 0); +x_41 = lean_ctor_get(x_12, 1); +x_42 = lean_ctor_get(x_12, 2); +lean_inc(x_42); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_12); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_32); +lean_ctor_set(x_43, 1, x_20); +x_44 = lean_array_push(x_42, x_43); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_40); +lean_ctor_set(x_45, 1, x_41); +lean_ctor_set(x_45, 2, x_44); +x_11 = x_34; +x_12 = x_45; +x_13 = x_31; +goto _start; +} +} +default: +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_25, 1); +lean_inc(x_47); +lean_dec(x_25); +lean_inc(x_12); +x_48 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_47); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +if (lean_obj_tag(x_49) == 0) +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_dec(x_20); +x_50 = lean_ctor_get(x_48, 1); +lean_inc(x_50); +lean_dec(x_48); +x_51 = lean_unsigned_to_nat(1u); +x_52 = lean_nat_add(x_11, x_51); +lean_dec(x_11); +x_11 = x_52; +x_13 = x_50; +goto _start; +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; +x_54 = lean_ctor_get(x_48, 1); +lean_inc(x_54); +lean_dec(x_48); +x_55 = lean_ctor_get(x_49, 0); +lean_inc(x_55); +lean_dec(x_49); +x_56 = lean_unsigned_to_nat(1u); +x_57 = lean_nat_add(x_11, x_56); +lean_dec(x_11); +x_58 = !lean_is_exclusive(x_12); +if (x_58 == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_12, 2); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_55); +lean_ctor_set(x_60, 1, x_20); +x_61 = lean_array_push(x_59, x_60); +lean_ctor_set(x_12, 2, x_61); +x_11 = x_57; +x_13 = x_54; +goto _start; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_63 = lean_ctor_get(x_12, 0); +x_64 = lean_ctor_get(x_12, 1); +x_65 = lean_ctor_get(x_12, 2); +lean_inc(x_65); +lean_inc(x_64); +lean_inc(x_63); +lean_dec(x_12); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_20); +x_67 = lean_array_push(x_65, x_66); +x_68 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_64); +lean_ctor_set(x_68, 2, x_67); +x_11 = x_57; +x_12 = x_68; +x_13 = x_54; +goto _start; +} +} +} +else +{ +uint8_t x_70; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_70 = !lean_is_exclusive(x_48); +if (x_70 == 0) +{ +return x_48; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_48, 0); +x_72 = lean_ctor_get(x_48, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_48); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_71); +lean_ctor_set(x_73, 1, x_72); +return x_73; +} +} +} +} +} +else +{ +uint8_t x_74; +lean_dec(x_24); +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_25); +if (x_74 == 0) +{ +return x_25; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_25, 0); +x_76 = lean_ctor_get(x_25, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_25); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; +} +} +} +else +{ +uint8_t x_78; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_21); +if (x_78 == 0) +{ +return x_21; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_21, 0); +x_80 = lean_ctor_get(x_21, 1); +lean_inc(x_80); +lean_inc(x_79); +lean_dec(x_21); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_79); +lean_ctor_set(x_81, 1, x_80); +return x_81; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___boxed), 13, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; +lean_inc(x_5); +x_10 = l_Lean_mkFVar(x_5); +lean_inc(x_2); +x_11 = lean_array_push(x_2, x_10); +x_12 = lean_array_get_size(x_11); +lean_inc(x_11); +x_13 = lean_expr_instantiate_rev_range(x_4, x_3, x_12, x_11); +lean_dec(x_12); +x_14 = lean_array_get_size(x_6); +x_15 = lean_nat_dec_lt(x_7, x_14); +lean_dec(x_14); +if (x_15 == 0) +{ +lean_object* x_16; +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +x_16 = lean_apply_4(x_1, x_11, x_13, x_8, x_9); +return x_16; +} +else +{ +lean_object* x_17; lean_object* x_18; +lean_dec(x_13); +lean_dec(x_11); +x_17 = lean_array_fget(x_6, x_7); +lean_inc(x_8); +x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_8, x_9); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = l_Lean_LocalDecl_type(x_19); +lean_dec(x_19); +lean_inc(x_8); +lean_inc(x_21); +x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_8, x_20); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +switch (lean_obj_tag(x_23)) { +case 0: +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +lean_dec(x_21); +lean_dec(x_17); +x_24 = lean_ctor_get(x_22, 1); +lean_inc(x_24); +lean_dec(x_22); +x_25 = lean_unsigned_to_nat(1u); +x_26 = lean_nat_add(x_7, x_25); +lean_dec(x_7); +x_7 = x_26; +x_9 = x_24; +goto _start; +} +case 1: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; +lean_dec(x_21); +x_28 = lean_ctor_get(x_22, 1); +lean_inc(x_28); +lean_dec(x_22); +x_29 = lean_ctor_get(x_23, 0); +lean_inc(x_29); +lean_dec(x_23); +x_30 = lean_unsigned_to_nat(1u); +x_31 = lean_nat_add(x_7, x_30); +lean_dec(x_7); +x_32 = !lean_is_exclusive(x_8); +if (x_32 == 0) +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_8, 2); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_29); +lean_ctor_set(x_34, 1, x_17); +x_35 = lean_array_push(x_33, x_34); +lean_ctor_set(x_8, 2, x_35); +x_7 = x_31; +x_9 = x_28; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_37 = lean_ctor_get(x_8, 0); +x_38 = lean_ctor_get(x_8, 1); +x_39 = lean_ctor_get(x_8, 2); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_dec(x_8); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_17); +x_41 = lean_array_push(x_39, x_40); +x_42 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_38); +lean_ctor_set(x_42, 2, x_41); +x_7 = x_31; +x_8 = x_42; +x_9 = x_28; +goto _start; +} +} +default: +{ +lean_object* x_44; lean_object* x_45; +x_44 = lean_ctor_get(x_22, 1); +lean_inc(x_44); +lean_dec(x_22); +lean_inc(x_8); +x_45 = l_Lean_Meta_isClassExpensive___main(x_21, x_8, x_44); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_17); +x_47 = lean_ctor_get(x_45, 1); +lean_inc(x_47); +lean_dec(x_45); +x_48 = lean_unsigned_to_nat(1u); +x_49 = lean_nat_add(x_7, x_48); +lean_dec(x_7); +x_7 = x_49; +x_9 = x_47; +goto _start; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_51 = lean_ctor_get(x_45, 1); +lean_inc(x_51); +lean_dec(x_45); +x_52 = lean_ctor_get(x_46, 0); +lean_inc(x_52); +lean_dec(x_46); +x_53 = lean_unsigned_to_nat(1u); +x_54 = lean_nat_add(x_7, x_53); +lean_dec(x_7); +x_55 = !lean_is_exclusive(x_8); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_8, 2); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_52); +lean_ctor_set(x_57, 1, x_17); +x_58 = lean_array_push(x_56, x_57); +lean_ctor_set(x_8, 2, x_58); +x_7 = x_54; +x_9 = x_51; +goto _start; +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_60 = lean_ctor_get(x_8, 0); +x_61 = lean_ctor_get(x_8, 1); +x_62 = lean_ctor_get(x_8, 2); +lean_inc(x_62); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_8); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_52); +lean_ctor_set(x_63, 1, x_17); +x_64 = lean_array_push(x_62, x_63); +x_65 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_64); +x_7 = x_54; +x_8 = x_65; +x_9 = x_51; +goto _start; +} +} +} +else +{ +uint8_t x_67; +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_67 = !lean_is_exclusive(x_45); +if (x_67 == 0) +{ +return x_45; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_45, 0); +x_69 = lean_ctor_get(x_45, 1); +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_45); +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; +} +} +} +} +} +else +{ +uint8_t x_71; +lean_dec(x_21); +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_71 = !lean_is_exclusive(x_22); +if (x_71 == 0) +{ +return x_22; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_22, 0); +x_73 = lean_ctor_get(x_22, 1); +lean_inc(x_73); +lean_inc(x_72); +lean_dec(x_22); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_75 = !lean_is_exclusive(x_18); +if (x_75 == 0) +{ +return x_18; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_18, 0); +x_77 = lean_ctor_get(x_18, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_18); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___boxed), 9, 0); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +if (lean_obj_tag(x_7) == 7) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; uint64_t x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_23 = lean_ctor_get(x_7, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_7, 1); +lean_inc(x_24); +x_25 = lean_ctor_get(x_7, 2); +lean_inc(x_25); +x_26 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); +lean_dec(x_7); +x_27 = lean_array_get_size(x_5); +lean_inc(x_5); +x_28 = lean_expr_instantiate_rev_range(x_24, x_6, x_27, x_5); +lean_dec(x_27); +lean_dec(x_24); +x_29 = l_Lean_Meta_mkFreshId___rarg(x_9); +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_29, 1); +lean_inc(x_31); +lean_dec(x_29); +x_32 = (uint8_t)((x_26 << 24) >> 61); +lean_inc(x_30); +x_33 = lean_local_ctx_mk_local_decl(x_4, x_30, x_23, x_28, x_32); +lean_inc(x_30); +x_34 = l_Lean_mkFVar(x_30); +lean_inc(x_5); +x_35 = lean_array_push(x_5, x_34); +if (lean_obj_tag(x_3) == 0) +{ +lean_dec(x_30); +lean_dec(x_5); +x_4 = x_33; +x_5 = x_35; +x_7 = x_25; +x_9 = x_31; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_37 = lean_ctor_get(x_3, 0); +lean_inc(x_37); +x_38 = lean_array_get_size(x_35); +x_39 = lean_nat_dec_lt(x_38, x_37); +lean_dec(x_37); +lean_dec(x_38); +if (x_39 == 0) +{ +uint8_t x_40; +lean_dec(x_3); +x_40 = !lean_is_exclusive(x_8); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_8, 1); +lean_dec(x_41); +lean_ctor_set(x_8, 1, x_33); +lean_inc(x_6); +x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_5, x_6, x_25, x_30, x_35, x_6, x_8, x_31); +lean_dec(x_35); +lean_dec(x_25); +lean_dec(x_6); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_8, 0); +x_44 = lean_ctor_get(x_8, 2); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_8); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_33); +lean_ctor_set(x_45, 2, x_44); +lean_inc(x_6); +x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_5, x_6, x_25, x_30, x_35, x_6, x_45, x_31); +lean_dec(x_35); +lean_dec(x_25); +lean_dec(x_6); +return x_46; +} +} +else +{ +lean_dec(x_30); +lean_dec(x_5); +x_4 = x_33; +x_5 = x_35; +x_7 = x_25; +x_9 = x_31; +goto _start; +} +} +} +else +{ +lean_object* x_48; +x_48 = lean_box(0); +x_10 = x_48; +goto block_22; +} +block_22: +{ +lean_object* x_11; lean_object* x_12; uint8_t x_13; +lean_dec(x_10); +x_11 = lean_array_get_size(x_5); +lean_inc(x_5); +x_12 = lean_expr_instantiate_rev_range(x_7, x_6, x_11, x_5); +x_13 = !lean_is_exclusive(x_8); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_8, 1); +lean_dec(x_14); +lean_inc(x_4); +lean_ctor_set(x_8, 1, x_4); +if (x_2 == 0) +{ +lean_object* x_15; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_6); +lean_inc(x_5); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_5, x_6, x_7, x_5, x_6, x_8, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_15; +} +else +{ +lean_object* x_16; +lean_inc(x_6); +lean_inc(x_5); +x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_8, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_8, 0); +x_18 = lean_ctor_get(x_8, 2); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_8); +lean_inc(x_4); +x_19 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_4); +lean_ctor_set(x_19, 2, x_18); +if (x_2 == 0) +{ +lean_object* x_20; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_6); +lean_inc(x_5); +x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_5, x_6, x_7, x_5, x_6, x_19, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_20; +} +else +{ +lean_object* x_21; +lean_inc(x_6); +lean_inc(x_5); +x_21 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_19, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_21; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg___boxed), 9, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_forallTelescope___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_5 = lean_ctor_get(x_4, 2); +lean_inc(x_5); +x_6 = lean_ctor_get(x_3, 1); +lean_inc(x_6); +x_7 = lean_box(0); +x_8 = 0; +x_9 = l_Array_empty___closed__1; +x_10 = lean_unsigned_to_nat(0u); +x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(x_2, x_8, x_7, x_6, x_9, x_10, x_1, x_3, x_4); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; uint8_t x_14; +x_13 = lean_ctor_get(x_11, 1); +x_14 = !lean_is_exclusive(x_13); +if (x_14 == 0) +{ +lean_object* x_15; +x_15 = lean_ctor_get(x_13, 2); +lean_dec(x_15); +lean_ctor_set(x_13, 2, x_5); +return x_11; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_16 = lean_ctor_get(x_13, 0); +x_17 = lean_ctor_get(x_13, 1); +x_18 = lean_ctor_get(x_13, 3); +x_19 = lean_ctor_get(x_13, 4); +x_20 = lean_ctor_get(x_13, 5); +lean_inc(x_20); +lean_inc(x_19); +lean_inc(x_18); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_13); +x_21 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_21, 0, x_16); +lean_ctor_set(x_21, 1, x_17); +lean_ctor_set(x_21, 2, x_5); +lean_ctor_set(x_21, 3, x_18); +lean_ctor_set(x_21, 4, x_19); +lean_ctor_set(x_21, 5, x_20); +lean_ctor_set(x_11, 1, x_21); +return x_11; +} +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_22 = lean_ctor_get(x_11, 1); +x_23 = lean_ctor_get(x_11, 0); +lean_inc(x_22); +lean_inc(x_23); +lean_dec(x_11); +x_24 = lean_ctor_get(x_22, 0); +lean_inc(x_24); +x_25 = lean_ctor_get(x_22, 1); +lean_inc(x_25); +x_26 = lean_ctor_get(x_22, 3); +lean_inc(x_26); +x_27 = lean_ctor_get(x_22, 4); +lean_inc(x_27); +x_28 = lean_ctor_get(x_22, 5); +lean_inc(x_28); +if (lean_is_exclusive(x_22)) { + lean_ctor_release(x_22, 0); + lean_ctor_release(x_22, 1); + lean_ctor_release(x_22, 2); + lean_ctor_release(x_22, 3); + lean_ctor_release(x_22, 4); + lean_ctor_release(x_22, 5); + x_29 = x_22; +} else { + lean_dec_ref(x_22); + x_29 = lean_box(0); +} +if (lean_is_scalar(x_29)) { + x_30 = lean_alloc_ctor(0, 6, 0); +} else { + x_30 = x_29; +} +lean_ctor_set(x_30, 0, x_24); +lean_ctor_set(x_30, 1, x_25); +lean_ctor_set(x_30, 2, x_5); +lean_ctor_set(x_30, 3, x_26); +lean_ctor_set(x_30, 4, x_27); +lean_ctor_set(x_30, 5, x_28); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_23); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +else +{ +uint8_t x_32; +x_32 = !lean_is_exclusive(x_11); +if (x_32 == 0) +{ +lean_object* x_33; uint8_t x_34; +x_33 = lean_ctor_get(x_11, 1); +x_34 = !lean_is_exclusive(x_33); +if (x_34 == 0) +{ +lean_object* x_35; +x_35 = lean_ctor_get(x_33, 2); +lean_dec(x_35); +lean_ctor_set(x_33, 2, x_5); +return x_11; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_36 = lean_ctor_get(x_33, 0); +x_37 = lean_ctor_get(x_33, 1); +x_38 = lean_ctor_get(x_33, 3); +x_39 = lean_ctor_get(x_33, 4); +x_40 = lean_ctor_get(x_33, 5); +lean_inc(x_40); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_33); +x_41 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_41, 0, x_36); +lean_ctor_set(x_41, 1, x_37); +lean_ctor_set(x_41, 2, x_5); +lean_ctor_set(x_41, 3, x_38); +lean_ctor_set(x_41, 4, x_39); +lean_ctor_set(x_41, 5, x_40); +lean_ctor_set(x_11, 1, x_41); +return x_11; +} +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_42 = lean_ctor_get(x_11, 1); +x_43 = lean_ctor_get(x_11, 0); +lean_inc(x_42); +lean_inc(x_43); +lean_dec(x_11); +x_44 = lean_ctor_get(x_42, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_42, 1); +lean_inc(x_45); +x_46 = lean_ctor_get(x_42, 3); +lean_inc(x_46); +x_47 = lean_ctor_get(x_42, 4); +lean_inc(x_47); +x_48 = lean_ctor_get(x_42, 5); +lean_inc(x_48); +if (lean_is_exclusive(x_42)) { + lean_ctor_release(x_42, 0); + lean_ctor_release(x_42, 1); + lean_ctor_release(x_42, 2); + lean_ctor_release(x_42, 3); + lean_ctor_release(x_42, 4); + lean_ctor_release(x_42, 5); + x_49 = x_42; +} else { + lean_dec_ref(x_42); + x_49 = lean_box(0); +} +if (lean_is_scalar(x_49)) { + x_50 = lean_alloc_ctor(0, 6, 0); +} else { + x_50 = x_49; +} +lean_ctor_set(x_50, 0, x_44); +lean_ctor_set(x_50, 1, x_45); +lean_ctor_set(x_50, 2, x_5); +lean_ctor_set(x_50, 3, x_46); +lean_ctor_set(x_50, 4, x_47); +lean_ctor_set(x_50, 5, x_48); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_43); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +} +lean_object* l_Lean_Meta_forallTelescope(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_forallTelescope___rarg), 4, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__2___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +return x_9; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; lean_object* x_12; +x_11 = lean_unbox(x_4); +lean_dec(x_4); +x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___lambda__1(x_1, x_2, x_3, x_11, x_5, x_6, x_7, x_8, x_9, x_10); +return x_12; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +uint8_t x_14; lean_object* x_15; +x_14 = lean_unbox(x_2); +lean_dec(x_2); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__3___rarg(x_1, x_14, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_6); +return x_15; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +return x_10; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescope___spec__1___rarg(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +return x_11; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_9 = lean_array_get_size(x_2); +lean_inc(x_2); +x_10 = lean_expr_instantiate_rev_range(x_4, x_3, x_9, x_2); +lean_dec(x_9); +x_11 = lean_array_get_size(x_5); +x_12 = lean_nat_dec_lt(x_6, x_11); +lean_dec(x_11); +if (x_12 == 0) +{ +lean_object* x_13; +lean_dec(x_6); +x_13 = lean_apply_4(x_1, x_2, x_10, x_7, x_8); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_10); +x_14 = lean_array_fget(x_5, x_6); +lean_inc(x_7); +x_15 = l_Lean_Meta_getFVarLocalDecl(x_14, x_7, x_8); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +x_18 = l_Lean_LocalDecl_type(x_16); +lean_dec(x_16); +lean_inc(x_7); +lean_inc(x_18); +x_19 = l_Lean_Meta_isClassQuick___main(x_18, x_7, x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +switch (lean_obj_tag(x_20)) { +case 0: +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_dec(x_18); +lean_dec(x_14); +x_21 = lean_ctor_get(x_19, 1); +lean_inc(x_21); +lean_dec(x_19); +x_22 = lean_unsigned_to_nat(1u); +x_23 = lean_nat_add(x_6, x_22); +lean_dec(x_6); +x_6 = x_23; +x_8 = x_21; +goto _start; +} +case 1: +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_dec(x_18); +x_25 = lean_ctor_get(x_19, 1); +lean_inc(x_25); +lean_dec(x_19); +x_26 = lean_ctor_get(x_20, 0); +lean_inc(x_26); +lean_dec(x_20); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_6, x_27); +lean_dec(x_6); +x_29 = !lean_is_exclusive(x_7); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_7, 2); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_26); +lean_ctor_set(x_31, 1, x_14); +x_32 = lean_array_push(x_30, x_31); +lean_ctor_set(x_7, 2, x_32); +x_6 = x_28; +x_8 = x_25; +goto _start; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_34 = lean_ctor_get(x_7, 0); +x_35 = lean_ctor_get(x_7, 1); +x_36 = lean_ctor_get(x_7, 2); +lean_inc(x_36); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_7); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_26); +lean_ctor_set(x_37, 1, x_14); +x_38 = lean_array_push(x_36, x_37); +x_39 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_39, 0, x_34); +lean_ctor_set(x_39, 1, x_35); +lean_ctor_set(x_39, 2, x_38); +x_6 = x_28; +x_7 = x_39; +x_8 = x_25; +goto _start; +} +} +default: +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_19, 1); +lean_inc(x_41); +lean_dec(x_19); +lean_inc(x_7); +x_42 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_41); +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_43; +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +lean_dec(x_14); +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +lean_dec(x_42); +x_45 = lean_unsigned_to_nat(1u); +x_46 = lean_nat_add(x_6, x_45); +lean_dec(x_6); +x_6 = x_46; +x_8 = x_44; +goto _start; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; uint8_t x_52; +x_48 = lean_ctor_get(x_42, 1); +lean_inc(x_48); +lean_dec(x_42); +x_49 = lean_ctor_get(x_43, 0); +lean_inc(x_49); +lean_dec(x_43); +x_50 = lean_unsigned_to_nat(1u); +x_51 = lean_nat_add(x_6, x_50); +lean_dec(x_6); +x_52 = !lean_is_exclusive(x_7); +if (x_52 == 0) +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_7, 2); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_49); +lean_ctor_set(x_54, 1, x_14); +x_55 = lean_array_push(x_53, x_54); +lean_ctor_set(x_7, 2, x_55); +x_6 = x_51; +x_8 = x_48; +goto _start; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_57 = lean_ctor_get(x_7, 0); +x_58 = lean_ctor_get(x_7, 1); +x_59 = lean_ctor_get(x_7, 2); +lean_inc(x_59); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_7); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_14); +x_61 = lean_array_push(x_59, x_60); +x_62 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_58); +lean_ctor_set(x_62, 2, x_61); +x_6 = x_51; +x_7 = x_62; +x_8 = x_48; +goto _start; +} +} +} +else +{ +uint8_t x_64; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_64 = !lean_is_exclusive(x_42); +if (x_64 == 0) +{ +return x_42; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_42, 0); +x_66 = lean_ctor_get(x_42, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_42); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; +} +} +} +} +} +else +{ +uint8_t x_68; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_68 = !lean_is_exclusive(x_19); +if (x_68 == 0) +{ +return x_19; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_19, 0); +x_70 = lean_ctor_get(x_19, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_19); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +uint8_t x_72; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_72 = !lean_is_exclusive(x_15); +if (x_72 == 0) +{ +return x_15; +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_73 = lean_ctor_get(x_15, 0); +x_74 = lean_ctor_get(x_15, 1); +lean_inc(x_74); +lean_inc(x_73); +lean_dec(x_15); +x_75 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +return x_75; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg___boxed), 8, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; +x_11 = l_Lean_Expr_isForall(x_8); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_12 = lean_apply_4(x_1, x_2, x_3, x_9, x_10); +return x_12; +} +else +{ +lean_object* x_13; +lean_dec(x_3); +x_13 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg(x_1, x_4, x_5, x_6, x_2, x_7, x_8, x_9, x_10); +return x_13; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; +lean_inc(x_9); +x_14 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_14, 0, x_9); +x_15 = lean_box(x_2); +lean_inc(x_8); +lean_inc(x_4); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_5); +lean_inc(x_1); +x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___lambda__1___boxed), 10, 7); +lean_closure_set(x_16, 0, x_1); +lean_closure_set(x_16, 1, x_5); +lean_closure_set(x_16, 2, x_9); +lean_closure_set(x_16, 3, x_15); +lean_closure_set(x_16, 4, x_3); +lean_closure_set(x_16, 5, x_4); +lean_closure_set(x_16, 6, x_8); +x_17 = lean_array_get_size(x_10); +x_18 = lean_nat_dec_lt(x_11, x_17); +lean_dec(x_17); +if (x_18 == 0) +{ +lean_object* x_19; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_19 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_14, x_16, x_12, x_13); +return x_19; +} +else +{ +lean_object* x_20; lean_object* x_21; +lean_dec(x_16); +lean_dec(x_14); +x_20 = lean_array_fget(x_10, x_11); +lean_inc(x_12); +x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_12, x_13); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); +lean_inc(x_23); +lean_dec(x_21); +x_24 = l_Lean_LocalDecl_type(x_22); +lean_dec(x_22); +lean_inc(x_12); +lean_inc(x_24); +x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_12, x_23); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +switch (lean_obj_tag(x_26)) { +case 0: +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_dec(x_24); +lean_dec(x_20); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_11, x_28); +lean_dec(x_11); +x_11 = x_29; +x_13 = x_27; +goto _start; +} +case 1: +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 1); +lean_inc(x_31); +lean_dec(x_25); +x_32 = lean_ctor_get(x_26, 0); +lean_inc(x_32); +lean_dec(x_26); +x_33 = lean_unsigned_to_nat(1u); +x_34 = lean_nat_add(x_11, x_33); +lean_dec(x_11); +x_35 = !lean_is_exclusive(x_12); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_12, 2); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_32); +lean_ctor_set(x_37, 1, x_20); +x_38 = lean_array_push(x_36, x_37); +lean_ctor_set(x_12, 2, x_38); +x_11 = x_34; +x_13 = x_31; +goto _start; +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_40 = lean_ctor_get(x_12, 0); +x_41 = lean_ctor_get(x_12, 1); +x_42 = lean_ctor_get(x_12, 2); +lean_inc(x_42); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_12); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_32); +lean_ctor_set(x_43, 1, x_20); +x_44 = lean_array_push(x_42, x_43); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_40); +lean_ctor_set(x_45, 1, x_41); +lean_ctor_set(x_45, 2, x_44); +x_11 = x_34; +x_12 = x_45; +x_13 = x_31; +goto _start; +} +} +default: +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_25, 1); +lean_inc(x_47); +lean_dec(x_25); +lean_inc(x_12); +x_48 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_47); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +if (lean_obj_tag(x_49) == 0) +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_dec(x_20); +x_50 = lean_ctor_get(x_48, 1); +lean_inc(x_50); +lean_dec(x_48); +x_51 = lean_unsigned_to_nat(1u); +x_52 = lean_nat_add(x_11, x_51); +lean_dec(x_11); +x_11 = x_52; +x_13 = x_50; +goto _start; +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; +x_54 = lean_ctor_get(x_48, 1); +lean_inc(x_54); +lean_dec(x_48); +x_55 = lean_ctor_get(x_49, 0); +lean_inc(x_55); +lean_dec(x_49); +x_56 = lean_unsigned_to_nat(1u); +x_57 = lean_nat_add(x_11, x_56); +lean_dec(x_11); +x_58 = !lean_is_exclusive(x_12); +if (x_58 == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_12, 2); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_55); +lean_ctor_set(x_60, 1, x_20); +x_61 = lean_array_push(x_59, x_60); +lean_ctor_set(x_12, 2, x_61); +x_11 = x_57; +x_13 = x_54; +goto _start; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_63 = lean_ctor_get(x_12, 0); +x_64 = lean_ctor_get(x_12, 1); +x_65 = lean_ctor_get(x_12, 2); +lean_inc(x_65); +lean_inc(x_64); +lean_inc(x_63); +lean_dec(x_12); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_20); +x_67 = lean_array_push(x_65, x_66); +x_68 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_64); +lean_ctor_set(x_68, 2, x_67); +x_11 = x_57; +x_12 = x_68; +x_13 = x_54; +goto _start; +} +} +} +else +{ +uint8_t x_70; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_70 = !lean_is_exclusive(x_48); +if (x_70 == 0) +{ +return x_48; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_48, 0); +x_72 = lean_ctor_get(x_48, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_48); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_71); +lean_ctor_set(x_73, 1, x_72); +return x_73; +} +} +} +} +} +else +{ +uint8_t x_74; +lean_dec(x_24); +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_25); +if (x_74 == 0) +{ +return x_25; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_25, 0); +x_76 = lean_ctor_get(x_25, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_25); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; +} +} +} +else +{ +uint8_t x_78; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_21); +if (x_78 == 0) +{ +return x_21; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_21, 0); +x_80 = lean_ctor_get(x_21, 1); +lean_inc(x_80); +lean_inc(x_79); +lean_dec(x_21); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_79); +lean_ctor_set(x_81, 1, x_80); +return x_81; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___boxed), 13, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; +lean_inc(x_5); +x_10 = l_Lean_mkFVar(x_5); +lean_inc(x_2); +x_11 = lean_array_push(x_2, x_10); +x_12 = lean_array_get_size(x_11); +lean_inc(x_11); +x_13 = lean_expr_instantiate_rev_range(x_4, x_3, x_12, x_11); +lean_dec(x_12); +x_14 = lean_array_get_size(x_6); +x_15 = lean_nat_dec_lt(x_7, x_14); +lean_dec(x_14); +if (x_15 == 0) +{ +lean_object* x_16; +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +x_16 = lean_apply_4(x_1, x_11, x_13, x_8, x_9); +return x_16; +} +else +{ +lean_object* x_17; lean_object* x_18; +lean_dec(x_13); +lean_dec(x_11); +x_17 = lean_array_fget(x_6, x_7); +lean_inc(x_8); +x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_8, x_9); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = l_Lean_LocalDecl_type(x_19); +lean_dec(x_19); +lean_inc(x_8); +lean_inc(x_21); +x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_8, x_20); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +switch (lean_obj_tag(x_23)) { +case 0: +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +lean_dec(x_21); +lean_dec(x_17); +x_24 = lean_ctor_get(x_22, 1); +lean_inc(x_24); +lean_dec(x_22); +x_25 = lean_unsigned_to_nat(1u); +x_26 = lean_nat_add(x_7, x_25); +lean_dec(x_7); +x_7 = x_26; +x_9 = x_24; +goto _start; +} +case 1: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; +lean_dec(x_21); +x_28 = lean_ctor_get(x_22, 1); +lean_inc(x_28); +lean_dec(x_22); +x_29 = lean_ctor_get(x_23, 0); +lean_inc(x_29); +lean_dec(x_23); +x_30 = lean_unsigned_to_nat(1u); +x_31 = lean_nat_add(x_7, x_30); +lean_dec(x_7); +x_32 = !lean_is_exclusive(x_8); +if (x_32 == 0) +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_8, 2); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_29); +lean_ctor_set(x_34, 1, x_17); +x_35 = lean_array_push(x_33, x_34); +lean_ctor_set(x_8, 2, x_35); +x_7 = x_31; +x_9 = x_28; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_37 = lean_ctor_get(x_8, 0); +x_38 = lean_ctor_get(x_8, 1); +x_39 = lean_ctor_get(x_8, 2); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_dec(x_8); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_17); +x_41 = lean_array_push(x_39, x_40); +x_42 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_38); +lean_ctor_set(x_42, 2, x_41); +x_7 = x_31; +x_8 = x_42; +x_9 = x_28; +goto _start; +} +} +default: +{ +lean_object* x_44; lean_object* x_45; +x_44 = lean_ctor_get(x_22, 1); +lean_inc(x_44); +lean_dec(x_22); +lean_inc(x_8); +x_45 = l_Lean_Meta_isClassExpensive___main(x_21, x_8, x_44); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_17); +x_47 = lean_ctor_get(x_45, 1); +lean_inc(x_47); +lean_dec(x_45); +x_48 = lean_unsigned_to_nat(1u); +x_49 = lean_nat_add(x_7, x_48); +lean_dec(x_7); +x_7 = x_49; +x_9 = x_47; +goto _start; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_51 = lean_ctor_get(x_45, 1); +lean_inc(x_51); +lean_dec(x_45); +x_52 = lean_ctor_get(x_46, 0); +lean_inc(x_52); +lean_dec(x_46); +x_53 = lean_unsigned_to_nat(1u); +x_54 = lean_nat_add(x_7, x_53); +lean_dec(x_7); +x_55 = !lean_is_exclusive(x_8); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_8, 2); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_52); +lean_ctor_set(x_57, 1, x_17); +x_58 = lean_array_push(x_56, x_57); +lean_ctor_set(x_8, 2, x_58); +x_7 = x_54; +x_9 = x_51; +goto _start; +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_60 = lean_ctor_get(x_8, 0); +x_61 = lean_ctor_get(x_8, 1); +x_62 = lean_ctor_get(x_8, 2); +lean_inc(x_62); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_8); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_52); +lean_ctor_set(x_63, 1, x_17); +x_64 = lean_array_push(x_62, x_63); +x_65 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_64); +x_7 = x_54; +x_8 = x_65; +x_9 = x_51; +goto _start; +} +} +} +else +{ +uint8_t x_67; +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_67 = !lean_is_exclusive(x_45); +if (x_67 == 0) +{ +return x_45; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_45, 0); +x_69 = lean_ctor_get(x_45, 1); +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_45); +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; +} +} +} +} +} +else +{ +uint8_t x_71; +lean_dec(x_21); +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_71 = !lean_is_exclusive(x_22); +if (x_71 == 0) +{ +return x_22; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_22, 0); +x_73 = lean_ctor_get(x_22, 1); +lean_inc(x_73); +lean_inc(x_72); +lean_dec(x_22); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_75 = !lean_is_exclusive(x_18); +if (x_75 == 0) +{ +return x_18; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_18, 0); +x_77 = lean_ctor_get(x_18, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_18); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg___boxed), 9, 0); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +if (lean_obj_tag(x_7) == 7) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; uint64_t x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_23 = lean_ctor_get(x_7, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_7, 1); +lean_inc(x_24); +x_25 = lean_ctor_get(x_7, 2); +lean_inc(x_25); +x_26 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); +lean_dec(x_7); +x_27 = lean_array_get_size(x_5); +lean_inc(x_5); +x_28 = lean_expr_instantiate_rev_range(x_24, x_6, x_27, x_5); +lean_dec(x_27); +lean_dec(x_24); +x_29 = l_Lean_Meta_mkFreshId___rarg(x_9); +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_29, 1); +lean_inc(x_31); +lean_dec(x_29); +x_32 = (uint8_t)((x_26 << 24) >> 61); +lean_inc(x_30); +x_33 = lean_local_ctx_mk_local_decl(x_4, x_30, x_23, x_28, x_32); +lean_inc(x_30); +x_34 = l_Lean_mkFVar(x_30); +lean_inc(x_5); +x_35 = lean_array_push(x_5, x_34); +if (lean_obj_tag(x_3) == 0) +{ +lean_dec(x_30); +lean_dec(x_5); +x_4 = x_33; +x_5 = x_35; +x_7 = x_25; +x_9 = x_31; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_37 = lean_ctor_get(x_3, 0); +lean_inc(x_37); +x_38 = lean_array_get_size(x_35); +x_39 = lean_nat_dec_lt(x_38, x_37); +lean_dec(x_37); +lean_dec(x_38); +if (x_39 == 0) +{ +uint8_t x_40; +lean_dec(x_3); +x_40 = !lean_is_exclusive(x_8); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_8, 1); +lean_dec(x_41); +lean_ctor_set(x_8, 1, x_33); +lean_inc(x_6); +x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_5, x_6, x_25, x_30, x_35, x_6, x_8, x_31); +lean_dec(x_35); +lean_dec(x_25); +lean_dec(x_6); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_8, 0); +x_44 = lean_ctor_get(x_8, 2); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_8); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_33); +lean_ctor_set(x_45, 2, x_44); +lean_inc(x_6); +x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_5, x_6, x_25, x_30, x_35, x_6, x_45, x_31); +lean_dec(x_35); +lean_dec(x_25); +lean_dec(x_6); +return x_46; +} +} +else +{ +lean_dec(x_30); +lean_dec(x_5); +x_4 = x_33; +x_5 = x_35; +x_7 = x_25; +x_9 = x_31; +goto _start; +} +} +} +else +{ +lean_object* x_48; +x_48 = lean_box(0); +x_10 = x_48; +goto block_22; +} +block_22: +{ +lean_object* x_11; lean_object* x_12; uint8_t x_13; +lean_dec(x_10); +x_11 = lean_array_get_size(x_5); +lean_inc(x_5); +x_12 = lean_expr_instantiate_rev_range(x_7, x_6, x_11, x_5); +x_13 = !lean_is_exclusive(x_8); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_8, 1); +lean_dec(x_14); +lean_inc(x_4); +lean_ctor_set(x_8, 1, x_4); +if (x_2 == 0) +{ +lean_object* x_15; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_6); +lean_inc(x_5); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_5, x_6, x_7, x_5, x_6, x_8, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_15; +} +else +{ +lean_object* x_16; +lean_inc(x_6); +lean_inc(x_5); +x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_8, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_8, 0); +x_18 = lean_ctor_get(x_8, 2); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_8); +lean_inc(x_4); +x_19 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_4); +lean_ctor_set(x_19, 2, x_18); +if (x_2 == 0) +{ +lean_object* x_20; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_6); +lean_inc(x_5); +x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_5, x_6, x_7, x_5, x_6, x_19, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_20; +} +else +{ +lean_object* x_21; +lean_inc(x_6); +lean_inc(x_5); +x_21 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_19, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_21; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg___boxed), 9, 0); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_2); +x_6 = l_Lean_Meta_whnf(x_2, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l_Lean_Expr_isForall(x_7); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_7); +lean_dec(x_3); +x_10 = l_Array_empty___closed__1; +x_11 = lean_apply_4(x_1, x_10, x_2, x_4, x_8); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +lean_dec(x_2); +x_12 = lean_ctor_get(x_8, 2); +lean_inc(x_12); +x_13 = lean_ctor_get(x_4, 1); +lean_inc(x_13); +x_14 = 1; +x_15 = l_Array_empty___closed__1; +x_16 = lean_unsigned_to_nat(0u); +x_17 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg(x_1, x_14, x_3, x_13, x_15, x_16, x_7, x_4, x_8); +if (lean_obj_tag(x_17) == 0) +{ +uint8_t x_18; +x_18 = !lean_is_exclusive(x_17); +if (x_18 == 0) +{ +lean_object* x_19; uint8_t x_20; +x_19 = lean_ctor_get(x_17, 1); +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_19, 2); +lean_dec(x_21); +lean_ctor_set(x_19, 2, x_12); +return x_17; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_22 = lean_ctor_get(x_19, 0); +x_23 = lean_ctor_get(x_19, 1); +x_24 = lean_ctor_get(x_19, 3); +x_25 = lean_ctor_get(x_19, 4); +x_26 = lean_ctor_get(x_19, 5); +lean_inc(x_26); +lean_inc(x_25); +lean_inc(x_24); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_19); +x_27 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_27, 0, x_22); +lean_ctor_set(x_27, 1, x_23); +lean_ctor_set(x_27, 2, x_12); +lean_ctor_set(x_27, 3, x_24); +lean_ctor_set(x_27, 4, x_25); +lean_ctor_set(x_27, 5, x_26); +lean_ctor_set(x_17, 1, x_27); +return x_17; +} +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_28 = lean_ctor_get(x_17, 1); +x_29 = lean_ctor_get(x_17, 0); +lean_inc(x_28); +lean_inc(x_29); +lean_dec(x_17); +x_30 = lean_ctor_get(x_28, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_28, 1); +lean_inc(x_31); +x_32 = lean_ctor_get(x_28, 3); +lean_inc(x_32); +x_33 = lean_ctor_get(x_28, 4); +lean_inc(x_33); +x_34 = lean_ctor_get(x_28, 5); +lean_inc(x_34); +if (lean_is_exclusive(x_28)) { + lean_ctor_release(x_28, 0); + lean_ctor_release(x_28, 1); + lean_ctor_release(x_28, 2); + lean_ctor_release(x_28, 3); + lean_ctor_release(x_28, 4); + lean_ctor_release(x_28, 5); + x_35 = x_28; +} else { + lean_dec_ref(x_28); + x_35 = lean_box(0); +} +if (lean_is_scalar(x_35)) { + x_36 = lean_alloc_ctor(0, 6, 0); +} else { + x_36 = x_35; +} +lean_ctor_set(x_36, 0, x_30); +lean_ctor_set(x_36, 1, x_31); +lean_ctor_set(x_36, 2, x_12); +lean_ctor_set(x_36, 3, x_32); +lean_ctor_set(x_36, 4, x_33); +lean_ctor_set(x_36, 5, x_34); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_29); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +else +{ +uint8_t x_38; +x_38 = !lean_is_exclusive(x_17); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_17, 1); +x_40 = !lean_is_exclusive(x_39); +if (x_40 == 0) +{ +lean_object* x_41; +x_41 = lean_ctor_get(x_39, 2); +lean_dec(x_41); +lean_ctor_set(x_39, 2, x_12); +return x_17; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_42 = lean_ctor_get(x_39, 0); +x_43 = lean_ctor_get(x_39, 1); +x_44 = lean_ctor_get(x_39, 3); +x_45 = lean_ctor_get(x_39, 4); +x_46 = lean_ctor_get(x_39, 5); +lean_inc(x_46); +lean_inc(x_45); +lean_inc(x_44); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_39); +x_47 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_47, 0, x_42); +lean_ctor_set(x_47, 1, x_43); +lean_ctor_set(x_47, 2, x_12); +lean_ctor_set(x_47, 3, x_44); +lean_ctor_set(x_47, 4, x_45); +lean_ctor_set(x_47, 5, x_46); +lean_ctor_set(x_17, 1, x_47); +return x_17; +} +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_48 = lean_ctor_get(x_17, 1); +x_49 = lean_ctor_get(x_17, 0); +lean_inc(x_48); +lean_inc(x_49); +lean_dec(x_17); +x_50 = lean_ctor_get(x_48, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_48, 1); +lean_inc(x_51); +x_52 = lean_ctor_get(x_48, 3); +lean_inc(x_52); +x_53 = lean_ctor_get(x_48, 4); +lean_inc(x_53); +x_54 = lean_ctor_get(x_48, 5); +lean_inc(x_54); +if (lean_is_exclusive(x_48)) { + lean_ctor_release(x_48, 0); + lean_ctor_release(x_48, 1); + lean_ctor_release(x_48, 2); + lean_ctor_release(x_48, 3); + lean_ctor_release(x_48, 4); + lean_ctor_release(x_48, 5); + x_55 = x_48; +} else { + lean_dec_ref(x_48); + x_55 = lean_box(0); +} +if (lean_is_scalar(x_55)) { + x_56 = lean_alloc_ctor(0, 6, 0); +} else { + x_56 = x_55; +} +lean_ctor_set(x_56, 0, x_50); +lean_ctor_set(x_56, 1, x_51); +lean_ctor_set(x_56, 2, x_12); +lean_ctor_set(x_56, 3, x_52); +lean_ctor_set(x_56, 4, x_53); +lean_ctor_set(x_56, 5, x_54); +x_57 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_57, 0, x_49); +lean_ctor_set(x_57, 1, x_56); +return x_57; +} +} +} +} +else +{ +uint8_t x_58; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_58 = !lean_is_exclusive(x_6); +if (x_58 == 0) +{ +return x_6; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_6, 0); +x_60 = lean_ctor_get(x_6, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_6); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set(x_61, 1, x_60); +return x_61; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1___rarg), 5, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_forallTelescopeReducing___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; +x_5 = lean_box(0); +x_6 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallTelescopeReducing___spec__1___rarg(x_2, x_1, x_5, x_3, x_4); +return x_6; +} +} +lean_object* l_Lean_Meta_forallTelescopeReducing(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_forallTelescopeReducing___rarg), 4, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +return x_9; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; lean_object* x_12; +x_11 = lean_unbox(x_4); +lean_dec(x_4); +x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___lambda__1(x_1, x_2, x_3, x_11, x_5, x_6, x_7, x_8, x_9, x_10); +return x_12; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +uint8_t x_14; lean_object* x_15; +x_14 = lean_unbox(x_2); +lean_dec(x_2); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__4___rarg(x_1, x_14, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_6); +return x_15; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallTelescopeReducing___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +return x_10; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallTelescopeReducing___spec__2___rarg(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +return x_11; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_9 = lean_array_get_size(x_2); +lean_inc(x_2); +x_10 = lean_expr_instantiate_rev_range(x_4, x_3, x_9, x_2); +lean_dec(x_9); +x_11 = lean_array_get_size(x_5); +x_12 = lean_nat_dec_lt(x_6, x_11); +lean_dec(x_11); +if (x_12 == 0) +{ +lean_object* x_13; +lean_dec(x_6); +x_13 = lean_apply_4(x_1, x_2, x_10, x_7, x_8); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_10); +x_14 = lean_array_fget(x_5, x_6); +lean_inc(x_7); +x_15 = l_Lean_Meta_getFVarLocalDecl(x_14, x_7, x_8); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +x_18 = l_Lean_LocalDecl_type(x_16); +lean_dec(x_16); +lean_inc(x_7); +lean_inc(x_18); +x_19 = l_Lean_Meta_isClassQuick___main(x_18, x_7, x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +switch (lean_obj_tag(x_20)) { +case 0: +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_dec(x_18); +lean_dec(x_14); +x_21 = lean_ctor_get(x_19, 1); +lean_inc(x_21); +lean_dec(x_19); +x_22 = lean_unsigned_to_nat(1u); +x_23 = lean_nat_add(x_6, x_22); +lean_dec(x_6); +x_6 = x_23; +x_8 = x_21; +goto _start; +} +case 1: +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; +lean_dec(x_18); +x_25 = lean_ctor_get(x_19, 1); +lean_inc(x_25); +lean_dec(x_19); +x_26 = lean_ctor_get(x_20, 0); +lean_inc(x_26); +lean_dec(x_20); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_6, x_27); +lean_dec(x_6); +x_29 = !lean_is_exclusive(x_7); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_7, 2); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_26); +lean_ctor_set(x_31, 1, x_14); +x_32 = lean_array_push(x_30, x_31); +lean_ctor_set(x_7, 2, x_32); +x_6 = x_28; +x_8 = x_25; +goto _start; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_34 = lean_ctor_get(x_7, 0); +x_35 = lean_ctor_get(x_7, 1); +x_36 = lean_ctor_get(x_7, 2); +lean_inc(x_36); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_7); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_26); +lean_ctor_set(x_37, 1, x_14); +x_38 = lean_array_push(x_36, x_37); +x_39 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_39, 0, x_34); +lean_ctor_set(x_39, 1, x_35); +lean_ctor_set(x_39, 2, x_38); +x_6 = x_28; +x_7 = x_39; +x_8 = x_25; +goto _start; +} +} +default: +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_19, 1); +lean_inc(x_41); +lean_dec(x_19); +lean_inc(x_7); +x_42 = l_Lean_Meta_isClassExpensive___main(x_18, x_7, x_41); +if (lean_obj_tag(x_42) == 0) +{ +lean_object* x_43; +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +lean_dec(x_14); +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +lean_dec(x_42); +x_45 = lean_unsigned_to_nat(1u); +x_46 = lean_nat_add(x_6, x_45); +lean_dec(x_6); +x_6 = x_46; +x_8 = x_44; +goto _start; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; uint8_t x_52; +x_48 = lean_ctor_get(x_42, 1); +lean_inc(x_48); +lean_dec(x_42); +x_49 = lean_ctor_get(x_43, 0); +lean_inc(x_49); +lean_dec(x_43); +x_50 = lean_unsigned_to_nat(1u); +x_51 = lean_nat_add(x_6, x_50); +lean_dec(x_6); +x_52 = !lean_is_exclusive(x_7); +if (x_52 == 0) +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_7, 2); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_49); +lean_ctor_set(x_54, 1, x_14); +x_55 = lean_array_push(x_53, x_54); +lean_ctor_set(x_7, 2, x_55); +x_6 = x_51; +x_8 = x_48; +goto _start; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_57 = lean_ctor_get(x_7, 0); +x_58 = lean_ctor_get(x_7, 1); +x_59 = lean_ctor_get(x_7, 2); +lean_inc(x_59); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_7); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_49); +lean_ctor_set(x_60, 1, x_14); +x_61 = lean_array_push(x_59, x_60); +x_62 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_58); +lean_ctor_set(x_62, 2, x_61); +x_6 = x_51; +x_7 = x_62; +x_8 = x_48; +goto _start; +} +} +} +else +{ +uint8_t x_64; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_64 = !lean_is_exclusive(x_42); +if (x_64 == 0) +{ +return x_42; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_42, 0); +x_66 = lean_ctor_get(x_42, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_42); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; +} +} +} +} +} +else +{ +uint8_t x_68; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_68 = !lean_is_exclusive(x_19); +if (x_68 == 0) +{ +return x_19; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_19, 0); +x_70 = lean_ctor_get(x_19, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_19); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +uint8_t x_72; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_72 = !lean_is_exclusive(x_15); +if (x_72 == 0) +{ +return x_15; +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_73 = lean_ctor_get(x_15, 0); +x_74 = lean_ctor_get(x_15, 1); +lean_inc(x_74); +lean_inc(x_73); +lean_dec(x_15); +x_75 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +return x_75; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg___boxed), 8, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; +x_11 = l_Lean_Expr_isForall(x_8); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_12 = lean_apply_4(x_1, x_2, x_3, x_9, x_10); +return x_12; +} +else +{ +lean_object* x_13; +lean_dec(x_3); +x_13 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg(x_1, x_4, x_5, x_6, x_2, x_7, x_8, x_9, x_10); +return x_13; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; +lean_inc(x_9); +x_14 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_14, 0, x_9); +x_15 = lean_box(x_2); +lean_inc(x_8); +lean_inc(x_4); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_5); +lean_inc(x_1); +x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___lambda__1___boxed), 10, 7); +lean_closure_set(x_16, 0, x_1); +lean_closure_set(x_16, 1, x_5); +lean_closure_set(x_16, 2, x_9); +lean_closure_set(x_16, 3, x_15); +lean_closure_set(x_16, 4, x_3); +lean_closure_set(x_16, 5, x_4); +lean_closure_set(x_16, 6, x_8); +x_17 = lean_array_get_size(x_10); +x_18 = lean_nat_dec_lt(x_11, x_17); +lean_dec(x_17); +if (x_18 == 0) +{ +lean_object* x_19; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_19 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_14, x_16, x_12, x_13); +return x_19; +} +else +{ +lean_object* x_20; lean_object* x_21; +lean_dec(x_16); +lean_dec(x_14); +x_20 = lean_array_fget(x_10, x_11); +lean_inc(x_12); +x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_12, x_13); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_21, 1); +lean_inc(x_23); +lean_dec(x_21); +x_24 = l_Lean_LocalDecl_type(x_22); +lean_dec(x_22); +lean_inc(x_12); +lean_inc(x_24); +x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_12, x_23); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +switch (lean_obj_tag(x_26)) { +case 0: +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_dec(x_24); +lean_dec(x_20); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_11, x_28); +lean_dec(x_11); +x_11 = x_29; +x_13 = x_27; +goto _start; +} +case 1: +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 1); +lean_inc(x_31); +lean_dec(x_25); +x_32 = lean_ctor_get(x_26, 0); +lean_inc(x_32); +lean_dec(x_26); +x_33 = lean_unsigned_to_nat(1u); +x_34 = lean_nat_add(x_11, x_33); +lean_dec(x_11); +x_35 = !lean_is_exclusive(x_12); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_12, 2); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_32); +lean_ctor_set(x_37, 1, x_20); +x_38 = lean_array_push(x_36, x_37); +lean_ctor_set(x_12, 2, x_38); +x_11 = x_34; +x_13 = x_31; +goto _start; +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_40 = lean_ctor_get(x_12, 0); +x_41 = lean_ctor_get(x_12, 1); +x_42 = lean_ctor_get(x_12, 2); +lean_inc(x_42); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_12); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_32); +lean_ctor_set(x_43, 1, x_20); +x_44 = lean_array_push(x_42, x_43); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_40); +lean_ctor_set(x_45, 1, x_41); +lean_ctor_set(x_45, 2, x_44); +x_11 = x_34; +x_12 = x_45; +x_13 = x_31; +goto _start; +} +} +default: +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_25, 1); +lean_inc(x_47); +lean_dec(x_25); +lean_inc(x_12); +x_48 = l_Lean_Meta_isClassExpensive___main(x_24, x_12, x_47); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +if (lean_obj_tag(x_49) == 0) +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_dec(x_20); +x_50 = lean_ctor_get(x_48, 1); +lean_inc(x_50); +lean_dec(x_48); +x_51 = lean_unsigned_to_nat(1u); +x_52 = lean_nat_add(x_11, x_51); +lean_dec(x_11); +x_11 = x_52; +x_13 = x_50; +goto _start; +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; +x_54 = lean_ctor_get(x_48, 1); +lean_inc(x_54); +lean_dec(x_48); +x_55 = lean_ctor_get(x_49, 0); +lean_inc(x_55); +lean_dec(x_49); +x_56 = lean_unsigned_to_nat(1u); +x_57 = lean_nat_add(x_11, x_56); +lean_dec(x_11); +x_58 = !lean_is_exclusive(x_12); +if (x_58 == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_12, 2); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_55); +lean_ctor_set(x_60, 1, x_20); +x_61 = lean_array_push(x_59, x_60); +lean_ctor_set(x_12, 2, x_61); +x_11 = x_57; +x_13 = x_54; +goto _start; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_63 = lean_ctor_get(x_12, 0); +x_64 = lean_ctor_get(x_12, 1); +x_65 = lean_ctor_get(x_12, 2); +lean_inc(x_65); +lean_inc(x_64); +lean_inc(x_63); +lean_dec(x_12); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_55); +lean_ctor_set(x_66, 1, x_20); +x_67 = lean_array_push(x_65, x_66); +x_68 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_68, 0, x_63); +lean_ctor_set(x_68, 1, x_64); +lean_ctor_set(x_68, 2, x_67); +x_11 = x_57; +x_12 = x_68; +x_13 = x_54; +goto _start; +} +} +} +else +{ +uint8_t x_70; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_70 = !lean_is_exclusive(x_48); +if (x_70 == 0) +{ +return x_48; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_48, 0); +x_72 = lean_ctor_get(x_48, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_48); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_71); +lean_ctor_set(x_73, 1, x_72); +return x_73; +} +} +} +} +} +else +{ +uint8_t x_74; +lean_dec(x_24); +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_25); +if (x_74 == 0) +{ +return x_25; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_25, 0); +x_76 = lean_ctor_get(x_25, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_25); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; +} +} +} +else +{ +uint8_t x_78; +lean_dec(x_20); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_21); +if (x_78 == 0) +{ +return x_21; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_21, 0); +x_80 = lean_ctor_get(x_21, 1); +lean_inc(x_80); +lean_inc(x_79); +lean_dec(x_21); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_79); +lean_ctor_set(x_81, 1, x_80); +return x_81; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___boxed), 13, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; uint8_t x_15; +lean_inc(x_5); +x_10 = l_Lean_mkFVar(x_5); +lean_inc(x_2); +x_11 = lean_array_push(x_2, x_10); +x_12 = lean_array_get_size(x_11); +lean_inc(x_11); +x_13 = lean_expr_instantiate_rev_range(x_4, x_3, x_12, x_11); +lean_dec(x_12); +x_14 = lean_array_get_size(x_6); +x_15 = lean_nat_dec_lt(x_7, x_14); +lean_dec(x_14); +if (x_15 == 0) +{ +lean_object* x_16; +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +x_16 = lean_apply_4(x_1, x_11, x_13, x_8, x_9); +return x_16; +} +else +{ +lean_object* x_17; lean_object* x_18; +lean_dec(x_13); +lean_dec(x_11); +x_17 = lean_array_fget(x_6, x_7); +lean_inc(x_8); +x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_8, x_9); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = l_Lean_LocalDecl_type(x_19); +lean_dec(x_19); +lean_inc(x_8); +lean_inc(x_21); +x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_8, x_20); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +switch (lean_obj_tag(x_23)) { +case 0: +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +lean_dec(x_21); +lean_dec(x_17); +x_24 = lean_ctor_get(x_22, 1); +lean_inc(x_24); +lean_dec(x_22); +x_25 = lean_unsigned_to_nat(1u); +x_26 = lean_nat_add(x_7, x_25); +lean_dec(x_7); +x_7 = x_26; +x_9 = x_24; +goto _start; +} +case 1: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; +lean_dec(x_21); +x_28 = lean_ctor_get(x_22, 1); +lean_inc(x_28); +lean_dec(x_22); +x_29 = lean_ctor_get(x_23, 0); +lean_inc(x_29); +lean_dec(x_23); +x_30 = lean_unsigned_to_nat(1u); +x_31 = lean_nat_add(x_7, x_30); +lean_dec(x_7); +x_32 = !lean_is_exclusive(x_8); +if (x_32 == 0) +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_8, 2); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_29); +lean_ctor_set(x_34, 1, x_17); +x_35 = lean_array_push(x_33, x_34); +lean_ctor_set(x_8, 2, x_35); +x_7 = x_31; +x_9 = x_28; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_37 = lean_ctor_get(x_8, 0); +x_38 = lean_ctor_get(x_8, 1); +x_39 = lean_ctor_get(x_8, 2); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_dec(x_8); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_17); +x_41 = lean_array_push(x_39, x_40); +x_42 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_38); +lean_ctor_set(x_42, 2, x_41); +x_7 = x_31; +x_8 = x_42; +x_9 = x_28; +goto _start; +} +} +default: +{ +lean_object* x_44; lean_object* x_45; +x_44 = lean_ctor_get(x_22, 1); +lean_inc(x_44); +lean_dec(x_22); +lean_inc(x_8); +x_45 = l_Lean_Meta_isClassExpensive___main(x_21, x_8, x_44); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_17); +x_47 = lean_ctor_get(x_45, 1); +lean_inc(x_47); +lean_dec(x_45); +x_48 = lean_unsigned_to_nat(1u); +x_49 = lean_nat_add(x_7, x_48); +lean_dec(x_7); +x_7 = x_49; +x_9 = x_47; +goto _start; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_51 = lean_ctor_get(x_45, 1); +lean_inc(x_51); +lean_dec(x_45); +x_52 = lean_ctor_get(x_46, 0); +lean_inc(x_52); +lean_dec(x_46); +x_53 = lean_unsigned_to_nat(1u); +x_54 = lean_nat_add(x_7, x_53); +lean_dec(x_7); +x_55 = !lean_is_exclusive(x_8); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_8, 2); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_52); +lean_ctor_set(x_57, 1, x_17); +x_58 = lean_array_push(x_56, x_57); +lean_ctor_set(x_8, 2, x_58); +x_7 = x_54; +x_9 = x_51; +goto _start; +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_60 = lean_ctor_get(x_8, 0); +x_61 = lean_ctor_get(x_8, 1); +x_62 = lean_ctor_get(x_8, 2); +lean_inc(x_62); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_8); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_52); +lean_ctor_set(x_63, 1, x_17); +x_64 = lean_array_push(x_62, x_63); +x_65 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_64); +x_7 = x_54; +x_8 = x_65; +x_9 = x_51; +goto _start; +} +} +} +else +{ +uint8_t x_67; +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_67 = !lean_is_exclusive(x_45); +if (x_67 == 0) +{ +return x_45; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_45, 0); +x_69 = lean_ctor_get(x_45, 1); +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_45); +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; +} +} +} +} +} +else +{ +uint8_t x_71; +lean_dec(x_21); +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_71 = !lean_is_exclusive(x_22); +if (x_71 == 0) +{ +return x_22; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_22, 0); +x_73 = lean_ctor_get(x_22, 1); +lean_inc(x_73); +lean_inc(x_72); +lean_dec(x_22); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_17); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_75 = !lean_is_exclusive(x_18); +if (x_75 == 0) +{ +return x_18; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_18, 0); +x_77 = lean_ctor_get(x_18, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_18); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg___boxed), 9, 0); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +if (lean_obj_tag(x_7) == 7) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; uint64_t x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_23 = lean_ctor_get(x_7, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_7, 1); +lean_inc(x_24); +x_25 = lean_ctor_get(x_7, 2); +lean_inc(x_25); +x_26 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); +lean_dec(x_7); +x_27 = lean_array_get_size(x_5); +lean_inc(x_5); +x_28 = lean_expr_instantiate_rev_range(x_24, x_6, x_27, x_5); +lean_dec(x_27); +lean_dec(x_24); +x_29 = l_Lean_Meta_mkFreshId___rarg(x_9); +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_29, 1); +lean_inc(x_31); +lean_dec(x_29); +x_32 = (uint8_t)((x_26 << 24) >> 61); +lean_inc(x_30); +x_33 = lean_local_ctx_mk_local_decl(x_4, x_30, x_23, x_28, x_32); +lean_inc(x_30); +x_34 = l_Lean_mkFVar(x_30); +lean_inc(x_5); +x_35 = lean_array_push(x_5, x_34); +if (lean_obj_tag(x_3) == 0) +{ +lean_dec(x_30); +lean_dec(x_5); +x_4 = x_33; +x_5 = x_35; +x_7 = x_25; +x_9 = x_31; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_37 = lean_ctor_get(x_3, 0); +lean_inc(x_37); +x_38 = lean_array_get_size(x_35); +x_39 = lean_nat_dec_lt(x_38, x_37); +lean_dec(x_37); +lean_dec(x_38); +if (x_39 == 0) +{ +uint8_t x_40; +lean_dec(x_3); +x_40 = !lean_is_exclusive(x_8); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_8, 1); +lean_dec(x_41); +lean_ctor_set(x_8, 1, x_33); +lean_inc(x_6); +x_42 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_5, x_6, x_25, x_30, x_35, x_6, x_8, x_31); +lean_dec(x_35); +lean_dec(x_25); +lean_dec(x_6); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_8, 0); +x_44 = lean_ctor_get(x_8, 2); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_8); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_33); +lean_ctor_set(x_45, 2, x_44); +lean_inc(x_6); +x_46 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_5, x_6, x_25, x_30, x_35, x_6, x_45, x_31); +lean_dec(x_35); +lean_dec(x_25); +lean_dec(x_6); +return x_46; +} +} +else +{ +lean_dec(x_30); +lean_dec(x_5); +x_4 = x_33; +x_5 = x_35; +x_7 = x_25; +x_9 = x_31; +goto _start; +} +} +} +else +{ +lean_object* x_48; +x_48 = lean_box(0); +x_10 = x_48; +goto block_22; +} +block_22: +{ +lean_object* x_11; lean_object* x_12; uint8_t x_13; +lean_dec(x_10); +x_11 = lean_array_get_size(x_5); +lean_inc(x_5); +x_12 = lean_expr_instantiate_rev_range(x_7, x_6, x_11, x_5); +x_13 = !lean_is_exclusive(x_8); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_8, 1); +lean_dec(x_14); +lean_inc(x_4); +lean_ctor_set(x_8, 1, x_4); +if (x_2 == 0) +{ +lean_object* x_15; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_6); +lean_inc(x_5); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_5, x_6, x_7, x_5, x_6, x_8, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_15; +} +else +{ +lean_object* x_16; +lean_inc(x_6); +lean_inc(x_5); +x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_8, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_8, 0); +x_18 = lean_ctor_get(x_8, 2); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_8); +lean_inc(x_4); +x_19 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_4); +lean_ctor_set(x_19, 2, x_18); +if (x_2 == 0) +{ +lean_object* x_20; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_4); +lean_dec(x_3); +lean_inc(x_6); +lean_inc(x_5); +x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_5, x_6, x_7, x_5, x_6, x_19, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_20; +} +else +{ +lean_object* x_21; +lean_inc(x_6); +lean_inc(x_5); +x_21 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_19, x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +return x_21; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg___boxed), 9, 0); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallBoundedTelescope___spec__1___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_2); +x_6 = l_Lean_Meta_whnf(x_2, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l_Lean_Expr_isForall(x_7); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_7); +lean_dec(x_3); +x_10 = l_Array_empty___closed__1; +x_11 = lean_apply_4(x_1, x_10, x_2, x_4, x_8); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +lean_dec(x_2); +x_12 = lean_ctor_get(x_8, 2); +lean_inc(x_12); +x_13 = lean_ctor_get(x_4, 1); +lean_inc(x_13); +x_14 = 1; +x_15 = l_Array_empty___closed__1; +x_16 = lean_unsigned_to_nat(0u); +x_17 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg(x_1, x_14, x_3, x_13, x_15, x_16, x_7, x_4, x_8); +if (lean_obj_tag(x_17) == 0) +{ +uint8_t x_18; +x_18 = !lean_is_exclusive(x_17); +if (x_18 == 0) +{ +lean_object* x_19; uint8_t x_20; +x_19 = lean_ctor_get(x_17, 1); +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_19, 2); +lean_dec(x_21); +lean_ctor_set(x_19, 2, x_12); +return x_17; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_22 = lean_ctor_get(x_19, 0); +x_23 = lean_ctor_get(x_19, 1); +x_24 = lean_ctor_get(x_19, 3); +x_25 = lean_ctor_get(x_19, 4); +x_26 = lean_ctor_get(x_19, 5); +lean_inc(x_26); +lean_inc(x_25); +lean_inc(x_24); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_19); +x_27 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_27, 0, x_22); +lean_ctor_set(x_27, 1, x_23); +lean_ctor_set(x_27, 2, x_12); +lean_ctor_set(x_27, 3, x_24); +lean_ctor_set(x_27, 4, x_25); +lean_ctor_set(x_27, 5, x_26); +lean_ctor_set(x_17, 1, x_27); +return x_17; +} +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_28 = lean_ctor_get(x_17, 1); +x_29 = lean_ctor_get(x_17, 0); +lean_inc(x_28); +lean_inc(x_29); +lean_dec(x_17); +x_30 = lean_ctor_get(x_28, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_28, 1); +lean_inc(x_31); +x_32 = lean_ctor_get(x_28, 3); +lean_inc(x_32); +x_33 = lean_ctor_get(x_28, 4); +lean_inc(x_33); +x_34 = lean_ctor_get(x_28, 5); +lean_inc(x_34); +if (lean_is_exclusive(x_28)) { + lean_ctor_release(x_28, 0); + lean_ctor_release(x_28, 1); + lean_ctor_release(x_28, 2); + lean_ctor_release(x_28, 3); + lean_ctor_release(x_28, 4); + lean_ctor_release(x_28, 5); + x_35 = x_28; +} else { + lean_dec_ref(x_28); + x_35 = lean_box(0); +} +if (lean_is_scalar(x_35)) { + x_36 = lean_alloc_ctor(0, 6, 0); +} else { + x_36 = x_35; +} +lean_ctor_set(x_36, 0, x_30); +lean_ctor_set(x_36, 1, x_31); +lean_ctor_set(x_36, 2, x_12); +lean_ctor_set(x_36, 3, x_32); +lean_ctor_set(x_36, 4, x_33); +lean_ctor_set(x_36, 5, x_34); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_29); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +else +{ +uint8_t x_38; +x_38 = !lean_is_exclusive(x_17); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +x_39 = lean_ctor_get(x_17, 1); +x_40 = !lean_is_exclusive(x_39); +if (x_40 == 0) +{ +lean_object* x_41; +x_41 = lean_ctor_get(x_39, 2); +lean_dec(x_41); +lean_ctor_set(x_39, 2, x_12); +return x_17; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_42 = lean_ctor_get(x_39, 0); +x_43 = lean_ctor_get(x_39, 1); +x_44 = lean_ctor_get(x_39, 3); +x_45 = lean_ctor_get(x_39, 4); +x_46 = lean_ctor_get(x_39, 5); +lean_inc(x_46); +lean_inc(x_45); +lean_inc(x_44); +lean_inc(x_43); +lean_inc(x_42); +lean_dec(x_39); +x_47 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_47, 0, x_42); +lean_ctor_set(x_47, 1, x_43); +lean_ctor_set(x_47, 2, x_12); +lean_ctor_set(x_47, 3, x_44); +lean_ctor_set(x_47, 4, x_45); +lean_ctor_set(x_47, 5, x_46); +lean_ctor_set(x_17, 1, x_47); +return x_17; +} +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_48 = lean_ctor_get(x_17, 1); +x_49 = lean_ctor_get(x_17, 0); +lean_inc(x_48); +lean_inc(x_49); +lean_dec(x_17); +x_50 = lean_ctor_get(x_48, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_48, 1); +lean_inc(x_51); +x_52 = lean_ctor_get(x_48, 3); +lean_inc(x_52); +x_53 = lean_ctor_get(x_48, 4); +lean_inc(x_53); +x_54 = lean_ctor_get(x_48, 5); +lean_inc(x_54); +if (lean_is_exclusive(x_48)) { + lean_ctor_release(x_48, 0); + lean_ctor_release(x_48, 1); + lean_ctor_release(x_48, 2); + lean_ctor_release(x_48, 3); + lean_ctor_release(x_48, 4); + lean_ctor_release(x_48, 5); + x_55 = x_48; +} else { + lean_dec_ref(x_48); + x_55 = lean_box(0); +} +if (lean_is_scalar(x_55)) { + x_56 = lean_alloc_ctor(0, 6, 0); +} else { + x_56 = x_55; +} +lean_ctor_set(x_56, 0, x_50); +lean_ctor_set(x_56, 1, x_51); +lean_ctor_set(x_56, 2, x_12); +lean_ctor_set(x_56, 3, x_52); +lean_ctor_set(x_56, 4, x_53); +lean_ctor_set(x_56, 5, x_54); +x_57 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_57, 0, x_49); +lean_ctor_set(x_57, 1, x_56); +return x_57; +} +} +} +} +else +{ +uint8_t x_58; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_58 = !lean_is_exclusive(x_6); +if (x_58 == 0) +{ +return x_6; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_6, 0); +x_60 = lean_ctor_get(x_6, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_6); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set(x_61, 1, x_60); +return x_61; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallBoundedTelescope___spec__1(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallBoundedTelescope___spec__1___rarg), 5, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_forallBoundedTelescope___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_forallBoundedTelescope___spec__1___rarg(x_3, x_1, x_2, x_4, x_5); +return x_6; +} +} +lean_object* l_Lean_Meta_forallBoundedTelescope(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_forallBoundedTelescope___rarg), 5, 0); +return x_2; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__3___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +return x_9; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; lean_object* x_12; +x_11 = lean_unbox(x_4); +lean_dec(x_4); +x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___lambda__1(x_1, x_2, x_3, x_11, x_5, x_6, x_7, x_8, x_9, x_10); +return x_12; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +_start: +{ +uint8_t x_14; lean_object* x_15; +x_14 = lean_unbox(x_2); +lean_dec(x_2); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__4___rarg(x_1, x_14, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_6); +return x_15; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_forallBoundedTelescope___spec__5___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +return x_10; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_forallBoundedTelescope___spec__2___rarg(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +return x_11; +} +} +lean_object* l_Lean_Meta_isClass(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +lean_inc(x_2); +lean_inc(x_1); +x_4 = l_Lean_Meta_isClassQuick___main(x_1, x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_5; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +switch (lean_obj_tag(x_5)) { +case 0: +{ +uint8_t x_6; +lean_dec(x_2); +lean_dec(x_1); +x_6 = !lean_is_exclusive(x_4); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; +x_7 = lean_ctor_get(x_4, 0); +lean_dec(x_7); +x_8 = lean_box(0); +lean_ctor_set(x_4, 0, x_8); +return x_4; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_4, 1); +lean_inc(x_9); +lean_dec(x_4); +x_10 = lean_box(0); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_9); +return x_11; +} +} +case 1: +{ +uint8_t x_12; +lean_dec(x_2); +lean_dec(x_1); +x_12 = !lean_is_exclusive(x_4); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_4, 0); +lean_dec(x_13); +x_14 = lean_ctor_get(x_5, 0); +lean_inc(x_14); +lean_dec(x_5); +x_15 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_4, 0, x_15); +return x_4; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_4, 1); +lean_inc(x_16); +lean_dec(x_4); +x_17 = lean_ctor_get(x_5, 0); +lean_inc(x_17); +lean_dec(x_5); +x_18 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_18, 0, x_17); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_18); +lean_ctor_set(x_19, 1, x_16); +return x_19; +} +} +default: +{ +lean_object* x_20; lean_object* x_21; +x_20 = lean_ctor_get(x_4, 1); +lean_inc(x_20); +lean_dec(x_4); +x_21 = l_Lean_Meta_isClassExpensive___main(x_1, x_2, x_20); +return x_21; +} +} +} +else +{ +uint8_t x_22; +lean_dec(x_2); +lean_dec(x_1); +x_22 = !lean_is_exclusive(x_4); +if (x_22 == 0) +{ +return x_4; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_4, 0); +x_24 = lean_ctor_get(x_4, 1); +lean_inc(x_24); +lean_inc(x_23); +lean_dec(x_4); +x_25 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_24); +return x_25; +} +} +} +} +lean_object* _init_l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive), 3, 0); +return x_1; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +switch (lean_obj_tag(x_5)) { +case 6: +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_22 = lean_ctor_get(x_5, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_5, 1); +lean_inc(x_23); +x_24 = lean_ctor_get(x_5, 2); +lean_inc(x_24); +x_25 = lean_ctor_get_uint64(x_5, sizeof(void*)*3); +lean_dec(x_5); +x_26 = lean_array_get_size(x_3); +lean_inc(x_3); +x_27 = lean_expr_instantiate_rev_range(x_23, x_4, x_26, x_3); +lean_dec(x_26); +lean_dec(x_23); +x_28 = l_Lean_Meta_mkFreshId___rarg(x_7); +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = (uint8_t)((x_25 << 24) >> 61); +lean_inc(x_29); +x_32 = lean_local_ctx_mk_local_decl(x_2, x_29, x_22, x_27, x_31); +x_33 = l_Lean_mkFVar(x_29); +x_34 = lean_array_push(x_3, x_33); +x_2 = x_32; +x_3 = x_34; +x_5 = x_24; +x_7 = x_30; +goto _start; +} case 8: { lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_36 = lean_ctor_get(x_6, 0); +x_36 = lean_ctor_get(x_5, 0); lean_inc(x_36); -x_37 = lean_ctor_get(x_6, 1); +x_37 = lean_ctor_get(x_5, 1); lean_inc(x_37); -x_38 = lean_ctor_get(x_6, 2); +x_38 = lean_ctor_get(x_5, 2); lean_inc(x_38); -x_39 = lean_ctor_get(x_6, 3); +x_39 = lean_ctor_get(x_5, 3); lean_inc(x_39); -lean_dec(x_6); -x_40 = lean_array_get_size(x_4); -lean_inc(x_4); -x_41 = lean_expr_instantiate_rev_range(x_37, x_5, x_40, x_4); +lean_dec(x_5); +x_40 = lean_array_get_size(x_3); +lean_inc(x_3); +x_41 = lean_expr_instantiate_rev_range(x_37, x_4, x_40, x_3); lean_dec(x_37); -lean_inc(x_4); -x_42 = lean_expr_instantiate_rev_range(x_38, x_5, x_40, x_4); +lean_inc(x_3); +x_42 = lean_expr_instantiate_rev_range(x_38, x_4, x_40, x_3); lean_dec(x_40); lean_dec(x_38); -x_43 = l_Lean_Meta_mkFreshId___rarg(x_8); +x_43 = l_Lean_Meta_mkFreshId___rarg(x_7); x_44 = lean_ctor_get(x_43, 0); lean_inc(x_44); x_45 = lean_ctor_get(x_43, 1); lean_inc(x_45); lean_dec(x_43); lean_inc(x_44); -x_46 = lean_local_ctx_mk_let_decl(x_3, x_44, x_36, x_41, x_42); +x_46 = lean_local_ctx_mk_let_decl(x_2, x_44, x_36, x_41, x_42); x_47 = l_Lean_mkFVar(x_44); -x_48 = lean_array_push(x_4, x_47); -x_3 = x_46; -x_4 = x_48; -x_6 = x_39; -x_8 = x_45; +x_48 = lean_array_push(x_3, x_47); +x_2 = x_46; +x_3 = x_48; +x_5 = x_39; +x_7 = x_45; goto _start; } default: { lean_object* x_50; x_50 = lean_box(0); -x_9 = x_50; +x_8 = x_50; goto block_21; } } block_21: { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +lean_dec(x_8); +x_9 = lean_array_get_size(x_3); +lean_inc(x_3); +x_10 = lean_expr_instantiate_rev_range(x_5, x_4, x_9, x_3); lean_dec(x_9); -x_10 = lean_array_get_size(x_4); -lean_inc(x_4); -x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); -lean_dec(x_10); -lean_dec(x_6); -x_12 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive), 4, 1); -lean_closure_set(x_12, 0, x_1); -lean_inc(x_4); -x_13 = lean_apply_2(x_2, x_4, x_11); -x_14 = !lean_is_exclusive(x_7); -if (x_14 == 0) +lean_dec(x_5); +lean_inc(x_3); +x_11 = lean_apply_2(x_1, x_3, x_10); +x_12 = !lean_is_exclusive(x_6); +if (x_12 == 0) { -lean_object* x_15; lean_object* x_16; -x_15 = lean_ctor_get(x_7, 1); -lean_dec(x_15); -lean_ctor_set(x_7, 1, x_3); -x_16 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_12, x_4, x_5, x_13, x_7, x_8); -lean_dec(x_4); -return x_16; +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_6, 1); +lean_dec(x_13); +lean_ctor_set(x_6, 1, x_2); +x_14 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1; +x_15 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_14, x_3, x_4, x_11, x_6, x_7); +lean_dec(x_3); +return x_15; } else { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_17 = lean_ctor_get(x_7, 0); -x_18 = lean_ctor_get(x_7, 2); -lean_inc(x_18); +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_16 = lean_ctor_get(x_6, 0); +x_17 = lean_ctor_get(x_6, 2); lean_inc(x_17); -lean_dec(x_7); -x_19 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_3); -lean_ctor_set(x_19, 2, x_18); -x_20 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_12, x_4, x_5, x_13, x_19, x_8); -lean_dec(x_4); +lean_inc(x_16); +lean_dec(x_6); +x_18 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_2); +lean_ctor_set(x_18, 2, x_17); +x_19 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1; +x_20 = l_Lean_Meta_withNewLocalInstances___main___rarg(x_19, x_3, x_4, x_11, x_18, x_7); +lean_dec(x_3); return x_20; } } @@ -6760,213 +12243,213 @@ lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main(lean_ _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg), 8, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg), 7, 0); return x_2; } } -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_9; -x_9 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_9; +lean_object* x_8; +x_8 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +return x_8; } } lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___rarg), 8, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___rarg), 7, 0); return x_2; } } -lean_object* l_Lean_Meta_lambdaTelescope___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Lean_Meta_lambdaTelescope___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_6 = lean_ctor_get(x_5, 2); +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_5 = lean_ctor_get(x_4, 2); +lean_inc(x_5); +x_6 = lean_ctor_get(x_3, 1); lean_inc(x_6); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -x_8 = l_Array_empty___closed__1; -x_9 = lean_unsigned_to_nat(0u); -x_10 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(x_1, x_3, x_7, x_8, x_9, x_2, x_4, x_5); -if (lean_obj_tag(x_10) == 0) +x_7 = l_Array_empty___closed__1; +x_8 = lean_unsigned_to_nat(0u); +x_9 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg(x_2, x_6, x_7, x_8, x_1, x_3, x_4); +if (lean_obj_tag(x_9) == 0) { -uint8_t x_11; -x_11 = !lean_is_exclusive(x_10); -if (x_11 == 0) +uint8_t x_10; +x_10 = !lean_is_exclusive(x_9); +if (x_10 == 0) { -lean_object* x_12; uint8_t x_13; -x_12 = lean_ctor_get(x_10, 1); -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) +lean_object* x_11; uint8_t x_12; +x_11 = lean_ctor_get(x_9, 1); +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) { -lean_object* x_14; -x_14 = lean_ctor_get(x_12, 2); -lean_dec(x_14); -lean_ctor_set(x_12, 2, x_6); -return x_10; +lean_object* x_13; +x_13 = lean_ctor_get(x_11, 2); +lean_dec(x_13); +lean_ctor_set(x_11, 2, x_5); +return x_9; } else { -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_15 = lean_ctor_get(x_12, 0); -x_16 = lean_ctor_get(x_12, 1); -x_17 = lean_ctor_get(x_12, 3); -x_18 = lean_ctor_get(x_12, 4); -x_19 = lean_ctor_get(x_12, 5); -lean_inc(x_19); +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_14 = lean_ctor_get(x_11, 0); +x_15 = lean_ctor_get(x_11, 1); +x_16 = lean_ctor_get(x_11, 3); +x_17 = lean_ctor_get(x_11, 4); +x_18 = lean_ctor_get(x_11, 5); lean_inc(x_18); lean_inc(x_17); lean_inc(x_16); lean_inc(x_15); -lean_dec(x_12); -x_20 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_20, 0, x_15); -lean_ctor_set(x_20, 1, x_16); -lean_ctor_set(x_20, 2, x_6); -lean_ctor_set(x_20, 3, x_17); -lean_ctor_set(x_20, 4, x_18); -lean_ctor_set(x_20, 5, x_19); -lean_ctor_set(x_10, 1, x_20); -return x_10; +lean_inc(x_14); +lean_dec(x_11); +x_19 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_19, 0, x_14); +lean_ctor_set(x_19, 1, x_15); +lean_ctor_set(x_19, 2, x_5); +lean_ctor_set(x_19, 3, x_16); +lean_ctor_set(x_19, 4, x_17); +lean_ctor_set(x_19, 5, x_18); +lean_ctor_set(x_9, 1, x_19); +return x_9; } } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_21 = lean_ctor_get(x_10, 1); -x_22 = lean_ctor_get(x_10, 0); +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_20 = lean_ctor_get(x_9, 1); +x_21 = lean_ctor_get(x_9, 0); +lean_inc(x_20); lean_inc(x_21); +lean_dec(x_9); +x_22 = lean_ctor_get(x_20, 0); lean_inc(x_22); -lean_dec(x_10); -x_23 = lean_ctor_get(x_21, 0); +x_23 = lean_ctor_get(x_20, 1); lean_inc(x_23); -x_24 = lean_ctor_get(x_21, 1); +x_24 = lean_ctor_get(x_20, 3); lean_inc(x_24); -x_25 = lean_ctor_get(x_21, 3); +x_25 = lean_ctor_get(x_20, 4); lean_inc(x_25); -x_26 = lean_ctor_get(x_21, 4); +x_26 = lean_ctor_get(x_20, 5); lean_inc(x_26); -x_27 = lean_ctor_get(x_21, 5); -lean_inc(x_27); -if (lean_is_exclusive(x_21)) { - lean_ctor_release(x_21, 0); - lean_ctor_release(x_21, 1); - lean_ctor_release(x_21, 2); - lean_ctor_release(x_21, 3); - lean_ctor_release(x_21, 4); - lean_ctor_release(x_21, 5); - x_28 = x_21; +if (lean_is_exclusive(x_20)) { + lean_ctor_release(x_20, 0); + lean_ctor_release(x_20, 1); + lean_ctor_release(x_20, 2); + lean_ctor_release(x_20, 3); + lean_ctor_release(x_20, 4); + lean_ctor_release(x_20, 5); + x_27 = x_20; } else { - lean_dec_ref(x_21); - x_28 = lean_box(0); + lean_dec_ref(x_20); + x_27 = lean_box(0); } -if (lean_is_scalar(x_28)) { - x_29 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_27)) { + x_28 = lean_alloc_ctor(0, 6, 0); } else { - x_29 = x_28; + x_28 = x_27; } -lean_ctor_set(x_29, 0, x_23); -lean_ctor_set(x_29, 1, x_24); -lean_ctor_set(x_29, 2, x_6); -lean_ctor_set(x_29, 3, x_25); -lean_ctor_set(x_29, 4, x_26); -lean_ctor_set(x_29, 5, x_27); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_22); -lean_ctor_set(x_30, 1, x_29); -return x_30; +lean_ctor_set(x_28, 0, x_22); +lean_ctor_set(x_28, 1, x_23); +lean_ctor_set(x_28, 2, x_5); +lean_ctor_set(x_28, 3, x_24); +lean_ctor_set(x_28, 4, x_25); +lean_ctor_set(x_28, 5, x_26); +x_29 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_29, 0, x_21); +lean_ctor_set(x_29, 1, x_28); +return x_29; } } else { -uint8_t x_31; -x_31 = !lean_is_exclusive(x_10); -if (x_31 == 0) +uint8_t x_30; +x_30 = !lean_is_exclusive(x_9); +if (x_30 == 0) { -lean_object* x_32; uint8_t x_33; -x_32 = lean_ctor_get(x_10, 1); -x_33 = !lean_is_exclusive(x_32); -if (x_33 == 0) +lean_object* x_31; uint8_t x_32; +x_31 = lean_ctor_get(x_9, 1); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) { -lean_object* x_34; -x_34 = lean_ctor_get(x_32, 2); -lean_dec(x_34); -lean_ctor_set(x_32, 2, x_6); -return x_10; +lean_object* x_33; +x_33 = lean_ctor_get(x_31, 2); +lean_dec(x_33); +lean_ctor_set(x_31, 2, x_5); +return x_9; } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_35 = lean_ctor_get(x_32, 0); -x_36 = lean_ctor_get(x_32, 1); -x_37 = lean_ctor_get(x_32, 3); -x_38 = lean_ctor_get(x_32, 4); -x_39 = lean_ctor_get(x_32, 5); -lean_inc(x_39); +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_34 = lean_ctor_get(x_31, 0); +x_35 = lean_ctor_get(x_31, 1); +x_36 = lean_ctor_get(x_31, 3); +x_37 = lean_ctor_get(x_31, 4); +x_38 = lean_ctor_get(x_31, 5); lean_inc(x_38); lean_inc(x_37); lean_inc(x_36); lean_inc(x_35); -lean_dec(x_32); -x_40 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_40, 0, x_35); -lean_ctor_set(x_40, 1, x_36); -lean_ctor_set(x_40, 2, x_6); -lean_ctor_set(x_40, 3, x_37); -lean_ctor_set(x_40, 4, x_38); -lean_ctor_set(x_40, 5, x_39); -lean_ctor_set(x_10, 1, x_40); -return x_10; +lean_inc(x_34); +lean_dec(x_31); +x_39 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_39, 0, x_34); +lean_ctor_set(x_39, 1, x_35); +lean_ctor_set(x_39, 2, x_5); +lean_ctor_set(x_39, 3, x_36); +lean_ctor_set(x_39, 4, x_37); +lean_ctor_set(x_39, 5, x_38); +lean_ctor_set(x_9, 1, x_39); +return x_9; } } else { -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_41 = lean_ctor_get(x_10, 1); -x_42 = lean_ctor_get(x_10, 0); +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_40 = lean_ctor_get(x_9, 1); +x_41 = lean_ctor_get(x_9, 0); +lean_inc(x_40); lean_inc(x_41); +lean_dec(x_9); +x_42 = lean_ctor_get(x_40, 0); lean_inc(x_42); -lean_dec(x_10); -x_43 = lean_ctor_get(x_41, 0); +x_43 = lean_ctor_get(x_40, 1); lean_inc(x_43); -x_44 = lean_ctor_get(x_41, 1); +x_44 = lean_ctor_get(x_40, 3); lean_inc(x_44); -x_45 = lean_ctor_get(x_41, 3); +x_45 = lean_ctor_get(x_40, 4); lean_inc(x_45); -x_46 = lean_ctor_get(x_41, 4); +x_46 = lean_ctor_get(x_40, 5); lean_inc(x_46); -x_47 = lean_ctor_get(x_41, 5); -lean_inc(x_47); -if (lean_is_exclusive(x_41)) { - lean_ctor_release(x_41, 0); - lean_ctor_release(x_41, 1); - lean_ctor_release(x_41, 2); - lean_ctor_release(x_41, 3); - lean_ctor_release(x_41, 4); - lean_ctor_release(x_41, 5); - x_48 = x_41; +if (lean_is_exclusive(x_40)) { + lean_ctor_release(x_40, 0); + lean_ctor_release(x_40, 1); + lean_ctor_release(x_40, 2); + lean_ctor_release(x_40, 3); + lean_ctor_release(x_40, 4); + lean_ctor_release(x_40, 5); + x_47 = x_40; } else { - lean_dec_ref(x_41); - x_48 = lean_box(0); + lean_dec_ref(x_40); + x_47 = lean_box(0); } -if (lean_is_scalar(x_48)) { - x_49 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_47)) { + x_48 = lean_alloc_ctor(0, 6, 0); } else { - x_49 = x_48; + x_48 = x_47; } -lean_ctor_set(x_49, 0, x_43); -lean_ctor_set(x_49, 1, x_44); -lean_ctor_set(x_49, 2, x_6); -lean_ctor_set(x_49, 3, x_45); -lean_ctor_set(x_49, 4, x_46); -lean_ctor_set(x_49, 5, x_47); -x_50 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_50, 0, x_42); -lean_ctor_set(x_50, 1, x_49); -return x_50; +lean_ctor_set(x_48, 0, x_42); +lean_ctor_set(x_48, 1, x_43); +lean_ctor_set(x_48, 2, x_5); +lean_ctor_set(x_48, 3, x_44); +lean_ctor_set(x_48, 4, x_45); +lean_ctor_set(x_48, 5, x_46); +x_49 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_49, 0, x_41); +lean_ctor_set(x_49, 1, x_48); +return x_49; } } } @@ -6975,7 +12458,7 @@ lean_object* l_Lean_Meta_lambdaTelescope(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_lambdaTelescope___rarg), 5, 0); +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_lambdaTelescope___rarg), 4, 0); return x_2; } } @@ -7297,88 +12780,92 @@ lean_dec(x_1); return x_2; } } -lean_object* l_Lean_Meta_usingDefault(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_whnfUsingDefault(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -uint8_t x_5; -x_5 = !lean_is_exclusive(x_3); -if (x_5 == 0) +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +if (x_4 == 0) { -lean_object* x_6; uint8_t x_7; -x_6 = lean_ctor_get(x_3, 0); -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_2, 0); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) { -uint8_t x_8; lean_object* x_9; -x_8 = 1; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_8); -x_9 = lean_apply_3(x_1, x_2, x_3, x_4); -return x_9; +uint8_t x_7; lean_object* x_8; +x_7 = 1; +lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 5, x_7); +x_8 = l_Lean_Meta_whnf(x_1, x_2, x_3); +return x_8; } else { -lean_object* x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; -x_10 = lean_ctor_get(x_6, 0); -x_11 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_12 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_13 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_14 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_10); -lean_dec(x_6); +lean_object* x_9; uint8_t x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; +x_9 = lean_ctor_get(x_5, 0); +x_10 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); +x_11 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); +x_12 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); +x_13 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); +x_14 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); +lean_inc(x_9); +lean_dec(x_5); x_15 = 1; -x_16 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_16, 0, x_10); -lean_ctor_set_uint8(x_16, sizeof(void*)*1, x_11); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 1, x_12); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 2, x_13); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 3, x_14); -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_15); -lean_ctor_set(x_3, 0, x_16); -x_17 = lean_apply_3(x_1, x_2, x_3, x_4); +x_16 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_16, 0, x_9); +lean_ctor_set_uint8(x_16, sizeof(void*)*1, x_10); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 1, x_11); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 2, x_12); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 3, x_13); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_14); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 5, x_15); +lean_ctor_set(x_2, 0, x_16); +x_17 = l_Lean_Meta_whnf(x_1, x_2, x_3); return x_17; } } else { -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_18 = lean_ctor_get(x_3, 0); -x_19 = lean_ctor_get(x_3, 1); -x_20 = lean_ctor_get(x_3, 2); +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_18 = lean_ctor_get(x_2, 0); +x_19 = lean_ctor_get(x_2, 1); +x_20 = lean_ctor_get(x_2, 2); lean_inc(x_20); lean_inc(x_19); lean_inc(x_18); -lean_dec(x_3); +lean_dec(x_2); x_21 = lean_ctor_get(x_18, 0); lean_inc(x_21); x_22 = lean_ctor_get_uint8(x_18, sizeof(void*)*1); x_23 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 1); x_24 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 2); x_25 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 3); +x_26 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 4); if (lean_is_exclusive(x_18)) { lean_ctor_release(x_18, 0); - x_26 = x_18; + x_27 = x_18; } else { lean_dec_ref(x_18); - x_26 = lean_box(0); + x_27 = lean_box(0); } -x_27 = 1; -if (lean_is_scalar(x_26)) { - x_28 = lean_alloc_ctor(0, 1, 5); +x_28 = 1; +if (lean_is_scalar(x_27)) { + x_29 = lean_alloc_ctor(0, 1, 6); } else { - x_28 = x_26; + x_29 = x_27; } -lean_ctor_set(x_28, 0, x_21); -lean_ctor_set_uint8(x_28, sizeof(void*)*1, x_22); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 1, x_23); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 2, x_24); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 3, x_25); -lean_ctor_set_uint8(x_28, sizeof(void*)*1 + 4, x_27); -x_29 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_29, 0, x_28); -lean_ctor_set(x_29, 1, x_19); -lean_ctor_set(x_29, 2, x_20); -x_30 = lean_apply_3(x_1, x_2, x_29, x_4); -return x_30; +lean_ctor_set(x_29, 0, x_21); +lean_ctor_set_uint8(x_29, sizeof(void*)*1, x_22); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 1, x_23); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 2, x_24); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 3, x_25); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_26); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 5, x_28); +x_30 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_19); +lean_ctor_set(x_30, 2, x_20); +x_31 = l_Lean_Meta_whnf(x_1, x_30, x_3); +return x_31; } } } @@ -7436,6 +12923,75 @@ l_Lean_Meta_InfoCacheKey_Inhabited___closed__1 = _init_l_Lean_Meta_InfoCacheKey_ lean_mark_persistent(l_Lean_Meta_InfoCacheKey_Inhabited___closed__1); l_Lean_Meta_InfoCacheKey_Inhabited = _init_l_Lean_Meta_InfoCacheKey_Inhabited(); lean_mark_persistent(l_Lean_Meta_InfoCacheKey_Inhabited); +l_Lean_Meta_mkWHNFRef___lambda__1___closed__1 = _init_l_Lean_Meta_mkWHNFRef___lambda__1___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkWHNFRef___lambda__1___closed__1); +l_Lean_Meta_mkWHNFRef___lambda__1___closed__2 = _init_l_Lean_Meta_mkWHNFRef___lambda__1___closed__2(); +lean_mark_persistent(l_Lean_Meta_mkWHNFRef___lambda__1___closed__2); +l_Lean_Meta_mkWHNFRef___closed__1 = _init_l_Lean_Meta_mkWHNFRef___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkWHNFRef___closed__1); +res = l_Lean_Meta_mkWHNFRef(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +l_Lean_Meta_whnfRef = lean_io_result_get_value(res); +lean_mark_persistent(l_Lean_Meta_whnfRef); +lean_dec_ref(res); +l_Lean_Meta_mkInferTypeRef___lambda__1___closed__1 = _init_l_Lean_Meta_mkInferTypeRef___lambda__1___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkInferTypeRef___lambda__1___closed__1); +l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2 = _init_l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2(); +lean_mark_persistent(l_Lean_Meta_mkInferTypeRef___lambda__1___closed__2); +l_Lean_Meta_mkInferTypeRef___closed__1 = _init_l_Lean_Meta_mkInferTypeRef___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkInferTypeRef___closed__1); +res = l_Lean_Meta_mkInferTypeRef(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +l_Lean_Meta_inferTypeRef = lean_io_result_get_value(res); +lean_mark_persistent(l_Lean_Meta_inferTypeRef); +lean_dec_ref(res); +l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__1 = _init_l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__1); +l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__2 = _init_l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__2(); +lean_mark_persistent(l_Lean_Meta_mkIsExprDefEqAuxRef___lambda__1___closed__2); +l_Lean_Meta_mkIsExprDefEqAuxRef___closed__1 = _init_l_Lean_Meta_mkIsExprDefEqAuxRef___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkIsExprDefEqAuxRef___closed__1); +res = l_Lean_Meta_mkIsExprDefEqAuxRef(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +l_Lean_Meta_isExprDefEqAuxRef = lean_io_result_get_value(res); +lean_mark_persistent(l_Lean_Meta_isExprDefEqAuxRef); +lean_dec_ref(res); +l_Lean_Meta_mkSynthPendingRef___closed__1 = _init_l_Lean_Meta_mkSynthPendingRef___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkSynthPendingRef___closed__1); +res = l_Lean_Meta_mkSynthPendingRef(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +l_Lean_Meta_synthPendingRef = lean_io_result_get_value(res); +lean_mark_persistent(l_Lean_Meta_synthPendingRef); +lean_dec_ref(res); +l_Lean_Meta_MetaExtState_inhabited___closed__1 = _init_l_Lean_Meta_MetaExtState_inhabited___closed__1(); +lean_mark_persistent(l_Lean_Meta_MetaExtState_inhabited___closed__1); +l_Lean_Meta_MetaExtState_inhabited___closed__2 = _init_l_Lean_Meta_MetaExtState_inhabited___closed__2(); +lean_mark_persistent(l_Lean_Meta_MetaExtState_inhabited___closed__2); +l_Lean_Meta_MetaExtState_inhabited___closed__3 = _init_l_Lean_Meta_MetaExtState_inhabited___closed__3(); +lean_mark_persistent(l_Lean_Meta_MetaExtState_inhabited___closed__3); +l_Lean_Meta_MetaExtState_inhabited___closed__4 = _init_l_Lean_Meta_MetaExtState_inhabited___closed__4(); +lean_mark_persistent(l_Lean_Meta_MetaExtState_inhabited___closed__4); +l_Lean_Meta_MetaExtState_inhabited = _init_l_Lean_Meta_MetaExtState_inhabited(); +lean_mark_persistent(l_Lean_Meta_MetaExtState_inhabited); +l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__1 = _init_l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__1(); +lean_mark_persistent(l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__1); +l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__2 = _init_l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__2(); +lean_mark_persistent(l_Lean_registerEnvExtensionUnsafe___at_Lean_Meta_mkMetaExtension___spec__1___closed__2); +l_Lean_Meta_mkMetaExtension___closed__1 = _init_l_Lean_Meta_mkMetaExtension___closed__1(); +lean_mark_persistent(l_Lean_Meta_mkMetaExtension___closed__1); +l_Lean_Meta_mkMetaExtension___closed__2 = _init_l_Lean_Meta_mkMetaExtension___closed__2(); +lean_mark_persistent(l_Lean_Meta_mkMetaExtension___closed__2); +l_Lean_Meta_mkMetaExtension___closed__3 = _init_l_Lean_Meta_mkMetaExtension___closed__3(); +lean_mark_persistent(l_Lean_Meta_mkMetaExtension___closed__3); +l_Lean_Meta_metaExt___closed__1 = _init_l_Lean_Meta_metaExt___closed__1(); +lean_mark_persistent(l_Lean_Meta_metaExt___closed__1); +l_Lean_Meta_metaExt___closed__2 = _init_l_Lean_Meta_metaExt___closed__2(); +lean_mark_persistent(l_Lean_Meta_metaExt___closed__2); +res = l_Lean_Meta_mkMetaExtension(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +l_Lean_Meta_metaExt = lean_io_result_get_value(res); +lean_mark_persistent(l_Lean_Meta_metaExt); +lean_dec_ref(res); l_Lean_Meta_dbgTrace___rarg___closed__1 = _init_l_Lean_Meta_dbgTrace___rarg___closed__1(); lean_mark_persistent(l_Lean_Meta_dbgTrace___rarg___closed__1); l_Lean_Meta_tracer___closed__1 = _init_l_Lean_Meta_tracer___closed__1(); @@ -7450,8 +13006,8 @@ l_Lean_Meta_tracer = _init_l_Lean_Meta_tracer(); lean_mark_persistent(l_Lean_Meta_tracer); l_Lean_Meta_isClassQuick___main___closed__1 = _init_l_Lean_Meta_isClassQuick___main___closed__1(); lean_mark_persistent(l_Lean_Meta_isClassQuick___main___closed__1); -l_Lean_Meta_isClassExpensive___main___closed__1 = _init_l_Lean_Meta_isClassExpensive___main___closed__1(); -lean_mark_persistent(l_Lean_Meta_isClassExpensive___main___closed__1); +l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1 = _init_l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/library/Init/Lean/Meta/Check.c b/stage0/library/Init/Lean/Meta/Check.c index 6b95e9c286..e67d413763 100644 --- a/stage0/library/Init/Lean/Meta/Check.c +++ b/stage0/library/Init/Lean/Meta/Check.c @@ -13,536 +13,480 @@ #ifdef __cplusplus extern "C" { #endif -lean_object* l_Lean_Meta_checkAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_6__checkAuxAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Check_4__checkConstant(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_1__ensureType(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClassExpensive___main(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_1__ensureType(lean_object*, lean_object*, lean_object*); +extern lean_object* l_EIO_Monad___closed__1; +lean_object* lean_local_ctx_mk_let_decl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1; +lean_object* l___private_Init_Lean_Meta_Check_6__checkAux(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClassQuick___main(lean_object*, lean_object*, lean_object*); extern lean_object* l_Array_empty___closed__1; +lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_ReaderT_Monad___rarg(lean_object*); lean_object* l_Array_forMAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getLevelAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; +lean_object* lean_array_push(lean_object*, lean_object*); +lean_object* lean_array_get_size(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___lambda__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isTypeCorrect(lean_object*, lean_object*, lean_object*); lean_object* lean_environment_find(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__10___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_6__checkAux___main(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_nat_add(lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_array_fget(lean_object*, lean_object*); +lean_object* lean_expr_instantiate_rev_range(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_eq(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_fvarId_x21(lean_object*); lean_object* l_List_lengthAux___main___rarg(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isTypeCorrectAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__9(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_5__checkApp___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkFreshId___rarg(lean_object*); uint8_t l_Lean_Expr_isForall(lean_object*); +lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_mkFVar(lean_object*); +uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_LocalDecl_type(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__12___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_ConstantInfo_lparams(lean_object*); -lean_object* l_Lean_Meta_usingDefault(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferTypeAuxAux___main(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_lambdaTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferTypeAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__9___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__2(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_lambdaTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_getLevel(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__4(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_Check_4__checkConstant___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_6__checkAuxAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_5__checkApp(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_5__checkApp(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__12(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__7(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_check(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Check_1__ensureType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_Check_1__ensureType(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_5; lean_object* x_6; -lean_inc(x_1); -x_5 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_5, 0, x_1); -x_6 = l_Lean_Meta_getLevelAux(x_1, x_5, x_2, x_3, x_4); +lean_object* x_4; +x_4 = l_Lean_Meta_getLevel(x_1, x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +uint8_t x_5; +x_5 = !lean_is_exclusive(x_4); +if (x_5 == 0) +{ +lean_object* x_6; lean_object* x_7; +x_6 = lean_ctor_get(x_4, 0); +lean_dec(x_6); +x_7 = lean_box(0); +lean_ctor_set(x_4, 0, x_7); +return x_4; +} +else +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_8 = lean_ctor_get(x_4, 1); +lean_inc(x_8); +lean_dec(x_4); +x_9 = lean_box(0); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_8); +return x_10; +} +} +else +{ +uint8_t x_11; +x_11 = !lean_is_exclusive(x_4); +if (x_11 == 0) +{ +return x_4; +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_4, 0); +x_13 = lean_ctor_get(x_4, 1); +lean_inc(x_13); +lean_inc(x_12); +lean_dec(x_4); +x_14 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_14, 0, x_12); +lean_ctor_set(x_14, 1, x_13); +return x_14; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l_Lean_Meta_getFVarLocalDecl(x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); if (lean_obj_tag(x_6) == 0) { -uint8_t x_7; -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -lean_object* x_8; lean_object* x_9; -x_8 = lean_ctor_get(x_6, 0); -lean_dec(x_8); -x_9 = lean_box(0); -lean_ctor_set(x_6, 0, x_9); -return x_6; -} -else -{ -lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_10 = lean_ctor_get(x_6, 1); -lean_inc(x_10); -lean_dec(x_6); -x_11 = lean_box(0); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_10); -return x_12; -} -} -else -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_6); -if (x_13 == 0) -{ -return x_6; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_14 = lean_ctor_get(x_6, 0); -x_15 = lean_ctor_get(x_6, 1); -lean_inc(x_15); -lean_inc(x_14); -lean_dec(x_6); -x_16 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_16, 0, x_14); -lean_ctor_set(x_16, 1, x_15); -return x_16; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -lean_inc(x_5); -x_7 = l_Lean_Meta_getFVarLocalDecl(x_4, x_5, x_6); -if (lean_obj_tag(x_7) == 0) -{ -lean_object* x_8; -x_8 = lean_ctor_get(x_7, 0); -lean_inc(x_8); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; -lean_dec(x_3); -x_9 = lean_ctor_get(x_7, 1); -lean_inc(x_9); -lean_dec(x_7); -x_10 = lean_ctor_get(x_8, 3); -lean_inc(x_10); -lean_dec(x_8); -lean_inc(x_5); -lean_inc(x_10); -x_11 = l___private_Init_Lean_Meta_Check_1__ensureType(x_1, x_10, x_5, x_9); -if (lean_obj_tag(x_11) == 0) -{ -lean_object* x_12; lean_object* x_13; -x_12 = lean_ctor_get(x_11, 1); -lean_inc(x_12); -lean_dec(x_11); -x_13 = lean_apply_3(x_2, x_10, x_5, x_12); -return x_13; -} -else -{ -uint8_t x_14; -lean_dec(x_10); +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); lean_dec(x_5); -lean_dec(x_2); -x_14 = !lean_is_exclusive(x_11); -if (x_14 == 0) +x_8 = lean_ctor_get(x_6, 3); +lean_inc(x_8); +lean_dec(x_6); +lean_inc(x_3); +lean_inc(x_8); +x_9 = l___private_Init_Lean_Meta_Check_1__ensureType(x_8, x_3, x_7); +if (lean_obj_tag(x_9) == 0) { +lean_object* x_10; lean_object* x_11; +x_10 = lean_ctor_get(x_9, 1); +lean_inc(x_10); +lean_dec(x_9); +x_11 = lean_apply_3(x_1, x_8, x_3, x_10); return x_11; } else { -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_11, 0); -x_16 = lean_ctor_get(x_11, 1); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_11); -x_17 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_17, 0, x_15); -lean_ctor_set(x_17, 1, x_16); -return x_17; +uint8_t x_12; +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_1); +x_12 = !lean_is_exclusive(x_9); +if (x_12 == 0) +{ +return x_9; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_9, 0); +x_14 = lean_ctor_get(x_9, 1); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_9); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); +return x_15; } } } else { -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_18 = lean_ctor_get(x_7, 1); +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_5, 1); +lean_inc(x_16); +lean_dec(x_5); +x_17 = lean_ctor_get(x_6, 3); +lean_inc(x_17); +x_18 = lean_ctor_get(x_6, 4); lean_inc(x_18); -lean_dec(x_7); -x_19 = lean_ctor_get(x_8, 3); -lean_inc(x_19); -x_20 = lean_ctor_get(x_8, 4); +lean_dec(x_6); +lean_inc(x_3); +lean_inc(x_17); +x_19 = l___private_Init_Lean_Meta_Check_1__ensureType(x_17, x_3, x_16); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; lean_object* x_21; +x_20 = lean_ctor_get(x_19, 1); lean_inc(x_20); -lean_dec(x_8); -lean_inc(x_5); -lean_inc(x_19); +lean_dec(x_19); lean_inc(x_1); -x_21 = l___private_Init_Lean_Meta_Check_1__ensureType(x_1, x_19, x_5, x_18); +lean_inc(x_3); +lean_inc(x_17); +x_21 = lean_apply_3(x_1, x_17, x_3, x_20); if (lean_obj_tag(x_21) == 0) { lean_object* x_22; lean_object* x_23; x_22 = lean_ctor_get(x_21, 1); lean_inc(x_22); lean_dec(x_21); -lean_inc(x_2); -lean_inc(x_5); -lean_inc(x_19); -x_23 = lean_apply_3(x_2, x_19, x_5, x_22); +lean_inc(x_3); +lean_inc(x_18); +x_23 = l_Lean_Meta_inferType(x_18, x_3, x_22); if (lean_obj_tag(x_23) == 0) { lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_23, 1); +x_24 = lean_ctor_get(x_23, 0); lean_inc(x_24); +x_25 = lean_ctor_get(x_23, 1); +lean_inc(x_25); lean_dec(x_23); -x_25 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 1); -lean_closure_set(x_25, 0, x_1); -lean_inc(x_5); -lean_inc(x_20); -x_26 = l_Lean_Meta_inferTypeAuxAux___main(x_25, x_20, x_5, x_24); +lean_inc(x_3); +x_26 = l_Lean_Meta_isExprDefEqAux(x_17, x_24, x_3, x_25); if (lean_obj_tag(x_26) == 0) { -lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_object* x_27; uint8_t x_28; x_27 = lean_ctor_get(x_26, 0); lean_inc(x_27); -x_28 = lean_ctor_get(x_26, 1); -lean_inc(x_28); -lean_dec(x_26); -lean_inc(x_5); -x_29 = lean_apply_4(x_3, x_19, x_27, x_5, x_28); -if (lean_obj_tag(x_29) == 0) +x_28 = lean_unbox(x_27); +lean_dec(x_27); +if (x_28 == 0) { -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_unbox(x_30); -lean_dec(x_30); -if (x_31 == 0) +uint8_t x_29; +lean_dec(x_18); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_26); +if (x_29 == 0) { -uint8_t x_32; -lean_dec(x_20); -lean_dec(x_2); -x_32 = !lean_is_exclusive(x_29); -if (x_32 == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_33 = lean_ctor_get(x_29, 1); -x_34 = lean_ctor_get(x_29, 0); -lean_dec(x_34); -x_35 = lean_ctor_get(x_33, 0); -lean_inc(x_35); -x_36 = lean_ctor_get(x_33, 1); -lean_inc(x_36); -x_37 = lean_ctor_get(x_5, 1); -lean_inc(x_37); -lean_dec(x_5); -x_38 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_38, 0, x_35); -lean_ctor_set(x_38, 1, x_36); -lean_ctor_set(x_38, 2, x_37); -x_39 = l_Lean_Expr_fvarId_x21(x_4); -x_40 = lean_alloc_ctor(11, 2, 0); -lean_ctor_set(x_40, 0, x_39); -lean_ctor_set(x_40, 1, x_38); -lean_ctor_set_tag(x_29, 1); -lean_ctor_set(x_29, 0, x_40); -return x_29; -} -else -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_41 = lean_ctor_get(x_29, 1); -lean_inc(x_41); -lean_dec(x_29); -x_42 = lean_ctor_get(x_41, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_41, 1); -lean_inc(x_43); -x_44 = lean_ctor_get(x_5, 1); -lean_inc(x_44); -lean_dec(x_5); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_42); -lean_ctor_set(x_45, 1, x_43); -lean_ctor_set(x_45, 2, x_44); -x_46 = l_Lean_Expr_fvarId_x21(x_4); -x_47 = lean_alloc_ctor(11, 2, 0); -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_45); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_47); -lean_ctor_set(x_48, 1, x_41); -return x_48; -} -} -else -{ -lean_object* x_49; lean_object* x_50; -x_49 = lean_ctor_get(x_29, 1); -lean_inc(x_49); -lean_dec(x_29); -x_50 = lean_apply_3(x_2, x_20, x_5, x_49); -return x_50; -} -} -else -{ -uint8_t x_51; -lean_dec(x_20); -lean_dec(x_5); -lean_dec(x_2); -x_51 = !lean_is_exclusive(x_29); -if (x_51 == 0) -{ -return x_29; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_29, 0); -x_53 = lean_ctor_get(x_29, 1); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_29); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; -} -} -} -else -{ -uint8_t x_55; -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_5); +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_30 = lean_ctor_get(x_26, 1); +x_31 = lean_ctor_get(x_26, 0); +lean_dec(x_31); +x_32 = lean_ctor_get(x_30, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_30, 1); +lean_inc(x_33); +x_34 = lean_ctor_get(x_3, 1); +lean_inc(x_34); lean_dec(x_3); -lean_dec(x_2); -x_55 = !lean_is_exclusive(x_26); -if (x_55 == 0) +x_35 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_35, 0, x_32); +lean_ctor_set(x_35, 1, x_33); +lean_ctor_set(x_35, 2, x_34); +x_36 = l_Lean_Expr_fvarId_x21(x_2); +x_37 = lean_alloc_ctor(12, 2, 0); +lean_ctor_set(x_37, 0, x_36); +lean_ctor_set(x_37, 1, x_35); +lean_ctor_set_tag(x_26, 1); +lean_ctor_set(x_26, 0, x_37); +return x_26; +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_38 = lean_ctor_get(x_26, 1); +lean_inc(x_38); +lean_dec(x_26); +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_38, 1); +lean_inc(x_40); +x_41 = lean_ctor_get(x_3, 1); +lean_inc(x_41); +lean_dec(x_3); +x_42 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_42, 0, x_39); +lean_ctor_set(x_42, 1, x_40); +lean_ctor_set(x_42, 2, x_41); +x_43 = l_Lean_Expr_fvarId_x21(x_2); +x_44 = lean_alloc_ctor(12, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_42); +x_45 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_45, 0, x_44); +lean_ctor_set(x_45, 1, x_38); +return x_45; +} +} +else +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_26, 1); +lean_inc(x_46); +lean_dec(x_26); +x_47 = lean_apply_3(x_1, x_18, x_3, x_46); +return x_47; +} +} +else +{ +uint8_t x_48; +lean_dec(x_18); +lean_dec(x_3); +lean_dec(x_1); +x_48 = !lean_is_exclusive(x_26); +if (x_48 == 0) { return x_26; } else { -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_26, 0); -x_57 = lean_ctor_get(x_26, 1); -lean_inc(x_57); -lean_inc(x_56); +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_26, 0); +x_50 = lean_ctor_get(x_26, 1); +lean_inc(x_50); +lean_inc(x_49); lean_dec(x_26); -x_58 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_58, 0, x_56); -lean_ctor_set(x_58, 1, x_57); -return x_58; +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; } } } else { -uint8_t x_59; -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_5); +uint8_t x_52; +lean_dec(x_18); +lean_dec(x_17); lean_dec(x_3); -lean_dec(x_2); lean_dec(x_1); -x_59 = !lean_is_exclusive(x_23); -if (x_59 == 0) +x_52 = !lean_is_exclusive(x_23); +if (x_52 == 0) { return x_23; } else { -lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_60 = lean_ctor_get(x_23, 0); -x_61 = lean_ctor_get(x_23, 1); -lean_inc(x_61); -lean_inc(x_60); +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_23, 0); +x_54 = lean_ctor_get(x_23, 1); +lean_inc(x_54); +lean_inc(x_53); lean_dec(x_23); -x_62 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_62, 0, x_60); -lean_ctor_set(x_62, 1, x_61); -return x_62; +x_55 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_55, 0, x_53); +lean_ctor_set(x_55, 1, x_54); +return x_55; } } } else { -uint8_t x_63; -lean_dec(x_20); -lean_dec(x_19); -lean_dec(x_5); +uint8_t x_56; +lean_dec(x_18); +lean_dec(x_17); lean_dec(x_3); -lean_dec(x_2); lean_dec(x_1); -x_63 = !lean_is_exclusive(x_21); -if (x_63 == 0) +x_56 = !lean_is_exclusive(x_21); +if (x_56 == 0) { return x_21; } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_21, 0); -x_65 = lean_ctor_get(x_21, 1); -lean_inc(x_65); -lean_inc(x_64); +lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_57 = lean_ctor_get(x_21, 0); +x_58 = lean_ctor_get(x_21, 1); +lean_inc(x_58); +lean_inc(x_57); lean_dec(x_21); -x_66 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_66, 0, x_64); -lean_ctor_set(x_66, 1, x_65); -return x_66; -} +x_59 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_59, 0, x_57); +lean_ctor_set(x_59, 1, x_58); +return x_59; } } } else { -uint8_t x_67; -lean_dec(x_5); +uint8_t x_60; +lean_dec(x_18); +lean_dec(x_17); lean_dec(x_3); -lean_dec(x_2); lean_dec(x_1); -x_67 = !lean_is_exclusive(x_7); -if (x_67 == 0) +x_60 = !lean_is_exclusive(x_19); +if (x_60 == 0) { -return x_7; +return x_19; } else { -lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_68 = lean_ctor_get(x_7, 0); -x_69 = lean_ctor_get(x_7, 1); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_7); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -return x_70; +lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_61 = lean_ctor_get(x_19, 0); +x_62 = lean_ctor_get(x_19, 1); +lean_inc(x_62); +lean_inc(x_61); +lean_dec(x_19); +x_63 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_63, 0, x_61); +lean_ctor_set(x_63, 1, x_62); +return x_63; } } } } -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -lean_inc(x_2); -x_8 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1___boxed), 6, 3); -lean_closure_set(x_8, 0, x_1); -lean_closure_set(x_8, 1, x_2); -lean_closure_set(x_8, 2, x_3); -x_9 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_10 = lean_unsigned_to_nat(0u); -x_11 = l_Array_forMAux___main___rarg(x_9, lean_box(0), lean_box(0), x_8, x_4, x_10); -lean_inc(x_6); -x_12 = lean_apply_2(x_11, x_6, x_7); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = lean_ctor_get(x_12, 1); -lean_inc(x_13); -lean_dec(x_12); -x_14 = lean_apply_3(x_2, x_5, x_6, x_13); -return x_14; -} else { -uint8_t x_15; -lean_dec(x_6); +uint8_t x_64; +lean_dec(x_3); +lean_dec(x_1); +x_64 = !lean_is_exclusive(x_5); +if (x_64 == 0) +{ +return x_5; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_5, 0); +x_66 = lean_ctor_get(x_5, 1); +lean_inc(x_66); +lean_inc(x_65); lean_dec(x_5); -lean_dec(x_2); -x_15 = !lean_is_exclusive(x_12); -if (x_15 == 0) -{ -return x_12; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_12, 0); -x_17 = lean_ctor_get(x_12, 1); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_12); -x_18 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_17); -return x_18; +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } } } -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* _init_l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1() { _start: { -lean_object* x_7; lean_object* x_8; +lean_object* x_1; lean_object* x_2; +x_1 = l_EIO_Monad___closed__1; +x_2 = l_ReaderT_Monad___rarg(x_1); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_inc(x_1); -x_7 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___boxed), 7, 3); -lean_closure_set(x_7, 0, x_1); -lean_closure_set(x_7, 1, x_3); -lean_closure_set(x_7, 2, x_2); -x_8 = l_Lean_Meta_lambdaTelescope___rarg(x_1, x_4, x_7, x_5, x_6); -return x_8; -} -} -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_4); -return x_7; -} -} -lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); -return x_8; -} -} -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; +x_6 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1___boxed), 4, 1); +lean_closure_set(x_6, 0, x_1); +x_7 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_Array_forMAux___main___rarg(x_7, lean_box(0), lean_box(0), x_6, x_2, x_8); lean_inc(x_4); -x_6 = l_Lean_Meta_getFVarLocalDecl(x_3, x_4, x_5); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); -lean_dec(x_6); -x_9 = l_Lean_LocalDecl_type(x_7); -lean_dec(x_7); -lean_inc(x_4); -lean_inc(x_9); -x_10 = l___private_Init_Lean_Meta_Check_1__ensureType(x_1, x_9, x_4, x_8); +x_10 = lean_apply_2(x_9, x_4, x_5); if (lean_obj_tag(x_10) == 0) { lean_object* x_11; lean_object* x_12; x_11 = lean_ctor_get(x_10, 1); lean_inc(x_11); lean_dec(x_10); -x_12 = lean_apply_3(x_2, x_9, x_4, x_11); +x_12 = lean_apply_3(x_1, x_3, x_4, x_11); return x_12; } else { uint8_t x_13; -lean_dec(x_9); lean_dec(x_4); -lean_dec(x_2); +lean_dec(x_3); +lean_dec(x_1); x_13 = !lean_is_exclusive(x_10); if (x_13 == 0) { @@ -563,84 +507,107 @@ return x_16; } } } -else -{ -uint8_t x_17; -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_17 = !lean_is_exclusive(x_6); -if (x_17 == 0) -{ -return x_6; } -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_6, 0); -x_19 = lean_ctor_get(x_6, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_6); -x_20 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_19); -return x_20; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -lean_inc(x_2); -lean_inc(x_1); -x_7 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1___boxed), 5, 2); -lean_closure_set(x_7, 0, x_1); -lean_closure_set(x_7, 1, x_2); -x_8 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_9 = lean_unsigned_to_nat(0u); -x_10 = l_Array_forMAux___main___rarg(x_8, lean_box(0), lean_box(0), x_7, x_3, x_9); -lean_inc(x_5); -x_11 = lean_apply_2(x_10, x_5, x_6); -if (lean_obj_tag(x_11) == 0) +lean_object* x_5; lean_object* x_6; +x_5 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___boxed), 5, 1); +lean_closure_set(x_5, 0, x_1); +x_6 = l_Lean_Meta_lambdaTelescope___rarg(x_2, x_5, x_3, x_4); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: { -lean_object* x_12; lean_object* x_13; -x_12 = lean_ctor_get(x_11, 1); -lean_inc(x_12); -lean_dec(x_11); -lean_inc(x_5); -lean_inc(x_4); -x_13 = l___private_Init_Lean_Meta_Check_1__ensureType(x_1, x_4, x_5, x_12); -if (lean_obj_tag(x_13) == 0) +lean_object* x_5; +x_5 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__1(x_1, x_2, x_3, x_4); +lean_dec(x_2); +return x_5; +} +} +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: { -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_13, 1); +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l_Lean_Meta_getFVarLocalDecl(x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +x_8 = l_Lean_LocalDecl_type(x_6); +lean_dec(x_6); +lean_inc(x_3); +lean_inc(x_8); +x_9 = l___private_Init_Lean_Meta_Check_1__ensureType(x_8, x_3, x_7); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_ctor_get(x_9, 1); +lean_inc(x_10); +lean_dec(x_9); +x_11 = lean_apply_3(x_1, x_8, x_3, x_10); +return x_11; +} +else +{ +uint8_t x_12; +lean_dec(x_8); +lean_dec(x_3); +lean_dec(x_1); +x_12 = !lean_is_exclusive(x_9); +if (x_12 == 0) +{ +return x_9; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_9, 0); +x_14 = lean_ctor_get(x_9, 1); lean_inc(x_14); -lean_dec(x_13); -x_15 = lean_apply_3(x_2, x_4, x_5, x_14); +lean_inc(x_13); +lean_dec(x_9); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_14); return x_15; } +} +} else { uint8_t x_16; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_16 = !lean_is_exclusive(x_13); +lean_dec(x_3); +lean_dec(x_1); +x_16 = !lean_is_exclusive(x_5); if (x_16 == 0) { -return x_13; +return x_5; } else { lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_13, 0); -x_18 = lean_ctor_get(x_13, 1); +x_17 = lean_ctor_get(x_5, 0); +x_18 = lean_ctor_get(x_5, 1); lean_inc(x_18); lean_inc(x_17); -lean_dec(x_13); +lean_dec(x_5); x_19 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_19, 0, x_17); lean_ctor_set(x_19, 1, x_18); @@ -648,252 +615,304 @@ return x_19; } } } -else -{ -uint8_t x_20; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_20 = !lean_is_exclusive(x_11); -if (x_20 == 0) -{ -return x_11; } -else -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_21 = lean_ctor_get(x_11, 0); -x_22 = lean_ctor_get(x_11, 1); -lean_inc(x_22); -lean_inc(x_21); -lean_dec(x_11); -x_23 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_23, 0, x_21); -lean_ctor_set(x_23, 1, x_22); -return x_23; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_inc(x_1); -x_6 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2___boxed), 6, 2); +x_6 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1___boxed), 4, 1); lean_closure_set(x_6, 0, x_1); -lean_closure_set(x_6, 1, x_2); -x_7 = lean_ctor_get(x_5, 2); -lean_inc(x_7); -x_8 = lean_ctor_get(x_4, 1); -lean_inc(x_8); -lean_inc(x_1); -x_9 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive), 4, 1); -lean_closure_set(x_9, 0, x_1); -x_10 = lean_box(0); -x_11 = 0; -x_12 = l_Array_empty___closed__1; -x_13 = lean_unsigned_to_nat(0u); -x_14 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_9, x_11, x_10, x_6, x_8, x_12, x_13, x_3, x_4, x_5); -if (lean_obj_tag(x_14) == 0) +x_7 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_Array_forMAux___main___rarg(x_7, lean_box(0), lean_box(0), x_6, x_2, x_8); +lean_inc(x_4); +x_10 = lean_apply_2(x_9, x_4, x_5); +if (lean_obj_tag(x_10) == 0) { -uint8_t x_15; -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_10, 1); +lean_inc(x_11); +lean_dec(x_10); +lean_inc(x_4); +lean_inc(x_3); +x_12 = l___private_Init_Lean_Meta_Check_1__ensureType(x_3, x_4, x_11); +if (lean_obj_tag(x_12) == 0) { -lean_object* x_16; uint8_t x_17; -x_16 = lean_ctor_get(x_14, 1); -x_17 = !lean_is_exclusive(x_16); -if (x_17 == 0) -{ -lean_object* x_18; -x_18 = lean_ctor_get(x_16, 2); -lean_dec(x_18); -lean_ctor_set(x_16, 2, x_7); +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_12, 1); +lean_inc(x_13); +lean_dec(x_12); +x_14 = lean_apply_3(x_1, x_3, x_4, x_13); return x_14; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_19 = lean_ctor_get(x_16, 0); -x_20 = lean_ctor_get(x_16, 1); -x_21 = lean_ctor_get(x_16, 3); -x_22 = lean_ctor_get(x_16, 4); -x_23 = lean_ctor_get(x_16, 5); -lean_inc(x_23); +uint8_t x_15; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_15 = !lean_is_exclusive(x_12); +if (x_15 == 0) +{ +return x_12; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_12, 0); +x_17 = lean_ctor_get(x_12, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_12); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +} +else +{ +uint8_t x_19; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_19 = !lean_is_exclusive(x_10); +if (x_19 == 0) +{ +return x_10; +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_10, 0); +x_21 = lean_ctor_get(x_10, 1); +lean_inc(x_21); +lean_inc(x_20); +lean_dec(x_10); +x_22 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_22, 0, x_20); +lean_ctor_set(x_22, 1, x_21); +return x_22; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_5 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2___boxed), 5, 1); +lean_closure_set(x_5, 0, x_1); +x_6 = lean_ctor_get(x_4, 2); +lean_inc(x_6); +x_7 = lean_ctor_get(x_3, 1); +lean_inc(x_7); +x_8 = lean_box(0); +x_9 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___rarg___closed__1; +x_10 = 0; +x_11 = l_Array_empty___closed__1; +x_12 = lean_unsigned_to_nat(0u); +x_13 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_9, x_10, x_8, x_5, x_7, x_11, x_12, x_2, x_3, x_4); +if (lean_obj_tag(x_13) == 0) +{ +uint8_t x_14; +x_14 = !lean_is_exclusive(x_13); +if (x_14 == 0) +{ +lean_object* x_15; uint8_t x_16; +x_15 = lean_ctor_get(x_13, 1); +x_16 = !lean_is_exclusive(x_15); +if (x_16 == 0) +{ +lean_object* x_17; +x_17 = lean_ctor_get(x_15, 2); +lean_dec(x_17); +lean_ctor_set(x_15, 2, x_6); +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_18 = lean_ctor_get(x_15, 0); +x_19 = lean_ctor_get(x_15, 1); +x_20 = lean_ctor_get(x_15, 3); +x_21 = lean_ctor_get(x_15, 4); +x_22 = lean_ctor_get(x_15, 5); lean_inc(x_22); lean_inc(x_21); lean_inc(x_20); lean_inc(x_19); -lean_dec(x_16); -x_24 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_24, 0, x_19); -lean_ctor_set(x_24, 1, x_20); -lean_ctor_set(x_24, 2, x_7); -lean_ctor_set(x_24, 3, x_21); -lean_ctor_set(x_24, 4, x_22); -lean_ctor_set(x_24, 5, x_23); -lean_ctor_set(x_14, 1, x_24); -return x_14; +lean_inc(x_18); +lean_dec(x_15); +x_23 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_23, 0, x_18); +lean_ctor_set(x_23, 1, x_19); +lean_ctor_set(x_23, 2, x_6); +lean_ctor_set(x_23, 3, x_20); +lean_ctor_set(x_23, 4, x_21); +lean_ctor_set(x_23, 5, x_22); +lean_ctor_set(x_13, 1, x_23); +return x_13; } } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_25 = lean_ctor_get(x_14, 1); -x_26 = lean_ctor_get(x_14, 0); +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_24 = lean_ctor_get(x_13, 1); +x_25 = lean_ctor_get(x_13, 0); +lean_inc(x_24); lean_inc(x_25); +lean_dec(x_13); +x_26 = lean_ctor_get(x_24, 0); lean_inc(x_26); -lean_dec(x_14); -x_27 = lean_ctor_get(x_25, 0); +x_27 = lean_ctor_get(x_24, 1); lean_inc(x_27); -x_28 = lean_ctor_get(x_25, 1); +x_28 = lean_ctor_get(x_24, 3); lean_inc(x_28); -x_29 = lean_ctor_get(x_25, 3); +x_29 = lean_ctor_get(x_24, 4); lean_inc(x_29); -x_30 = lean_ctor_get(x_25, 4); +x_30 = lean_ctor_get(x_24, 5); lean_inc(x_30); -x_31 = lean_ctor_get(x_25, 5); -lean_inc(x_31); -if (lean_is_exclusive(x_25)) { - lean_ctor_release(x_25, 0); - lean_ctor_release(x_25, 1); - lean_ctor_release(x_25, 2); - lean_ctor_release(x_25, 3); - lean_ctor_release(x_25, 4); - lean_ctor_release(x_25, 5); - x_32 = x_25; +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + lean_ctor_release(x_24, 1); + lean_ctor_release(x_24, 2); + lean_ctor_release(x_24, 3); + lean_ctor_release(x_24, 4); + lean_ctor_release(x_24, 5); + x_31 = x_24; } else { - lean_dec_ref(x_25); - x_32 = lean_box(0); + lean_dec_ref(x_24); + x_31 = lean_box(0); } -if (lean_is_scalar(x_32)) { - x_33 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_31)) { + x_32 = lean_alloc_ctor(0, 6, 0); } else { - x_33 = x_32; + x_32 = x_31; } -lean_ctor_set(x_33, 0, x_27); -lean_ctor_set(x_33, 1, x_28); -lean_ctor_set(x_33, 2, x_7); -lean_ctor_set(x_33, 3, x_29); -lean_ctor_set(x_33, 4, x_30); -lean_ctor_set(x_33, 5, x_31); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_26); -lean_ctor_set(x_34, 1, x_33); -return x_34; +lean_ctor_set(x_32, 0, x_26); +lean_ctor_set(x_32, 1, x_27); +lean_ctor_set(x_32, 2, x_6); +lean_ctor_set(x_32, 3, x_28); +lean_ctor_set(x_32, 4, x_29); +lean_ctor_set(x_32, 5, x_30); +x_33 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_33, 0, x_25); +lean_ctor_set(x_33, 1, x_32); +return x_33; } } else { -uint8_t x_35; -x_35 = !lean_is_exclusive(x_14); -if (x_35 == 0) +uint8_t x_34; +x_34 = !lean_is_exclusive(x_13); +if (x_34 == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_14, 1); -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_13, 1); +x_36 = !lean_is_exclusive(x_35); +if (x_36 == 0) { -lean_object* x_38; -x_38 = lean_ctor_get(x_36, 2); -lean_dec(x_38); -lean_ctor_set(x_36, 2, x_7); -return x_14; +lean_object* x_37; +x_37 = lean_ctor_get(x_35, 2); +lean_dec(x_37); +lean_ctor_set(x_35, 2, x_6); +return x_13; } else { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_36, 0); -x_40 = lean_ctor_get(x_36, 1); -x_41 = lean_ctor_get(x_36, 3); -x_42 = lean_ctor_get(x_36, 4); -x_43 = lean_ctor_get(x_36, 5); -lean_inc(x_43); +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_38 = lean_ctor_get(x_35, 0); +x_39 = lean_ctor_get(x_35, 1); +x_40 = lean_ctor_get(x_35, 3); +x_41 = lean_ctor_get(x_35, 4); +x_42 = lean_ctor_get(x_35, 5); lean_inc(x_42); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); -lean_dec(x_36); -x_44 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_7); -lean_ctor_set(x_44, 3, x_41); -lean_ctor_set(x_44, 4, x_42); -lean_ctor_set(x_44, 5, x_43); -lean_ctor_set(x_14, 1, x_44); -return x_14; +lean_inc(x_38); +lean_dec(x_35); +x_43 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_43, 0, x_38); +lean_ctor_set(x_43, 1, x_39); +lean_ctor_set(x_43, 2, x_6); +lean_ctor_set(x_43, 3, x_40); +lean_ctor_set(x_43, 4, x_41); +lean_ctor_set(x_43, 5, x_42); +lean_ctor_set(x_13, 1, x_43); +return x_13; } } else { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_45 = lean_ctor_get(x_14, 1); -x_46 = lean_ctor_get(x_14, 0); +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_44 = lean_ctor_get(x_13, 1); +x_45 = lean_ctor_get(x_13, 0); +lean_inc(x_44); lean_inc(x_45); +lean_dec(x_13); +x_46 = lean_ctor_get(x_44, 0); lean_inc(x_46); -lean_dec(x_14); -x_47 = lean_ctor_get(x_45, 0); +x_47 = lean_ctor_get(x_44, 1); lean_inc(x_47); -x_48 = lean_ctor_get(x_45, 1); +x_48 = lean_ctor_get(x_44, 3); lean_inc(x_48); -x_49 = lean_ctor_get(x_45, 3); +x_49 = lean_ctor_get(x_44, 4); lean_inc(x_49); -x_50 = lean_ctor_get(x_45, 4); +x_50 = lean_ctor_get(x_44, 5); lean_inc(x_50); -x_51 = lean_ctor_get(x_45, 5); -lean_inc(x_51); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - lean_ctor_release(x_45, 3); - lean_ctor_release(x_45, 4); - lean_ctor_release(x_45, 5); - x_52 = x_45; +if (lean_is_exclusive(x_44)) { + lean_ctor_release(x_44, 0); + lean_ctor_release(x_44, 1); + lean_ctor_release(x_44, 2); + lean_ctor_release(x_44, 3); + lean_ctor_release(x_44, 4); + lean_ctor_release(x_44, 5); + x_51 = x_44; } else { - lean_dec_ref(x_45); - x_52 = lean_box(0); + lean_dec_ref(x_44); + x_51 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_51)) { + x_52 = lean_alloc_ctor(0, 6, 0); } else { - x_53 = x_52; + x_52 = x_51; } -lean_ctor_set(x_53, 0, x_47); -lean_ctor_set(x_53, 1, x_48); -lean_ctor_set(x_53, 2, x_7); -lean_ctor_set(x_53, 3, x_49); -lean_ctor_set(x_53, 4, x_50); -lean_ctor_set(x_53, 5, x_51); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_46); -lean_ctor_set(x_54, 1, x_53); -return x_54; +lean_ctor_set(x_52, 0, x_46); +lean_ctor_set(x_52, 1, x_47); +lean_ctor_set(x_52, 2, x_6); +lean_ctor_set(x_52, 3, x_48); +lean_ctor_set(x_52, 4, x_49); +lean_ctor_set(x_52, 5, x_50); +x_53 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_53, 0, x_45); +lean_ctor_set(x_53, 1, x_52); +return x_53; } } } } -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1(x_1, x_2, x_3, x_4); +lean_dec(x_2); +return x_5; +} +} +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l___private_Init_Lean_Meta_Check_3__checkForall___lambda__1(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_3); +x_6 = l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); return x_6; } } -lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l___private_Init_Lean_Meta_Check_3__checkForall___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -return x_7; -} -} lean_object* l___private_Init_Lean_Meta_Check_4__checkConstant(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -981,170 +1000,573 @@ lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_Check_5__checkApp(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Meta_Check_5__checkApp(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_8; -lean_inc(x_3); -lean_inc(x_6); +lean_object* x_6; +lean_inc(x_1); lean_inc(x_4); -x_8 = lean_apply_3(x_3, x_4, x_6, x_7); +lean_inc(x_2); +x_6 = lean_apply_3(x_1, x_2, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +lean_inc(x_4); +lean_inc(x_3); +x_8 = lean_apply_3(x_1, x_3, x_4, x_7); if (lean_obj_tag(x_8) == 0) { lean_object* x_9; lean_object* x_10; x_9 = lean_ctor_get(x_8, 1); lean_inc(x_9); lean_dec(x_8); -lean_inc(x_6); -lean_inc(x_5); -x_10 = lean_apply_3(x_3, x_5, x_6, x_9); +lean_inc(x_4); +lean_inc(x_2); +x_10 = l_Lean_Meta_inferType(x_2, x_4, x_9); if (lean_obj_tag(x_10) == 0) { lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_10, 1); +x_11 = lean_ctor_get(x_10, 0); lean_inc(x_11); -lean_dec(x_10); -lean_inc(x_1); -x_12 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 1); -lean_closure_set(x_12, 0, x_1); -lean_inc(x_6); -lean_inc(x_4); +x_12 = lean_ctor_get(x_10, 1); lean_inc(x_12); -x_13 = l_Lean_Meta_inferTypeAuxAux___main(x_12, x_4, x_6, x_11); +lean_dec(x_10); +lean_inc(x_4); +x_13 = l_Lean_Meta_whnf(x_11, x_4, x_12); if (lean_obj_tag(x_13) == 0) { -lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; x_14 = lean_ctor_get(x_13, 0); lean_inc(x_14); x_15 = lean_ctor_get(x_13, 1); lean_inc(x_15); -lean_dec(x_13); -lean_inc(x_6); -x_16 = lean_apply_3(x_1, x_14, x_6, x_15); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -if (lean_is_exclusive(x_16)) { - lean_ctor_release(x_16, 0); - lean_ctor_release(x_16, 1); - x_19 = x_16; +if (lean_is_exclusive(x_13)) { + lean_ctor_release(x_13, 0); + lean_ctor_release(x_13, 1); + x_16 = x_13; } else { - lean_dec_ref(x_16); - x_19 = lean_box(0); + lean_dec_ref(x_13); + x_16 = lean_box(0); } -if (lean_obj_tag(x_17) == 7) +if (lean_obj_tag(x_14) == 7) { -lean_object* x_31; lean_object* x_32; -lean_dec(x_19); -x_31 = lean_ctor_get(x_17, 1); +lean_object* x_28; lean_object* x_29; +lean_dec(x_16); +x_28 = lean_ctor_get(x_14, 1); +lean_inc(x_28); +lean_dec(x_14); +lean_inc(x_4); +lean_inc(x_3); +x_29 = l_Lean_Meta_inferType(x_3, x_4, x_15); +if (lean_obj_tag(x_29) == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_29, 1); lean_inc(x_31); -lean_dec(x_17); -lean_inc(x_6); -lean_inc(x_5); -x_32 = l_Lean_Meta_inferTypeAuxAux___main(x_12, x_5, x_6, x_18); +lean_dec(x_29); +lean_inc(x_4); +x_32 = l_Lean_Meta_isExprDefEqAux(x_28, x_30, x_4, x_31); if (lean_obj_tag(x_32) == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; +lean_object* x_33; uint8_t x_34; x_33 = lean_ctor_get(x_32, 0); lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); -lean_inc(x_34); -lean_dec(x_32); -lean_inc(x_6); -x_35 = lean_apply_4(x_2, x_31, x_33, x_6, x_34); -if (lean_obj_tag(x_35) == 0) +x_34 = lean_unbox(x_33); +lean_dec(x_33); +if (x_34 == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_unbox(x_36); -lean_dec(x_36); -if (x_37 == 0) +uint8_t x_35; +x_35 = !lean_is_exclusive(x_32); +if (x_35 == 0) { -uint8_t x_38; -x_38 = !lean_is_exclusive(x_35); -if (x_38 == 0) -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_39 = lean_ctor_get(x_35, 1); -x_40 = lean_ctor_get(x_35, 0); -lean_dec(x_40); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_6, 1); -lean_inc(x_43); -lean_dec(x_6); -x_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_41); -lean_ctor_set(x_44, 1, x_42); -lean_ctor_set(x_44, 2, x_43); -x_45 = lean_alloc_ctor(12, 3, 0); -lean_ctor_set(x_45, 0, x_4); -lean_ctor_set(x_45, 1, x_5); -lean_ctor_set(x_45, 2, x_44); -lean_ctor_set_tag(x_35, 1); -lean_ctor_set(x_35, 0, x_45); -return x_35; -} -else -{ -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_46 = lean_ctor_get(x_35, 1); -lean_inc(x_46); -lean_dec(x_35); -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_6, 1); -lean_inc(x_49); -lean_dec(x_6); -x_50 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_48); -lean_ctor_set(x_50, 2, x_49); -x_51 = lean_alloc_ctor(12, 3, 0); -lean_ctor_set(x_51, 0, x_4); -lean_ctor_set(x_51, 1, x_5); -lean_ctor_set(x_51, 2, x_50); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_46); -return x_52; -} -} -else -{ -uint8_t x_53; -lean_dec(x_6); -lean_dec(x_5); +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_36 = lean_ctor_get(x_32, 1); +x_37 = lean_ctor_get(x_32, 0); +lean_dec(x_37); +x_38 = lean_ctor_get(x_36, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_36, 1); +lean_inc(x_39); +x_40 = lean_ctor_get(x_4, 1); +lean_inc(x_40); lean_dec(x_4); -x_53 = !lean_is_exclusive(x_35); -if (x_53 == 0) +x_41 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_41, 0, x_38); +lean_ctor_set(x_41, 1, x_39); +lean_ctor_set(x_41, 2, x_40); +x_42 = lean_alloc_ctor(13, 3, 0); +lean_ctor_set(x_42, 0, x_2); +lean_ctor_set(x_42, 1, x_3); +lean_ctor_set(x_42, 2, x_41); +lean_ctor_set_tag(x_32, 1); +lean_ctor_set(x_32, 0, x_42); +return x_32; +} +else { -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_35, 0); -lean_dec(x_54); -x_55 = lean_box(0); -lean_ctor_set(x_35, 0, x_55); -return x_35; +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_43 = lean_ctor_get(x_32, 1); +lean_inc(x_43); +lean_dec(x_32); +x_44 = lean_ctor_get(x_43, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_43, 1); +lean_inc(x_45); +x_46 = lean_ctor_get(x_4, 1); +lean_inc(x_46); +lean_dec(x_4); +x_47 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_47, 0, x_44); +lean_ctor_set(x_47, 1, x_45); +lean_ctor_set(x_47, 2, x_46); +x_48 = lean_alloc_ctor(13, 3, 0); +lean_ctor_set(x_48, 0, x_2); +lean_ctor_set(x_48, 1, x_3); +lean_ctor_set(x_48, 2, x_47); +x_49 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_43); +return x_49; +} +} +else +{ +uint8_t x_50; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_50 = !lean_is_exclusive(x_32); +if (x_50 == 0) +{ +lean_object* x_51; lean_object* x_52; +x_51 = lean_ctor_get(x_32, 0); +lean_dec(x_51); +x_52 = lean_box(0); +lean_ctor_set(x_32, 0, x_52); +return x_32; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_32, 1); +lean_inc(x_53); +lean_dec(x_32); +x_54 = lean_box(0); +x_55 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_55, 0, x_54); +lean_ctor_set(x_55, 1, x_53); +return x_55; +} +} +} +else +{ +uint8_t x_56; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_56 = !lean_is_exclusive(x_32); +if (x_56 == 0) +{ +return x_32; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_57 = lean_ctor_get(x_32, 0); +x_58 = lean_ctor_get(x_32, 1); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_32); +x_59 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_59, 0, x_57); +lean_ctor_set(x_59, 1, x_58); +return x_59; +} +} +} +else +{ +uint8_t x_60; +lean_dec(x_28); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_60 = !lean_is_exclusive(x_29); +if (x_60 == 0) +{ +return x_29; +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_61 = lean_ctor_get(x_29, 0); +x_62 = lean_ctor_get(x_29, 1); +lean_inc(x_62); +lean_inc(x_61); +lean_dec(x_29); +x_63 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_63, 0, x_61); +lean_ctor_set(x_63, 1, x_62); +return x_63; +} +} +} +else +{ +lean_object* x_64; +x_64 = lean_box(0); +x_17 = x_64; +goto block_27; +} +block_27: +{ +uint8_t x_18; +lean_dec(x_17); +x_18 = l_Lean_Expr_isForall(x_14); +lean_dec(x_14); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_19 = lean_ctor_get(x_15, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_15, 1); +lean_inc(x_20); +x_21 = lean_ctor_get(x_4, 1); +lean_inc(x_21); +lean_dec(x_4); +x_22 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_22, 0, x_19); +lean_ctor_set(x_22, 1, x_20); +lean_ctor_set(x_22, 2, x_21); +x_23 = lean_alloc_ctor(5, 3, 0); +lean_ctor_set(x_23, 0, x_2); +lean_ctor_set(x_23, 1, x_3); +lean_ctor_set(x_23, 2, x_22); +if (lean_is_scalar(x_16)) { + x_24 = lean_alloc_ctor(1, 2, 0); +} else { + x_24 = x_16; + lean_ctor_set_tag(x_24, 1); +} +lean_ctor_set(x_24, 0, x_23); +lean_ctor_set(x_24, 1, x_15); +return x_24; +} +else +{ +lean_object* x_25; lean_object* x_26; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_25 = lean_box(0); +if (lean_is_scalar(x_16)) { + x_26 = lean_alloc_ctor(0, 2, 0); +} else { + x_26 = x_16; +} +lean_ctor_set(x_26, 0, x_25); +lean_ctor_set(x_26, 1, x_15); +return x_26; +} +} +} +else +{ +uint8_t x_65; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_65 = !lean_is_exclusive(x_13); +if (x_65 == 0) +{ +return x_13; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_66 = lean_ctor_get(x_13, 0); +x_67 = lean_ctor_get(x_13, 1); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_13); +x_68 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +return x_68; +} +} +} +else +{ +uint8_t x_69; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_69 = !lean_is_exclusive(x_10); +if (x_69 == 0) +{ +return x_10; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_10, 0); +x_71 = lean_ctor_get(x_10, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_10); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_73 = !lean_is_exclusive(x_8); +if (x_73 == 0) +{ +return x_8; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_8, 0); +x_75 = lean_ctor_get(x_8, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_8); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_77 = !lean_is_exclusive(x_6); +if (x_77 == 0) +{ +return x_6; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_6, 0); +x_79 = lean_ctor_get(x_6, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_6); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Check_5__checkApp___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +lean_inc(x_1); +x_5 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_1, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; +x_6 = lean_ctor_get(x_5, 1); +lean_inc(x_6); +lean_dec(x_5); +lean_inc(x_3); +lean_inc(x_2); +x_7 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_2, x_3, x_6); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; lean_object* x_9; +x_8 = lean_ctor_get(x_7, 1); +lean_inc(x_8); +lean_dec(x_7); +lean_inc(x_3); +lean_inc(x_1); +x_9 = l_Lean_Meta_inferType(x_1, x_3, x_8); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_9, 1); +lean_inc(x_11); +lean_dec(x_9); +lean_inc(x_3); +x_12 = l_Lean_Meta_whnf(x_10, x_3, x_11); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 1); +lean_inc(x_14); +if (lean_is_exclusive(x_12)) { + lean_ctor_release(x_12, 0); + lean_ctor_release(x_12, 1); + x_15 = x_12; +} else { + lean_dec_ref(x_12); + x_15 = lean_box(0); +} +if (lean_obj_tag(x_13) == 7) +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_15); +x_27 = lean_ctor_get(x_13, 1); +lean_inc(x_27); +lean_dec(x_13); +lean_inc(x_3); +lean_inc(x_2); +x_28 = l_Lean_Meta_inferType(x_2, x_3, x_14); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +lean_inc(x_3); +x_31 = l_Lean_Meta_isExprDefEqAux(x_27, x_29, x_3, x_30); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; uint8_t x_33; +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_unbox(x_32); +lean_dec(x_32); +if (x_33 == 0) +{ +uint8_t x_34; +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_35 = lean_ctor_get(x_31, 1); +x_36 = lean_ctor_get(x_31, 0); +lean_dec(x_36); +x_37 = lean_ctor_get(x_35, 0); +lean_inc(x_37); +x_38 = lean_ctor_get(x_35, 1); +lean_inc(x_38); +x_39 = lean_ctor_get(x_3, 1); +lean_inc(x_39); +lean_dec(x_3); +x_40 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_40, 0, x_37); +lean_ctor_set(x_40, 1, x_38); +lean_ctor_set(x_40, 2, x_39); +x_41 = lean_alloc_ctor(13, 3, 0); +lean_ctor_set(x_41, 0, x_1); +lean_ctor_set(x_41, 1, x_2); +lean_ctor_set(x_41, 2, x_40); +lean_ctor_set_tag(x_31, 1); +lean_ctor_set(x_31, 0, x_41); +return x_31; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_42 = lean_ctor_get(x_31, 1); +lean_inc(x_42); +lean_dec(x_31); +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_42, 1); +lean_inc(x_44); +x_45 = lean_ctor_get(x_3, 1); +lean_inc(x_45); +lean_dec(x_3); +x_46 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_46, 0, x_43); +lean_ctor_set(x_46, 1, x_44); +lean_ctor_set(x_46, 2, x_45); +x_47 = lean_alloc_ctor(13, 3, 0); +lean_ctor_set(x_47, 0, x_1); +lean_ctor_set(x_47, 1, x_2); +lean_ctor_set(x_47, 2, x_46); +x_48 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_48, 0, x_47); +lean_ctor_set(x_48, 1, x_42); +return x_48; +} +} +else +{ +uint8_t x_49; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_49 = !lean_is_exclusive(x_31); +if (x_49 == 0) +{ +lean_object* x_50; lean_object* x_51; +x_50 = lean_ctor_get(x_31, 0); +lean_dec(x_50); +x_51 = lean_box(0); +lean_ctor_set(x_31, 0, x_51); +return x_31; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_31, 1); +lean_inc(x_52); +lean_dec(x_31); +x_53 = lean_box(0); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_53); +lean_ctor_set(x_54, 1, x_52); +return x_54; +} +} +} +else +{ +uint8_t x_55; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_55 = !lean_is_exclusive(x_31); +if (x_55 == 0) +{ +return x_31; } else { lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_35, 1); +x_56 = lean_ctor_get(x_31, 0); +x_57 = lean_ctor_get(x_31, 1); +lean_inc(x_57); lean_inc(x_56); -lean_dec(x_35); -x_57 = lean_box(0); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_56); +lean_dec(x_31); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_56); +lean_ctor_set(x_58, 1, x_57); return x_58; } } @@ -1152,22 +1574,23 @@ return x_58; else { uint8_t x_59; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_59 = !lean_is_exclusive(x_35); +lean_dec(x_27); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_59 = !lean_is_exclusive(x_28); if (x_59 == 0) { -return x_35; +return x_28; } else { lean_object* x_60; lean_object* x_61; lean_object* x_62; -x_60 = lean_ctor_get(x_35, 0); -x_61 = lean_ctor_get(x_35, 1); +x_60 = lean_ctor_get(x_28, 0); +x_61 = lean_ctor_get(x_28, 1); lean_inc(x_61); lean_inc(x_60); -lean_dec(x_35); +lean_dec(x_28); x_62 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_62, 0, x_60); lean_ctor_set(x_62, 1, x_61); @@ -1177,114 +1600,108 @@ return x_62; } else { -uint8_t x_63; -lean_dec(x_31); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_63 = !lean_is_exclusive(x_32); -if (x_63 == 0) +lean_object* x_63; +x_63 = lean_box(0); +x_16 = x_63; +goto block_26; +} +block_26: { -return x_32; +uint8_t x_17; +lean_dec(x_16); +x_17 = l_Lean_Expr_isForall(x_13); +lean_dec(x_13); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_18 = lean_ctor_get(x_14, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_14, 1); +lean_inc(x_19); +x_20 = lean_ctor_get(x_3, 1); +lean_inc(x_20); +lean_dec(x_3); +x_21 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_21, 0, x_18); +lean_ctor_set(x_21, 1, x_19); +lean_ctor_set(x_21, 2, x_20); +x_22 = lean_alloc_ctor(5, 3, 0); +lean_ctor_set(x_22, 0, x_1); +lean_ctor_set(x_22, 1, x_2); +lean_ctor_set(x_22, 2, x_21); +if (lean_is_scalar(x_15)) { + x_23 = lean_alloc_ctor(1, 2, 0); +} else { + x_23 = x_15; + lean_ctor_set_tag(x_23, 1); +} +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_14); +return x_23; } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_32, 0); -x_65 = lean_ctor_get(x_32, 1); +lean_object* x_24; lean_object* x_25; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_24 = lean_box(0); +if (lean_is_scalar(x_15)) { + x_25 = lean_alloc_ctor(0, 2, 0); +} else { + x_25 = x_15; +} +lean_ctor_set(x_25, 0, x_24); +lean_ctor_set(x_25, 1, x_14); +return x_25; +} +} +} +else +{ +uint8_t x_64; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_64 = !lean_is_exclusive(x_12); +if (x_64 == 0) +{ +return x_12; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_12, 0); +x_66 = lean_ctor_get(x_12, 1); +lean_inc(x_66); lean_inc(x_65); -lean_inc(x_64); -lean_dec(x_32); -x_66 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_66, 0, x_64); -lean_ctor_set(x_66, 1, x_65); -return x_66; -} -} -} -else -{ -lean_object* x_67; lean_dec(x_12); -lean_dec(x_2); -x_67 = lean_box(0); -x_20 = x_67; -goto block_30; -} -block_30: -{ -uint8_t x_21; -lean_dec(x_20); -x_21 = l_Lean_Expr_isForall(x_17); -lean_dec(x_17); -if (x_21 == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_22 = lean_ctor_get(x_18, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_18, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_6, 1); -lean_inc(x_24); -lean_dec(x_6); -x_25 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_25, 0, x_22); -lean_ctor_set(x_25, 1, x_23); -lean_ctor_set(x_25, 2, x_24); -x_26 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_26, 0, x_4); -lean_ctor_set(x_26, 1, x_5); -lean_ctor_set(x_26, 2, x_25); -if (lean_is_scalar(x_19)) { - x_27 = lean_alloc_ctor(1, 2, 0); -} else { - x_27 = x_19; - lean_ctor_set_tag(x_27, 1); -} -lean_ctor_set(x_27, 0, x_26); -lean_ctor_set(x_27, 1, x_18); -return x_27; -} -else -{ -lean_object* x_28; lean_object* x_29; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_28 = lean_box(0); -if (lean_is_scalar(x_19)) { - x_29 = lean_alloc_ctor(0, 2, 0); -} else { - x_29 = x_19; -} -lean_ctor_set(x_29, 0, x_28); -lean_ctor_set(x_29, 1, x_18); -return x_29; +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; } } } else { uint8_t x_68; -lean_dec(x_12); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); -x_68 = !lean_is_exclusive(x_16); +lean_dec(x_1); +x_68 = !lean_is_exclusive(x_9); if (x_68 == 0) { -return x_16; +return x_9; } else { lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_16, 0); -x_70 = lean_ctor_get(x_16, 1); +x_69 = lean_ctor_get(x_9, 0); +x_70 = lean_ctor_get(x_9, 1); lean_inc(x_70); lean_inc(x_69); -lean_dec(x_16); +lean_dec(x_9); x_71 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_71, 0, x_69); lean_ctor_set(x_71, 1, x_70); @@ -1295,25 +1712,22 @@ return x_71; else { uint8_t x_72; -lean_dec(x_12); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_72 = !lean_is_exclusive(x_13); +x_72 = !lean_is_exclusive(x_7); if (x_72 == 0) { -return x_13; +return x_7; } else { lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_13, 0); -x_74 = lean_ctor_get(x_13, 1); +x_73 = lean_ctor_get(x_7, 0); +x_74 = lean_ctor_get(x_7, 1); lean_inc(x_74); lean_inc(x_73); -lean_dec(x_13); +lean_dec(x_7); x_75 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_75, 0, x_73); lean_ctor_set(x_75, 1, x_74); @@ -1324,24 +1738,22 @@ return x_75; else { uint8_t x_76; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_76 = !lean_is_exclusive(x_10); +x_76 = !lean_is_exclusive(x_5); if (x_76 == 0) { -return x_10; +return x_5; } else { lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_10, 0); -x_78 = lean_ctor_get(x_10, 1); +x_77 = lean_ctor_get(x_5, 0); +x_78 = lean_ctor_get(x_5, 1); lean_inc(x_78); lean_inc(x_77); -lean_dec(x_10); +lean_dec(x_5); x_79 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_79, 0, x_77); lean_ctor_set(x_79, 1, x_78); @@ -1349,292 +1761,2935 @@ return x_79; } } } -else -{ -uint8_t x_80; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_80 = !lean_is_exclusive(x_8); -if (x_80 == 0) -{ -return x_8; } -else -{ -lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_8, 0); -x_82 = lean_ctor_get(x_8, 1); -lean_inc(x_82); -lean_inc(x_81); -lean_dec(x_8); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -return x_83; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Check_6__checkAuxAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -switch (lean_obj_tag(x_3)) { -case 4: +lean_object* x_5; uint8_t x_6; +x_5 = lean_array_get_size(x_1); +x_6 = lean_nat_dec_lt(x_2, x_5); +lean_dec(x_5); +if (x_6 == 0) { -lean_object* x_6; lean_object* x_7; lean_object* x_8; -lean_dec(x_2); -lean_dec(x_1); -x_6 = lean_ctor_get(x_3, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_3, 1); -lean_inc(x_7); +lean_object* x_7; lean_object* x_8; lean_dec(x_3); -x_8 = l___private_Init_Lean_Meta_Check_4__checkConstant(x_6, x_7, x_4, x_5); -lean_dec(x_4); +lean_dec(x_2); +x_7 = lean_box(0); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_4); return x_8; } -case 5: +else { lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_3, 0); -lean_inc(x_9); -x_10 = lean_ctor_get(x_3, 1); -lean_inc(x_10); -lean_dec(x_3); -lean_inc(x_2); -lean_inc(x_1); -x_11 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_6__checkAuxAux___main), 5, 2); -lean_closure_set(x_11, 0, x_1); -lean_closure_set(x_11, 1, x_2); -x_12 = l___private_Init_Lean_Meta_Check_5__checkApp(x_1, x_2, x_11, x_9, x_10, x_4, x_5); -return x_12; -} -case 6: +x_9 = lean_array_fget(x_1, x_2); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_2, x_10); +lean_dec(x_2); +lean_inc(x_3); +x_12 = l_Lean_Meta_getFVarLocalDecl(x_9, x_3, x_4); +if (lean_obj_tag(x_12) == 0) { -lean_object* x_13; lean_object* x_14; -lean_inc(x_2); -lean_inc(x_1); -x_13 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_6__checkAuxAux___main), 5, 2); -lean_closure_set(x_13, 0, x_1); -lean_closure_set(x_13, 1, x_2); -x_14 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet(x_1, x_2, x_13, x_3, x_4, x_5); -return x_14; -} -case 7: +lean_object* x_13; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +if (lean_obj_tag(x_13) == 0) { -lean_object* x_15; lean_object* x_16; -lean_inc(x_1); -x_15 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_6__checkAuxAux___main), 5, 2); -lean_closure_set(x_15, 0, x_1); -lean_closure_set(x_15, 1, x_2); -x_16 = l___private_Init_Lean_Meta_Check_3__checkForall(x_1, x_15, x_3, x_4, x_5); -return x_16; -} -case 8: +lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_9); +x_14 = lean_ctor_get(x_12, 1); +lean_inc(x_14); +lean_dec(x_12); +x_15 = lean_ctor_get(x_13, 3); +lean_inc(x_15); +lean_dec(x_13); +lean_inc(x_3); +lean_inc(x_15); +x_16 = l___private_Init_Lean_Meta_Check_1__ensureType(x_15, x_3, x_14); +if (lean_obj_tag(x_16) == 0) { lean_object* x_17; lean_object* x_18; -lean_inc(x_2); -lean_inc(x_1); -x_17 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_Check_6__checkAuxAux___main), 5, 2); -lean_closure_set(x_17, 0, x_1); -lean_closure_set(x_17, 1, x_2); -x_18 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet(x_1, x_2, x_17, x_3, x_4, x_5); -return x_18; -} -case 10: +x_17 = lean_ctor_get(x_16, 1); +lean_inc(x_17); +lean_dec(x_16); +lean_inc(x_3); +x_18 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_15, x_3, x_17); +if (lean_obj_tag(x_18) == 0) { lean_object* x_19; -x_19 = lean_ctor_get(x_3, 1); +x_19 = lean_ctor_get(x_18, 1); lean_inc(x_19); -lean_dec(x_3); -x_3 = x_19; +lean_dec(x_18); +x_2 = x_11; +x_4 = x_19; goto _start; } -case 11: +else { -lean_object* x_21; -x_21 = lean_ctor_get(x_3, 2); -lean_inc(x_21); +uint8_t x_21; +lean_dec(x_11); lean_dec(x_3); -x_3 = x_21; -goto _start; +x_21 = !lean_is_exclusive(x_18); +if (x_21 == 0) +{ +return x_18; } -default: +else { -lean_object* x_23; lean_object* x_24; -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_23 = lean_box(0); -x_24 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_24, 0, x_23); -lean_ctor_set(x_24, 1, x_5); +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_18, 0); +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_18); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); return x_24; } } } -} -lean_object* l___private_Init_Lean_Meta_Check_6__checkAuxAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: +else { -lean_object* x_6; -x_6 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main(x_1, x_2, x_3, x_4, x_5); -return x_6; -} -} -lean_object* l_Lean_Meta_checkAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: +uint8_t x_25; +lean_dec(x_15); +lean_dec(x_11); +lean_dec(x_3); +x_25 = !lean_is_exclusive(x_16); +if (x_25 == 0) { -uint8_t x_6; -x_6 = !lean_is_exclusive(x_4); -if (x_6 == 0) +return x_16; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_16, 0); +x_27 = lean_ctor_get(x_16, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_16); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_29 = lean_ctor_get(x_12, 1); +lean_inc(x_29); +lean_dec(x_12); +x_30 = lean_ctor_get(x_13, 3); +lean_inc(x_30); +x_31 = lean_ctor_get(x_13, 4); +lean_inc(x_31); +lean_dec(x_13); +lean_inc(x_3); +lean_inc(x_30); +x_32 = l___private_Init_Lean_Meta_Check_1__ensureType(x_30, x_3, x_29); +if (lean_obj_tag(x_32) == 0) +{ +lean_object* x_33; lean_object* x_34; +x_33 = lean_ctor_get(x_32, 1); +lean_inc(x_33); +lean_dec(x_32); +lean_inc(x_3); +lean_inc(x_30); +x_34 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_30, x_3, x_33); +if (lean_obj_tag(x_34) == 0) +{ +lean_object* x_35; lean_object* x_36; +x_35 = lean_ctor_get(x_34, 1); +lean_inc(x_35); +lean_dec(x_34); +lean_inc(x_3); +lean_inc(x_31); +x_36 = l_Lean_Meta_inferType(x_31, x_3, x_35); +if (lean_obj_tag(x_36) == 0) +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +x_38 = lean_ctor_get(x_36, 1); +lean_inc(x_38); +lean_dec(x_36); +lean_inc(x_3); +x_39 = l_Lean_Meta_isExprDefEqAux(x_30, x_37, x_3, x_38); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_unbox(x_40); +lean_dec(x_40); +if (x_41 == 0) +{ +uint8_t x_42; +lean_dec(x_31); +lean_dec(x_11); +x_42 = !lean_is_exclusive(x_39); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_43 = lean_ctor_get(x_39, 1); +x_44 = lean_ctor_get(x_39, 0); +lean_dec(x_44); +x_45 = lean_ctor_get(x_43, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_43, 1); +lean_inc(x_46); +x_47 = lean_ctor_get(x_3, 1); +lean_inc(x_47); +lean_dec(x_3); +x_48 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_48, 0, x_45); +lean_ctor_set(x_48, 1, x_46); +lean_ctor_set(x_48, 2, x_47); +x_49 = l_Lean_Expr_fvarId_x21(x_9); +lean_dec(x_9); +x_50 = lean_alloc_ctor(12, 2, 0); +lean_ctor_set(x_50, 0, x_49); +lean_ctor_set(x_50, 1, x_48); +lean_ctor_set_tag(x_39, 1); +lean_ctor_set(x_39, 0, x_50); +return x_39; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_51 = lean_ctor_get(x_39, 1); +lean_inc(x_51); +lean_dec(x_39); +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +x_54 = lean_ctor_get(x_3, 1); +lean_inc(x_54); +lean_dec(x_3); +x_55 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_55, 0, x_52); +lean_ctor_set(x_55, 1, x_53); +lean_ctor_set(x_55, 2, x_54); +x_56 = l_Lean_Expr_fvarId_x21(x_9); +lean_dec(x_9); +x_57 = lean_alloc_ctor(12, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_55); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_57); +lean_ctor_set(x_58, 1, x_51); +return x_58; +} +} +else +{ +lean_object* x_59; lean_object* x_60; +lean_dec(x_9); +x_59 = lean_ctor_get(x_39, 1); +lean_inc(x_59); +lean_dec(x_39); +lean_inc(x_3); +x_60 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_31, x_3, x_59); +if (lean_obj_tag(x_60) == 0) +{ +lean_object* x_61; +x_61 = lean_ctor_get(x_60, 1); +lean_inc(x_61); +lean_dec(x_60); +x_2 = x_11; +x_4 = x_61; +goto _start; +} +else +{ +uint8_t x_63; +lean_dec(x_11); +lean_dec(x_3); +x_63 = !lean_is_exclusive(x_60); +if (x_63 == 0) +{ +return x_60; +} +else +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_64 = lean_ctor_get(x_60, 0); +x_65 = lean_ctor_get(x_60, 1); +lean_inc(x_65); +lean_inc(x_64); +lean_dec(x_60); +x_66 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_66, 0, x_64); +lean_ctor_set(x_66, 1, x_65); +return x_66; +} +} +} +} +else +{ +uint8_t x_67; +lean_dec(x_31); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_3); +x_67 = !lean_is_exclusive(x_39); +if (x_67 == 0) +{ +return x_39; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_39, 0); +x_69 = lean_ctor_get(x_39, 1); +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_39); +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; +} +} +} +else +{ +uint8_t x_71; +lean_dec(x_31); +lean_dec(x_30); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_3); +x_71 = !lean_is_exclusive(x_36); +if (x_71 == 0) +{ +return x_36; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_36, 0); +x_73 = lean_ctor_get(x_36, 1); +lean_inc(x_73); +lean_inc(x_72); +lean_dec(x_36); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_31); +lean_dec(x_30); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_3); +x_75 = !lean_is_exclusive(x_34); +if (x_75 == 0) +{ +return x_34; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_34, 0); +x_77 = lean_ctor_get(x_34, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_34); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +else +{ +uint8_t x_79; +lean_dec(x_31); +lean_dec(x_30); +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_3); +x_79 = !lean_is_exclusive(x_32); +if (x_79 == 0) +{ +return x_32; +} +else +{ +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_32, 0); +x_81 = lean_ctor_get(x_32, 1); +lean_inc(x_81); +lean_inc(x_80); +lean_dec(x_32); +x_82 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_82, 0, x_80); +lean_ctor_set(x_82, 1, x_81); +return x_82; +} +} +} +} +else +{ +uint8_t x_83; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_3); +x_83 = !lean_is_exclusive(x_12); +if (x_83 == 0) +{ +return x_12; +} +else +{ +lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_84 = lean_ctor_get(x_12, 0); +x_85 = lean_ctor_get(x_12, 1); +lean_inc(x_85); +lean_inc(x_84); +lean_dec(x_12); +x_86 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_86, 0, x_84); +lean_ctor_set(x_86, 1, x_85); +return x_86; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: { lean_object* x_7; uint8_t x_8; -x_7 = lean_ctor_get(x_4, 0); -x_8 = !lean_is_exclusive(x_7); +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_lt(x_4, x_7); +lean_dec(x_7); if (x_8 == 0) { -uint8_t x_9; lean_object* x_10; -x_9 = 0; -lean_ctor_set_uint8(x_7, sizeof(void*)*1 + 4, x_9); -x_10 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main(x_1, x_2, x_3, x_4, x_5); +lean_object* x_9; lean_object* x_10; +lean_dec(x_4); +x_9 = lean_unsigned_to_nat(0u); +lean_inc(x_5); +x_10 = l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__3(x_1, x_9, x_5, x_6); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_10, 1); +lean_inc(x_11); +lean_dec(x_10); +x_12 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_2, x_5, x_11); +return x_12; +} +else +{ +uint8_t x_13; +lean_dec(x_5); +lean_dec(x_2); +x_13 = !lean_is_exclusive(x_10); +if (x_13 == 0) +{ return x_10; } else { -lean_object* x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; -x_11 = lean_ctor_get(x_7, 0); -x_12 = lean_ctor_get_uint8(x_7, sizeof(void*)*1); -x_13 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 1); -x_14 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 2); -x_15 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 3); -lean_inc(x_11); -lean_dec(x_7); -x_16 = 0; -x_17 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_17, 0, x_11); -lean_ctor_set_uint8(x_17, sizeof(void*)*1, x_12); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 1, x_13); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 2, x_14); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 3, x_15); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 4, x_16); -lean_ctor_set(x_4, 0, x_17); -x_18 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main(x_1, x_2, x_3, x_4, x_5); +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_10, 0); +x_15 = lean_ctor_get(x_10, 1); +lean_inc(x_15); +lean_inc(x_14); +lean_dec(x_10); +x_16 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_16, 0, x_14); +lean_ctor_set(x_16, 1, x_15); +return x_16; +} +} +} +else +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_array_fget(x_3, x_4); +lean_inc(x_5); +x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_5, x_6); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = l_Lean_LocalDecl_type(x_19); +lean_dec(x_19); +lean_inc(x_5); +lean_inc(x_21); +x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_5, x_20); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +switch (lean_obj_tag(x_23)) { +case 0: +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +lean_dec(x_21); +lean_dec(x_17); +x_24 = lean_ctor_get(x_22, 1); +lean_inc(x_24); +lean_dec(x_22); +x_25 = lean_unsigned_to_nat(1u); +x_26 = lean_nat_add(x_4, x_25); +lean_dec(x_4); +x_4 = x_26; +x_6 = x_24; +goto _start; +} +case 1: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; +lean_dec(x_21); +x_28 = lean_ctor_get(x_22, 1); +lean_inc(x_28); +lean_dec(x_22); +x_29 = lean_ctor_get(x_23, 0); +lean_inc(x_29); +lean_dec(x_23); +x_30 = lean_unsigned_to_nat(1u); +x_31 = lean_nat_add(x_4, x_30); +lean_dec(x_4); +x_32 = !lean_is_exclusive(x_5); +if (x_32 == 0) +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_5, 2); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_29); +lean_ctor_set(x_34, 1, x_17); +x_35 = lean_array_push(x_33, x_34); +lean_ctor_set(x_5, 2, x_35); +x_4 = x_31; +x_6 = x_28; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_37 = lean_ctor_get(x_5, 0); +x_38 = lean_ctor_get(x_5, 1); +x_39 = lean_ctor_get(x_5, 2); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_dec(x_5); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_17); +x_41 = lean_array_push(x_39, x_40); +x_42 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_38); +lean_ctor_set(x_42, 2, x_41); +x_4 = x_31; +x_5 = x_42; +x_6 = x_28; +goto _start; +} +} +default: +{ +lean_object* x_44; lean_object* x_45; +x_44 = lean_ctor_get(x_22, 1); +lean_inc(x_44); +lean_dec(x_22); +lean_inc(x_5); +x_45 = l_Lean_Meta_isClassExpensive___main(x_21, x_5, x_44); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_17); +x_47 = lean_ctor_get(x_45, 1); +lean_inc(x_47); +lean_dec(x_45); +x_48 = lean_unsigned_to_nat(1u); +x_49 = lean_nat_add(x_4, x_48); +lean_dec(x_4); +x_4 = x_49; +x_6 = x_47; +goto _start; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_51 = lean_ctor_get(x_45, 1); +lean_inc(x_51); +lean_dec(x_45); +x_52 = lean_ctor_get(x_46, 0); +lean_inc(x_52); +lean_dec(x_46); +x_53 = lean_unsigned_to_nat(1u); +x_54 = lean_nat_add(x_4, x_53); +lean_dec(x_4); +x_55 = !lean_is_exclusive(x_5); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_5, 2); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_52); +lean_ctor_set(x_57, 1, x_17); +x_58 = lean_array_push(x_56, x_57); +lean_ctor_set(x_5, 2, x_58); +x_4 = x_54; +x_6 = x_51; +goto _start; +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_60 = lean_ctor_get(x_5, 0); +x_61 = lean_ctor_get(x_5, 1); +x_62 = lean_ctor_get(x_5, 2); +lean_inc(x_62); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_5); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_52); +lean_ctor_set(x_63, 1, x_17); +x_64 = lean_array_push(x_62, x_63); +x_65 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_64); +x_4 = x_54; +x_5 = x_65; +x_6 = x_51; +goto _start; +} +} +} +else +{ +uint8_t x_67; +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_67 = !lean_is_exclusive(x_45); +if (x_67 == 0) +{ +return x_45; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_45, 0); +x_69 = lean_ctor_get(x_45, 1); +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_45); +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; +} +} +} +} +} +else +{ +uint8_t x_71; +lean_dec(x_21); +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_71 = !lean_is_exclusive(x_22); +if (x_71 == 0) +{ +return x_22; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_22, 0); +x_73 = lean_ctor_get(x_22, 1); +lean_inc(x_73); +lean_inc(x_72); +lean_dec(x_22); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_75 = !lean_is_exclusive(x_18); +if (x_75 == 0) +{ return x_18; } -} else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_19 = lean_ctor_get(x_4, 0); -x_20 = lean_ctor_get(x_4, 1); -x_21 = lean_ctor_get(x_4, 2); -lean_inc(x_21); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_4); -x_22 = lean_ctor_get(x_19, 0); -lean_inc(x_22); -x_23 = lean_ctor_get_uint8(x_19, sizeof(void*)*1); -x_24 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 1); -x_25 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 2); -x_26 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_19)) { - lean_ctor_release(x_19, 0); - x_27 = x_19; -} else { - lean_dec_ref(x_19); - x_27 = lean_box(0); -} -x_28 = 0; -if (lean_is_scalar(x_27)) { - x_29 = lean_alloc_ctor(0, 1, 5); -} else { - x_29 = x_27; -} -lean_ctor_set(x_29, 0, x_22); -lean_ctor_set_uint8(x_29, sizeof(void*)*1, x_23); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 1, x_24); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 2, x_25); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 3, x_26); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_28); -x_30 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_30, 0, x_29); -lean_ctor_set(x_30, 1, x_20); -lean_ctor_set(x_30, 2, x_21); -x_31 = l___private_Init_Lean_Meta_Check_6__checkAuxAux___main(x_1, x_2, x_3, x_30, x_5); -return x_31; +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_18, 0); +x_77 = lean_ctor_get(x_18, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_18); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; } } } -lean_object* l_Lean_Meta_isTypeCorrectAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +} +} +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_6; -x_6 = l_Lean_Meta_checkAux(x_1, x_2, x_3, x_4, x_5); -if (lean_obj_tag(x_6) == 0) +lean_object* x_7; +switch (lean_obj_tag(x_4)) { +case 6: { -uint8_t x_7; -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) +lean_object* x_18; lean_object* x_19; lean_object* x_20; uint64_t x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_18 = lean_ctor_get(x_4, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_4, 1); +lean_inc(x_19); +x_20 = lean_ctor_get(x_4, 2); +lean_inc(x_20); +x_21 = lean_ctor_get_uint64(x_4, sizeof(void*)*3); +lean_dec(x_4); +x_22 = lean_array_get_size(x_2); +lean_inc(x_2); +x_23 = lean_expr_instantiate_rev_range(x_19, x_3, x_22, x_2); +lean_dec(x_22); +lean_dec(x_19); +x_24 = l_Lean_Meta_mkFreshId___rarg(x_6); +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = (uint8_t)((x_21 << 24) >> 61); +lean_inc(x_25); +x_28 = lean_local_ctx_mk_local_decl(x_1, x_25, x_18, x_23, x_27); +x_29 = l_Lean_mkFVar(x_25); +x_30 = lean_array_push(x_2, x_29); +x_1 = x_28; +x_2 = x_30; +x_4 = x_20; +x_6 = x_26; +goto _start; +} +case 8: { -lean_object* x_8; uint8_t x_9; lean_object* x_10; -x_8 = lean_ctor_get(x_6, 0); +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_32 = lean_ctor_get(x_4, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_4, 1); +lean_inc(x_33); +x_34 = lean_ctor_get(x_4, 2); +lean_inc(x_34); +x_35 = lean_ctor_get(x_4, 3); +lean_inc(x_35); +lean_dec(x_4); +x_36 = lean_array_get_size(x_2); +lean_inc(x_2); +x_37 = lean_expr_instantiate_rev_range(x_33, x_3, x_36, x_2); +lean_dec(x_33); +lean_inc(x_2); +x_38 = lean_expr_instantiate_rev_range(x_34, x_3, x_36, x_2); +lean_dec(x_36); +lean_dec(x_34); +x_39 = l_Lean_Meta_mkFreshId___rarg(x_6); +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +lean_dec(x_39); +lean_inc(x_40); +x_42 = lean_local_ctx_mk_let_decl(x_1, x_40, x_32, x_37, x_38); +x_43 = l_Lean_mkFVar(x_40); +x_44 = lean_array_push(x_2, x_43); +x_1 = x_42; +x_2 = x_44; +x_4 = x_35; +x_6 = x_41; +goto _start; +} +default: +{ +lean_object* x_46; +x_46 = lean_box(0); +x_7 = x_46; +goto block_17; +} +} +block_17: +{ +lean_object* x_8; lean_object* x_9; uint8_t x_10; +lean_dec(x_7); +x_8 = lean_array_get_size(x_2); +lean_inc(x_2); +x_9 = lean_expr_instantiate_rev_range(x_4, x_3, x_8, x_2); lean_dec(x_8); -x_9 = 1; -x_10 = lean_box(x_9); -lean_ctor_set(x_6, 0, x_10); -return x_6; +lean_dec(x_4); +x_10 = !lean_is_exclusive(x_5); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_5, 1); +lean_dec(x_11); +lean_ctor_set(x_5, 1, x_1); +x_12 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__6(x_2, x_9, x_2, x_3, x_5, x_6); +lean_dec(x_2); +return x_12; } else { -lean_object* x_11; uint8_t x_12; lean_object* x_13; lean_object* x_14; -x_11 = lean_ctor_get(x_6, 1); -lean_inc(x_11); -lean_dec(x_6); -x_12 = 1; -x_13 = lean_box(x_12); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_11); -return x_14; +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_5, 0); +x_14 = lean_ctor_get(x_5, 2); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_5); +x_15 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_1); +lean_ctor_set(x_15, 2, x_14); +x_16 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__6(x_2, x_9, x_2, x_3, x_15, x_6); +lean_dec(x_2); +return x_16; } } +} +} +lean_object* l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_4 = lean_ctor_get(x_3, 2); +lean_inc(x_4); +x_5 = lean_ctor_get(x_2, 1); +lean_inc(x_5); +x_6 = l_Array_empty___closed__1; +x_7 = lean_unsigned_to_nat(0u); +x_8 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__5(x_5, x_6, x_7, x_1, x_2, x_3); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_8, 1); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; +x_12 = lean_ctor_get(x_10, 2); +lean_dec(x_12); +lean_ctor_set(x_10, 2, x_4); +return x_8; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_13 = lean_ctor_get(x_10, 0); +x_14 = lean_ctor_get(x_10, 1); +x_15 = lean_ctor_get(x_10, 3); +x_16 = lean_ctor_get(x_10, 4); +x_17 = lean_ctor_get(x_10, 5); +lean_inc(x_17); +lean_inc(x_16); +lean_inc(x_15); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_10); +x_18 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_18, 0, x_13); +lean_ctor_set(x_18, 1, x_14); +lean_ctor_set(x_18, 2, x_4); +lean_ctor_set(x_18, 3, x_15); +lean_ctor_set(x_18, 4, x_16); +lean_ctor_set(x_18, 5, x_17); +lean_ctor_set(x_8, 1, x_18); +return x_8; +} +} +else +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_19 = lean_ctor_get(x_8, 1); +x_20 = lean_ctor_get(x_8, 0); +lean_inc(x_19); +lean_inc(x_20); +lean_dec(x_8); +x_21 = lean_ctor_get(x_19, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +x_23 = lean_ctor_get(x_19, 3); +lean_inc(x_23); +x_24 = lean_ctor_get(x_19, 4); +lean_inc(x_24); +x_25 = lean_ctor_get(x_19, 5); +lean_inc(x_25); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + lean_ctor_release(x_19, 2); + lean_ctor_release(x_19, 3); + lean_ctor_release(x_19, 4); + lean_ctor_release(x_19, 5); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +if (lean_is_scalar(x_26)) { + x_27 = lean_alloc_ctor(0, 6, 0); +} else { + x_27 = x_26; +} +lean_ctor_set(x_27, 0, x_21); +lean_ctor_set(x_27, 1, x_22); +lean_ctor_set(x_27, 2, x_4); +lean_ctor_set(x_27, 3, x_23); +lean_ctor_set(x_27, 4, x_24); +lean_ctor_set(x_27, 5, x_25); +x_28 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_28, 0, x_20); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +else +{ +uint8_t x_29; +x_29 = !lean_is_exclusive(x_8); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_8, 1); +x_31 = !lean_is_exclusive(x_30); +if (x_31 == 0) +{ +lean_object* x_32; +x_32 = lean_ctor_get(x_30, 2); +lean_dec(x_32); +lean_ctor_set(x_30, 2, x_4); +return x_8; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_33 = lean_ctor_get(x_30, 0); +x_34 = lean_ctor_get(x_30, 1); +x_35 = lean_ctor_get(x_30, 3); +x_36 = lean_ctor_get(x_30, 4); +x_37 = lean_ctor_get(x_30, 5); +lean_inc(x_37); +lean_inc(x_36); +lean_inc(x_35); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_30); +x_38 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_38, 0, x_33); +lean_ctor_set(x_38, 1, x_34); +lean_ctor_set(x_38, 2, x_4); +lean_ctor_set(x_38, 3, x_35); +lean_ctor_set(x_38, 4, x_36); +lean_ctor_set(x_38, 5, x_37); +lean_ctor_set(x_8, 1, x_38); +return x_8; +} +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_39 = lean_ctor_get(x_8, 1); +x_40 = lean_ctor_get(x_8, 0); +lean_inc(x_39); +lean_inc(x_40); +lean_dec(x_8); +x_41 = lean_ctor_get(x_39, 0); +lean_inc(x_41); +x_42 = lean_ctor_get(x_39, 1); +lean_inc(x_42); +x_43 = lean_ctor_get(x_39, 3); +lean_inc(x_43); +x_44 = lean_ctor_get(x_39, 4); +lean_inc(x_44); +x_45 = lean_ctor_get(x_39, 5); +lean_inc(x_45); +if (lean_is_exclusive(x_39)) { + lean_ctor_release(x_39, 0); + lean_ctor_release(x_39, 1); + lean_ctor_release(x_39, 2); + lean_ctor_release(x_39, 3); + lean_ctor_release(x_39, 4); + lean_ctor_release(x_39, 5); + x_46 = x_39; +} else { + lean_dec_ref(x_39); + x_46 = lean_box(0); +} +if (lean_is_scalar(x_46)) { + x_47 = lean_alloc_ctor(0, 6, 0); +} else { + x_47 = x_46; +} +lean_ctor_set(x_47, 0, x_41); +lean_ctor_set(x_47, 1, x_42); +lean_ctor_set(x_47, 2, x_4); +lean_ctor_set(x_47, 3, x_43); +lean_ctor_set(x_47, 4, x_44); +lean_ctor_set(x_47, 5, x_45); +x_48 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_48, 0, x_40); +lean_ctor_set(x_48, 1, x_47); +return x_48; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__4(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_array_get_size(x_1); +x_6 = lean_nat_dec_lt(x_2, x_5); +lean_dec(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_dec(x_3); +lean_dec(x_2); +x_7 = lean_box(0); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_4); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_9 = lean_array_fget(x_1, x_2); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_2, x_10); +lean_dec(x_2); +lean_inc(x_3); +x_12 = l_Lean_Meta_getFVarLocalDecl(x_9, x_3, x_4); +lean_dec(x_9); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 1); +lean_inc(x_14); +lean_dec(x_12); +x_15 = l_Lean_LocalDecl_type(x_13); +lean_dec(x_13); +lean_inc(x_3); +lean_inc(x_15); +x_16 = l___private_Init_Lean_Meta_Check_1__ensureType(x_15, x_3, x_14); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_ctor_get(x_16, 1); +lean_inc(x_17); +lean_dec(x_16); +lean_inc(x_3); +x_18 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_15, x_3, x_17); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_18, 1); +lean_inc(x_19); +lean_dec(x_18); +x_2 = x_11; +x_4 = x_19; +goto _start; +} +else +{ +uint8_t x_21; +lean_dec(x_11); +lean_dec(x_3); +x_21 = !lean_is_exclusive(x_18); +if (x_21 == 0) +{ +return x_18; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_18, 0); +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_18); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +else +{ +uint8_t x_25; +lean_dec(x_15); +lean_dec(x_11); +lean_dec(x_3); +x_25 = !lean_is_exclusive(x_16); +if (x_25 == 0) +{ +return x_16; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_16, 0); +x_27 = lean_ctor_get(x_16, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_16); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_dec(x_11); +lean_dec(x_3); +x_29 = !lean_is_exclusive(x_12); +if (x_29 == 0) +{ +return x_12; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_12, 0); +x_31 = lean_ctor_get(x_12, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_12); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__10(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_lt(x_4, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_4); +x_9 = lean_unsigned_to_nat(0u); +lean_inc(x_5); +x_10 = l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8(x_1, x_9, x_5, x_6); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_10, 1); +lean_inc(x_11); +lean_dec(x_10); +lean_inc(x_5); +lean_inc(x_2); +x_12 = l___private_Init_Lean_Meta_Check_1__ensureType(x_2, x_5, x_11); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_12, 1); +lean_inc(x_13); +lean_dec(x_12); +x_14 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_2, x_5, x_13); +return x_14; +} else { uint8_t x_15; -x_15 = !lean_is_exclusive(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_15 = !lean_is_exclusive(x_12); if (x_15 == 0) { -lean_object* x_16; uint8_t x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_6, 0); -lean_dec(x_16); -x_17 = 0; -x_18 = lean_box(x_17); -lean_ctor_set_tag(x_6, 0); -lean_ctor_set(x_6, 0, x_18); -return x_6; +return x_12; } else { -lean_object* x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; -x_19 = lean_ctor_get(x_6, 1); -lean_inc(x_19); -lean_dec(x_6); -x_20 = 0; -x_21 = lean_box(x_20); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_21); -lean_ctor_set(x_22, 1, x_19); +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_12, 0); +x_17 = lean_ctor_get(x_12, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_12); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +} +else +{ +uint8_t x_19; +lean_dec(x_5); +lean_dec(x_2); +x_19 = !lean_is_exclusive(x_10); +if (x_19 == 0) +{ +return x_10; +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_10, 0); +x_21 = lean_ctor_get(x_10, 1); +lean_inc(x_21); +lean_inc(x_20); +lean_dec(x_10); +x_22 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_22, 0, x_20); +lean_ctor_set(x_22, 1, x_21); return x_22; } } } +else +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_array_fget(x_3, x_4); +lean_inc(x_5); +x_24 = l_Lean_Meta_getFVarLocalDecl(x_23, x_5, x_6); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = l_Lean_LocalDecl_type(x_25); +lean_dec(x_25); +lean_inc(x_5); +lean_inc(x_27); +x_28 = l_Lean_Meta_isClassQuick___main(x_27, x_5, x_26); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +switch (lean_obj_tag(x_29)) { +case 0: +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +lean_dec(x_27); +lean_dec(x_23); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = lean_unsigned_to_nat(1u); +x_32 = lean_nat_add(x_4, x_31); +lean_dec(x_4); +x_4 = x_32; +x_6 = x_30; +goto _start; +} +case 1: +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; +lean_dec(x_27); +x_34 = lean_ctor_get(x_28, 1); +lean_inc(x_34); +lean_dec(x_28); +x_35 = lean_ctor_get(x_29, 0); +lean_inc(x_35); +lean_dec(x_29); +x_36 = lean_unsigned_to_nat(1u); +x_37 = lean_nat_add(x_4, x_36); +lean_dec(x_4); +x_38 = !lean_is_exclusive(x_5); +if (x_38 == 0) +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_5, 2); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_35); +lean_ctor_set(x_40, 1, x_23); +x_41 = lean_array_push(x_39, x_40); +lean_ctor_set(x_5, 2, x_41); +x_4 = x_37; +x_6 = x_34; +goto _start; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_5, 0); +x_44 = lean_ctor_get(x_5, 1); +x_45 = lean_ctor_get(x_5, 2); +lean_inc(x_45); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_5); +x_46 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_46, 0, x_35); +lean_ctor_set(x_46, 1, x_23); +x_47 = lean_array_push(x_45, x_46); +x_48 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_44); +lean_ctor_set(x_48, 2, x_47); +x_4 = x_37; +x_5 = x_48; +x_6 = x_34; +goto _start; +} +} +default: +{ +lean_object* x_50; lean_object* x_51; +x_50 = lean_ctor_get(x_28, 1); +lean_inc(x_50); +lean_dec(x_28); +lean_inc(x_5); +x_51 = l_Lean_Meta_isClassExpensive___main(x_27, x_5, x_50); +if (lean_obj_tag(x_51) == 0) +{ +lean_object* x_52; +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +if (lean_obj_tag(x_52) == 0) +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +lean_dec(x_23); +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +lean_dec(x_51); +x_54 = lean_unsigned_to_nat(1u); +x_55 = lean_nat_add(x_4, x_54); +lean_dec(x_4); +x_4 = x_55; +x_6 = x_53; +goto _start; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; +x_57 = lean_ctor_get(x_51, 1); +lean_inc(x_57); +lean_dec(x_51); +x_58 = lean_ctor_get(x_52, 0); +lean_inc(x_58); +lean_dec(x_52); +x_59 = lean_unsigned_to_nat(1u); +x_60 = lean_nat_add(x_4, x_59); +lean_dec(x_4); +x_61 = !lean_is_exclusive(x_5); +if (x_61 == 0) +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_5, 2); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_58); +lean_ctor_set(x_63, 1, x_23); +x_64 = lean_array_push(x_62, x_63); +lean_ctor_set(x_5, 2, x_64); +x_4 = x_60; +x_6 = x_57; +goto _start; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_66 = lean_ctor_get(x_5, 0); +x_67 = lean_ctor_get(x_5, 1); +x_68 = lean_ctor_get(x_5, 2); +lean_inc(x_68); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_5); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_58); +lean_ctor_set(x_69, 1, x_23); +x_70 = lean_array_push(x_68, x_69); +x_71 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_71, 0, x_66); +lean_ctor_set(x_71, 1, x_67); +lean_ctor_set(x_71, 2, x_70); +x_4 = x_60; +x_5 = x_71; +x_6 = x_57; +goto _start; +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_23); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_73 = !lean_is_exclusive(x_51); +if (x_73 == 0) +{ +return x_51; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_51, 0); +x_75 = lean_ctor_get(x_51, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_51); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_27); +lean_dec(x_23); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_28); +if (x_77 == 0) +{ +return x_28; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_28, 0); +x_79 = lean_ctor_get(x_28, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_28); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_23); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_81 = !lean_is_exclusive(x_24); +if (x_81 == 0) +{ +return x_24; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_24, 0); +x_83 = lean_ctor_get(x_24, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_24); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___lambda__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; +x_10 = l_Lean_Expr_isForall(x_7); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_11 = lean_unsigned_to_nat(0u); +lean_inc(x_8); +x_12 = l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8(x_1, x_11, x_8, x_9); +lean_dec(x_1); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_12, 1); +lean_inc(x_13); +lean_dec(x_12); +lean_inc(x_8); +lean_inc(x_2); +x_14 = l___private_Init_Lean_Meta_Check_1__ensureType(x_2, x_8, x_13); +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_ctor_get(x_14, 1); +lean_inc(x_15); +lean_dec(x_14); +x_16 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_2, x_8, x_15); +return x_16; +} +else +{ +uint8_t x_17; +lean_dec(x_8); +lean_dec(x_2); +x_17 = !lean_is_exclusive(x_14); +if (x_17 == 0) +{ +return x_14; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_14, 0); +x_19 = lean_ctor_get(x_14, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_14); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +else +{ +uint8_t x_21; +lean_dec(x_8); +lean_dec(x_2); +x_21 = !lean_is_exclusive(x_12); +if (x_21 == 0) +{ +return x_12; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_12, 0); +x_23 = lean_ctor_get(x_12, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_12); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +else +{ +lean_object* x_25; +lean_dec(x_2); +x_25 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__9(x_3, x_4, x_5, x_1, x_6, x_7, x_8, x_9); +return x_25; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; +lean_inc(x_8); +x_13 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_13, 0, x_8); +x_14 = lean_box(x_1); +lean_inc(x_7); +lean_inc(x_3); +lean_inc(x_2); +lean_inc(x_8); +lean_inc(x_4); +x_15 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___lambda__1___boxed), 9, 6); +lean_closure_set(x_15, 0, x_4); +lean_closure_set(x_15, 1, x_8); +lean_closure_set(x_15, 2, x_14); +lean_closure_set(x_15, 3, x_2); +lean_closure_set(x_15, 4, x_3); +lean_closure_set(x_15, 5, x_7); +x_16 = lean_array_get_size(x_9); +x_17 = lean_nat_dec_lt(x_10, x_16); +lean_dec(x_16); +if (x_17 == 0) +{ +lean_object* x_18; +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_18 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_13, x_15, x_11, x_12); +return x_18; +} +else +{ +lean_object* x_19; lean_object* x_20; +lean_dec(x_15); +lean_dec(x_13); +x_19 = lean_array_fget(x_9, x_10); +lean_inc(x_11); +x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_11, x_12); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = l_Lean_LocalDecl_type(x_21); +lean_dec(x_21); +lean_inc(x_11); +lean_inc(x_23); +x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_11, x_22); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +switch (lean_obj_tag(x_25)) { +case 0: +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +lean_dec(x_23); +lean_dec(x_19); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_10, x_27); +lean_dec(x_10); +x_10 = x_28; +x_12 = x_26; +goto _start; +} +case 1: +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_dec(x_23); +x_30 = lean_ctor_get(x_24, 1); +lean_inc(x_30); +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 0); +lean_inc(x_31); +lean_dec(x_25); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_10, x_32); +lean_dec(x_10); +x_34 = !lean_is_exclusive(x_11); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_11, 2); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_31); +lean_ctor_set(x_36, 1, x_19); +x_37 = lean_array_push(x_35, x_36); +lean_ctor_set(x_11, 2, x_37); +x_10 = x_33; +x_12 = x_30; +goto _start; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_39 = lean_ctor_get(x_11, 0); +x_40 = lean_ctor_get(x_11, 1); +x_41 = lean_ctor_get(x_11, 2); +lean_inc(x_41); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_11); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_31); +lean_ctor_set(x_42, 1, x_19); +x_43 = lean_array_push(x_41, x_42); +x_44 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_40); +lean_ctor_set(x_44, 2, x_43); +x_10 = x_33; +x_11 = x_44; +x_12 = x_30; +goto _start; +} +} +default: +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_24, 1); +lean_inc(x_46); +lean_dec(x_24); +lean_inc(x_11); +x_47 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_46); +if (lean_obj_tag(x_47) == 0) +{ +lean_object* x_48; +x_48 = lean_ctor_get(x_47, 0); +lean_inc(x_48); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_19); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +lean_dec(x_47); +x_50 = lean_unsigned_to_nat(1u); +x_51 = lean_nat_add(x_10, x_50); +lean_dec(x_10); +x_10 = x_51; +x_12 = x_49; +goto _start; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; +x_53 = lean_ctor_get(x_47, 1); +lean_inc(x_53); +lean_dec(x_47); +x_54 = lean_ctor_get(x_48, 0); +lean_inc(x_54); +lean_dec(x_48); +x_55 = lean_unsigned_to_nat(1u); +x_56 = lean_nat_add(x_10, x_55); +lean_dec(x_10); +x_57 = !lean_is_exclusive(x_11); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_11, 2); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_19); +x_60 = lean_array_push(x_58, x_59); +lean_ctor_set(x_11, 2, x_60); +x_10 = x_56; +x_12 = x_53; +goto _start; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_62 = lean_ctor_get(x_11, 0); +x_63 = lean_ctor_get(x_11, 1); +x_64 = lean_ctor_get(x_11, 2); +lean_inc(x_64); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_11); +x_65 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_65, 0, x_54); +lean_ctor_set(x_65, 1, x_19); +x_66 = lean_array_push(x_64, x_65); +x_67 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_63); +lean_ctor_set(x_67, 2, x_66); +x_10 = x_56; +x_11 = x_67; +x_12 = x_53; +goto _start; +} +} +} +else +{ +uint8_t x_69; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_69 = !lean_is_exclusive(x_47); +if (x_69 == 0) +{ +return x_47; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_47, 0); +x_71 = lean_ctor_get(x_47, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_47); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_23); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_73 = !lean_is_exclusive(x_24); +if (x_73 == 0) +{ +return x_24; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_24, 0); +x_75 = lean_ctor_get(x_24, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_24); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_20); +if (x_77 == 0) +{ +return x_20; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_20, 0); +x_79 = lean_ctor_get(x_20, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_20); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__12(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_lt(x_4, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_4); +x_9 = lean_unsigned_to_nat(0u); +lean_inc(x_5); +x_10 = l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8(x_1, x_9, x_5, x_6); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_10, 1); +lean_inc(x_11); +lean_dec(x_10); +lean_inc(x_5); +lean_inc(x_2); +x_12 = l___private_Init_Lean_Meta_Check_1__ensureType(x_2, x_5, x_11); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_12, 1); +lean_inc(x_13); +lean_dec(x_12); +x_14 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_2, x_5, x_13); +return x_14; +} +else +{ +uint8_t x_15; +lean_dec(x_5); +lean_dec(x_2); +x_15 = !lean_is_exclusive(x_12); +if (x_15 == 0) +{ +return x_12; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_12, 0); +x_17 = lean_ctor_get(x_12, 1); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_12); +x_18 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +return x_18; +} +} +} +else +{ +uint8_t x_19; +lean_dec(x_5); +lean_dec(x_2); +x_19 = !lean_is_exclusive(x_10); +if (x_19 == 0) +{ +return x_10; +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_10, 0); +x_21 = lean_ctor_get(x_10, 1); +lean_inc(x_21); +lean_inc(x_20); +lean_dec(x_10); +x_22 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_22, 0, x_20); +lean_ctor_set(x_22, 1, x_21); +return x_22; +} +} +} +else +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_array_fget(x_3, x_4); +lean_inc(x_5); +x_24 = l_Lean_Meta_getFVarLocalDecl(x_23, x_5, x_6); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = l_Lean_LocalDecl_type(x_25); +lean_dec(x_25); +lean_inc(x_5); +lean_inc(x_27); +x_28 = l_Lean_Meta_isClassQuick___main(x_27, x_5, x_26); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +switch (lean_obj_tag(x_29)) { +case 0: +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +lean_dec(x_27); +lean_dec(x_23); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = lean_unsigned_to_nat(1u); +x_32 = lean_nat_add(x_4, x_31); +lean_dec(x_4); +x_4 = x_32; +x_6 = x_30; +goto _start; +} +case 1: +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; +lean_dec(x_27); +x_34 = lean_ctor_get(x_28, 1); +lean_inc(x_34); +lean_dec(x_28); +x_35 = lean_ctor_get(x_29, 0); +lean_inc(x_35); +lean_dec(x_29); +x_36 = lean_unsigned_to_nat(1u); +x_37 = lean_nat_add(x_4, x_36); +lean_dec(x_4); +x_38 = !lean_is_exclusive(x_5); +if (x_38 == 0) +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_5, 2); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_35); +lean_ctor_set(x_40, 1, x_23); +x_41 = lean_array_push(x_39, x_40); +lean_ctor_set(x_5, 2, x_41); +x_4 = x_37; +x_6 = x_34; +goto _start; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_5, 0); +x_44 = lean_ctor_get(x_5, 1); +x_45 = lean_ctor_get(x_5, 2); +lean_inc(x_45); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_5); +x_46 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_46, 0, x_35); +lean_ctor_set(x_46, 1, x_23); +x_47 = lean_array_push(x_45, x_46); +x_48 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_44); +lean_ctor_set(x_48, 2, x_47); +x_4 = x_37; +x_5 = x_48; +x_6 = x_34; +goto _start; +} +} +default: +{ +lean_object* x_50; lean_object* x_51; +x_50 = lean_ctor_get(x_28, 1); +lean_inc(x_50); +lean_dec(x_28); +lean_inc(x_5); +x_51 = l_Lean_Meta_isClassExpensive___main(x_27, x_5, x_50); +if (lean_obj_tag(x_51) == 0) +{ +lean_object* x_52; +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +if (lean_obj_tag(x_52) == 0) +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +lean_dec(x_23); +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +lean_dec(x_51); +x_54 = lean_unsigned_to_nat(1u); +x_55 = lean_nat_add(x_4, x_54); +lean_dec(x_4); +x_4 = x_55; +x_6 = x_53; +goto _start; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; +x_57 = lean_ctor_get(x_51, 1); +lean_inc(x_57); +lean_dec(x_51); +x_58 = lean_ctor_get(x_52, 0); +lean_inc(x_58); +lean_dec(x_52); +x_59 = lean_unsigned_to_nat(1u); +x_60 = lean_nat_add(x_4, x_59); +lean_dec(x_4); +x_61 = !lean_is_exclusive(x_5); +if (x_61 == 0) +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_5, 2); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_58); +lean_ctor_set(x_63, 1, x_23); +x_64 = lean_array_push(x_62, x_63); +lean_ctor_set(x_5, 2, x_64); +x_4 = x_60; +x_6 = x_57; +goto _start; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_66 = lean_ctor_get(x_5, 0); +x_67 = lean_ctor_get(x_5, 1); +x_68 = lean_ctor_get(x_5, 2); +lean_inc(x_68); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_5); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_58); +lean_ctor_set(x_69, 1, x_23); +x_70 = lean_array_push(x_68, x_69); +x_71 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_71, 0, x_66); +lean_ctor_set(x_71, 1, x_67); +lean_ctor_set(x_71, 2, x_70); +x_4 = x_60; +x_5 = x_71; +x_6 = x_57; +goto _start; +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_23); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_73 = !lean_is_exclusive(x_51); +if (x_73 == 0) +{ +return x_51; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_51, 0); +x_75 = lean_ctor_get(x_51, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_51); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_27); +lean_dec(x_23); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_28); +if (x_77 == 0) +{ +return x_28; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_28, 0); +x_79 = lean_ctor_get(x_28, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_28); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_23); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_81 = !lean_is_exclusive(x_24); +if (x_81 == 0) +{ +return x_24; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_24, 0); +x_83 = lean_ctor_get(x_24, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_24); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__9(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +if (lean_obj_tag(x_6) == 7) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_22 = lean_ctor_get(x_6, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_6, 1); +lean_inc(x_23); +x_24 = lean_ctor_get(x_6, 2); +lean_inc(x_24); +x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); +lean_dec(x_6); +x_26 = lean_array_get_size(x_4); +lean_inc(x_4); +x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); +lean_dec(x_26); +lean_dec(x_23); +x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = (uint8_t)((x_25 << 24) >> 61); +lean_inc(x_29); +x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); +x_33 = l_Lean_mkFVar(x_29); +x_34 = lean_array_push(x_4, x_33); +if (lean_obj_tag(x_2) == 0) +{ +x_3 = x_32; +x_4 = x_34; +x_6 = x_24; +x_8 = x_30; +goto _start; +} +else +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_2, 0); +lean_inc(x_36); +x_37 = lean_array_get_size(x_34); +x_38 = lean_nat_dec_lt(x_37, x_36); +lean_dec(x_36); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +lean_dec(x_2); +lean_inc(x_34); +x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); +lean_dec(x_37); +lean_dec(x_24); +x_40 = !lean_is_exclusive(x_7); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_7, 1); +lean_dec(x_41); +lean_ctor_set(x_7, 1, x_32); +x_42 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__12(x_34, x_39, x_34, x_5, x_7, x_30); +lean_dec(x_34); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_7, 0); +x_44 = lean_ctor_get(x_7, 2); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_7); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_32); +lean_ctor_set(x_45, 2, x_44); +x_46 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__12(x_34, x_39, x_34, x_5, x_45, x_30); +lean_dec(x_34); +return x_46; +} +} +else +{ +lean_dec(x_37); +x_3 = x_32; +x_4 = x_34; +x_6 = x_24; +x_8 = x_30; +goto _start; +} +} +} +else +{ +lean_object* x_48; +x_48 = lean_box(0); +x_9 = x_48; +goto block_21; +} +block_21: +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +lean_dec(x_9); +x_10 = lean_array_get_size(x_4); +lean_inc(x_4); +x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); +x_12 = !lean_is_exclusive(x_7); +if (x_12 == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_7, 1); +lean_dec(x_13); +lean_inc(x_3); +lean_ctor_set(x_7, 1, x_3); +if (x_1 == 0) +{ +lean_object* x_14; +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__10(x_4, x_11, x_4, x_5, x_7, x_8); +lean_dec(x_4); +return x_14; +} +else +{ +lean_object* x_15; +lean_inc(x_5); +lean_inc(x_4); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_7, 0); +x_17 = lean_ctor_get(x_7, 2); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_7); +lean_inc(x_3); +x_18 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_3); +lean_ctor_set(x_18, 2, x_17); +if (x_1 == 0) +{ +lean_object* x_19; +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_19 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__10(x_4, x_11, x_4, x_5, x_18, x_8); +lean_dec(x_4); +return x_19; +} +else +{ +lean_object* x_20; +lean_inc(x_5); +lean_inc(x_4); +x_20 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_20; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Check_3__checkForall___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_4 = lean_ctor_get(x_3, 2); +lean_inc(x_4); +x_5 = lean_ctor_get(x_2, 1); +lean_inc(x_5); +x_6 = lean_box(0); +x_7 = 0; +x_8 = l_Array_empty___closed__1; +x_9 = lean_unsigned_to_nat(0u); +x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__9(x_7, x_6, x_5, x_8, x_9, x_1, x_2, x_3); +if (lean_obj_tag(x_10) == 0) +{ +uint8_t x_11; +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; uint8_t x_13; +x_12 = lean_ctor_get(x_10, 1); +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_12, 2); +lean_dec(x_14); +lean_ctor_set(x_12, 2, x_4); +return x_10; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_15 = lean_ctor_get(x_12, 0); +x_16 = lean_ctor_get(x_12, 1); +x_17 = lean_ctor_get(x_12, 3); +x_18 = lean_ctor_get(x_12, 4); +x_19 = lean_ctor_get(x_12, 5); +lean_inc(x_19); +lean_inc(x_18); +lean_inc(x_17); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_12); +x_20 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_20, 0, x_15); +lean_ctor_set(x_20, 1, x_16); +lean_ctor_set(x_20, 2, x_4); +lean_ctor_set(x_20, 3, x_17); +lean_ctor_set(x_20, 4, x_18); +lean_ctor_set(x_20, 5, x_19); +lean_ctor_set(x_10, 1, x_20); +return x_10; +} +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_21 = lean_ctor_get(x_10, 1); +x_22 = lean_ctor_get(x_10, 0); +lean_inc(x_21); +lean_inc(x_22); +lean_dec(x_10); +x_23 = lean_ctor_get(x_21, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_21, 1); +lean_inc(x_24); +x_25 = lean_ctor_get(x_21, 3); +lean_inc(x_25); +x_26 = lean_ctor_get(x_21, 4); +lean_inc(x_26); +x_27 = lean_ctor_get(x_21, 5); +lean_inc(x_27); +if (lean_is_exclusive(x_21)) { + lean_ctor_release(x_21, 0); + lean_ctor_release(x_21, 1); + lean_ctor_release(x_21, 2); + lean_ctor_release(x_21, 3); + lean_ctor_release(x_21, 4); + lean_ctor_release(x_21, 5); + x_28 = x_21; +} else { + lean_dec_ref(x_21); + x_28 = lean_box(0); +} +if (lean_is_scalar(x_28)) { + x_29 = lean_alloc_ctor(0, 6, 0); +} else { + x_29 = x_28; +} +lean_ctor_set(x_29, 0, x_23); +lean_ctor_set(x_29, 1, x_24); +lean_ctor_set(x_29, 2, x_4); +lean_ctor_set(x_29, 3, x_25); +lean_ctor_set(x_29, 4, x_26); +lean_ctor_set(x_29, 5, x_27); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_22); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +else +{ +uint8_t x_31; +x_31 = !lean_is_exclusive(x_10); +if (x_31 == 0) +{ +lean_object* x_32; uint8_t x_33; +x_32 = lean_ctor_get(x_10, 1); +x_33 = !lean_is_exclusive(x_32); +if (x_33 == 0) +{ +lean_object* x_34; +x_34 = lean_ctor_get(x_32, 2); +lean_dec(x_34); +lean_ctor_set(x_32, 2, x_4); +return x_10; +} +else +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_35 = lean_ctor_get(x_32, 0); +x_36 = lean_ctor_get(x_32, 1); +x_37 = lean_ctor_get(x_32, 3); +x_38 = lean_ctor_get(x_32, 4); +x_39 = lean_ctor_get(x_32, 5); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_inc(x_36); +lean_inc(x_35); +lean_dec(x_32); +x_40 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_40, 0, x_35); +lean_ctor_set(x_40, 1, x_36); +lean_ctor_set(x_40, 2, x_4); +lean_ctor_set(x_40, 3, x_37); +lean_ctor_set(x_40, 4, x_38); +lean_ctor_set(x_40, 5, x_39); +lean_ctor_set(x_10, 1, x_40); +return x_10; +} +} +else +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_41 = lean_ctor_get(x_10, 1); +x_42 = lean_ctor_get(x_10, 0); +lean_inc(x_41); +lean_inc(x_42); +lean_dec(x_10); +x_43 = lean_ctor_get(x_41, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_41, 1); +lean_inc(x_44); +x_45 = lean_ctor_get(x_41, 3); +lean_inc(x_45); +x_46 = lean_ctor_get(x_41, 4); +lean_inc(x_46); +x_47 = lean_ctor_get(x_41, 5); +lean_inc(x_47); +if (lean_is_exclusive(x_41)) { + lean_ctor_release(x_41, 0); + lean_ctor_release(x_41, 1); + lean_ctor_release(x_41, 2); + lean_ctor_release(x_41, 3); + lean_ctor_release(x_41, 4); + lean_ctor_release(x_41, 5); + x_48 = x_41; +} else { + lean_dec_ref(x_41); + x_48 = lean_box(0); +} +if (lean_is_scalar(x_48)) { + x_49 = lean_alloc_ctor(0, 6, 0); +} else { + x_49 = x_48; +} +lean_ctor_set(x_49, 0, x_43); +lean_ctor_set(x_49, 1, x_44); +lean_ctor_set(x_49, 2, x_4); +lean_ctor_set(x_49, 3, x_45); +lean_ctor_set(x_49, 4, x_46); +lean_ctor_set(x_49, 5, x_47); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_42); +lean_ctor_set(x_50, 1, x_49); +return x_50; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Check_6__checkAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +switch (lean_obj_tag(x_1)) { +case 4: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +x_5 = lean_ctor_get(x_1, 1); +lean_inc(x_5); +lean_dec(x_1); +x_6 = l___private_Init_Lean_Meta_Check_4__checkConstant(x_4, x_5, x_2, x_3); +lean_dec(x_2); +return x_6; +} +case 5: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_1, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_1, 1); +lean_inc(x_8); +lean_dec(x_1); +x_9 = l___private_Init_Lean_Meta_Check_5__checkApp___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__1(x_7, x_8, x_2, x_3); +return x_9; +} +case 6: +{ +lean_object* x_10; +x_10 = l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__4(x_1, x_2, x_3); +return x_10; +} +case 7: +{ +lean_object* x_11; +x_11 = l___private_Init_Lean_Meta_Check_3__checkForall___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__7(x_1, x_2, x_3); +return x_11; +} +case 8: +{ +lean_object* x_12; +x_12 = l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__4(x_1, x_2, x_3); +return x_12; +} +case 10: +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_1, 1); +lean_inc(x_13); +lean_dec(x_1); +x_1 = x_13; +goto _start; +} +case 11: +{ +lean_object* x_15; +x_15 = lean_ctor_get(x_1, 2); +lean_inc(x_15); +lean_dec(x_1); +x_1 = x_15; +goto _start; +} +default: +{ +lean_object* x_17; lean_object* x_18; +lean_dec(x_2); +lean_dec(x_1); +x_17 = lean_box(0); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_17); +lean_ctor_set(x_18, 1, x_3); +return x_18; +} +} +} +} +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__3(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__6(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_3); +lean_dec(x_1); +return x_7; +} +} +lean_object* l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Array_forMAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__8(x_1, x_2, x_3, x_4); +lean_dec(x_1); +return x_5; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__10___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__10(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_3); +lean_dec(x_1); +return x_7; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_3); +lean_dec(x_3); +x_11 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___lambda__1(x_1, x_2, x_10, x_4, x_5, x_6, x_7, x_8, x_9); +return x_11; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +uint8_t x_13; lean_object* x_14; +x_13 = lean_unbox(x_1); +lean_dec(x_1); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__11(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +return x_14; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__12___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__12(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_3); +lean_dec(x_1); +return x_7; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__9___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_1); +lean_dec(x_1); +x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_Check_6__checkAux___main___spec__9(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_10; +} +} +lean_object* l___private_Init_Lean_Meta_Check_6__checkAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_Lean_Meta_check(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +if (x_4 == 0) +{ +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_2, 0); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +uint8_t x_7; lean_object* x_8; +x_7 = 0; +lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 5, x_7); +x_8 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_1, x_2, x_3); +return x_8; +} +else +{ +lean_object* x_9; uint8_t x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; +x_9 = lean_ctor_get(x_5, 0); +x_10 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); +x_11 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); +x_12 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); +x_13 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); +x_14 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); +lean_inc(x_9); +lean_dec(x_5); +x_15 = 0; +x_16 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_16, 0, x_9); +lean_ctor_set_uint8(x_16, sizeof(void*)*1, x_10); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 1, x_11); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 2, x_12); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 3, x_13); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_14); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 5, x_15); +lean_ctor_set(x_2, 0, x_16); +x_17 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_1, x_2, x_3); +return x_17; +} +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_18 = lean_ctor_get(x_2, 0); +x_19 = lean_ctor_get(x_2, 1); +x_20 = lean_ctor_get(x_2, 2); +lean_inc(x_20); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_2); +x_21 = lean_ctor_get(x_18, 0); +lean_inc(x_21); +x_22 = lean_ctor_get_uint8(x_18, sizeof(void*)*1); +x_23 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 1); +x_24 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 2); +x_25 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 3); +x_26 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 4); +if (lean_is_exclusive(x_18)) { + lean_ctor_release(x_18, 0); + x_27 = x_18; +} else { + lean_dec_ref(x_18); + x_27 = lean_box(0); +} +x_28 = 0; +if (lean_is_scalar(x_27)) { + x_29 = lean_alloc_ctor(0, 1, 6); +} else { + x_29 = x_27; +} +lean_ctor_set(x_29, 0, x_21); +lean_ctor_set_uint8(x_29, sizeof(void*)*1, x_22); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 1, x_23); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 2, x_24); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 3, x_25); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_26); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 5, x_28); +x_30 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_19); +lean_ctor_set(x_30, 2, x_20); +x_31 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_1, x_30, x_3); +return x_31; +} +} +} +lean_object* l_Lean_Meta_isTypeCorrect(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Init_Lean_Meta_Check_6__checkAux___main(x_1, x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +uint8_t x_5; +x_5 = !lean_is_exclusive(x_4); +if (x_5 == 0) +{ +lean_object* x_6; uint8_t x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_4, 0); +lean_dec(x_6); +x_7 = 1; +x_8 = lean_box(x_7); +lean_ctor_set(x_4, 0, x_8); +return x_4; +} +else +{ +lean_object* x_9; uint8_t x_10; lean_object* x_11; lean_object* x_12; +x_9 = lean_ctor_get(x_4, 1); +lean_inc(x_9); +lean_dec(x_4); +x_10 = 1; +x_11 = lean_box(x_10); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_11); +lean_ctor_set(x_12, 1, x_9); +return x_12; +} +} +else +{ +uint8_t x_13; +x_13 = !lean_is_exclusive(x_4); +if (x_13 == 0) +{ +lean_object* x_14; uint8_t x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_4, 0); +lean_dec(x_14); +x_15 = 0; +x_16 = lean_box(x_15); +lean_ctor_set_tag(x_4, 0); +lean_ctor_set(x_4, 0, x_16); +return x_4; +} +else +{ +lean_object* x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; +x_17 = lean_ctor_get(x_4, 1); +lean_inc(x_17); +lean_dec(x_4); +x_18 = 0; +x_19 = lean_box(x_18); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_17); +return x_20; +} +} +} } lean_object* initialize_Init_Lean_Meta_InferType(lean_object*); static bool _G_initialized = false; @@ -1645,6 +4700,8 @@ _G_initialized = true; res = initialize_Init_Lean_Meta_InferType(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1 = _init_l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/library/Init/Lean/Meta/Exception.c b/stage0/library/Init/Lean/Meta/Exception.c index 4dfa5e2ee9..3d49e1c341 100644 --- a/stage0/library/Init/Lean/Meta/Exception.c +++ b/stage0/library/Init/Lean/Meta/Exception.c @@ -35,6 +35,7 @@ extern lean_object* l_List_repr___rarg___closed__2; extern lean_object* l_List_reprAux___main___rarg___closed__1; lean_object* l_Lean_Meta_Exception_toStr___closed__11; extern lean_object* l_Lean_Options_empty; +lean_object* l_Lean_Meta_Exception_toStr___closed__16; lean_object* l_Lean_Meta_Exception_toStr___closed__7; lean_object* l_List_toStringAux___main___at_Lean_Meta_Exception_toStr___spec__2___boxed(lean_object*, lean_object*); lean_object* l_Lean_Meta_Exception_toStr___closed__10; @@ -54,7 +55,7 @@ _start: { lean_object* x_1; lean_object* x_2; x_1 = l_String_splitAux___main___closed__1; -x_2 = lean_alloc_ctor(14, 1, 0); +x_2 = lean_alloc_ctor(15, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } @@ -249,7 +250,7 @@ lean_object* _init_l_Lean_Meta_Exception_toStr___closed__13() { _start: { lean_object* x_1; -x_1 = lean_mk_string("type mismatch at let-expression"); +x_1 = lean_mk_string("isDefEq is stuck"); return x_1; } } @@ -257,7 +258,7 @@ lean_object* _init_l_Lean_Meta_Exception_toStr___closed__14() { _start: { lean_object* x_1; -x_1 = lean_mk_string("application type mismatch"); +x_1 = lean_mk_string("type mismatch at let-expression"); return x_1; } } @@ -265,6 +266,14 @@ lean_object* _init_l_Lean_Meta_Exception_toStr___closed__15() { _start: { lean_object* x_1; +x_1 = lean_mk_string("application type mismatch"); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_Exception_toStr___closed__16() { +_start: +{ +lean_object* x_1; x_1 = lean_mk_string("bug"); return x_1; } @@ -421,14 +430,21 @@ lean_dec(x_1); x_51 = l_Lean_Meta_Exception_toStr___closed__15; return x_51; } -default: +case 14: { lean_object* x_52; -x_52 = lean_ctor_get(x_1, 0); -lean_inc(x_52); lean_dec(x_1); +x_52 = l_Lean_Meta_Exception_toStr___closed__16; return x_52; } +default: +{ +lean_object* x_53; +x_53 = lean_ctor_get(x_1, 0); +lean_inc(x_53); +lean_dec(x_1); +return x_53; +} } } } @@ -505,6 +521,8 @@ l_Lean_Meta_Exception_toStr___closed__14 = _init_l_Lean_Meta_Exception_toStr___c lean_mark_persistent(l_Lean_Meta_Exception_toStr___closed__14); l_Lean_Meta_Exception_toStr___closed__15 = _init_l_Lean_Meta_Exception_toStr___closed__15(); lean_mark_persistent(l_Lean_Meta_Exception_toStr___closed__15); +l_Lean_Meta_Exception_toStr___closed__16 = _init_l_Lean_Meta_Exception_toStr___closed__16(); +lean_mark_persistent(l_Lean_Meta_Exception_toStr___closed__16); l_Lean_Meta_Exception_HasToString___closed__1 = _init_l_Lean_Meta_Exception_HasToString___closed__1(); lean_mark_persistent(l_Lean_Meta_Exception_HasToString___closed__1); l_Lean_Meta_Exception_HasToString = _init_l_Lean_Meta_Exception_HasToString(); diff --git a/stage0/library/Init/Lean/Meta/ExprDefEq.c b/stage0/library/Init/Lean/Meta/ExprDefEq.c index 6928abe3fd..dfb9ef683e 100644 --- a/stage0/library/Init/Lean/Meta/ExprDefEq.c +++ b/stage0/library/Init/Lean/Meta/ExprDefEq.c @@ -13,272 +13,415 @@ #ifdef __cplusplus extern "C" { #endif -uint8_t l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__1(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__9; +lean_object* l_Lean_Meta_CheckAssignmentQuick_check___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_update_forall(lean_object*, uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__4; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_mvarId_x21(lean_object*); +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___closed__1; +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l___private_Init_Lean_Meta_ExprDefEq_25__etaEq(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_11__visit(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__9; +lean_object* lean_mk_empty_array_with_capacity(lean_object*); +lean_object* l_HashMapImp_find___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__1___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__2; lean_object* l_unreachable_x21___rarg(lean_object*); -lean_object* l_HashMapImp_find___at_Lean_Meta_CheckAssignment_findCached___spec__1___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_15__simpAssignmentArgAux(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_uget(lean_object*, size_t); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__6; +lean_object* l_Lean_Meta_setIsExprDefEqAuxRef(lean_object*); lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_checkAssignment___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_update_mdata(lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6; extern lean_object* l_EIO_Monad___closed__1; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4; +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__6(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__5(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_ReaderT_bind___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_updateMData_x21___closed__2; +lean_object* l___private_Init_Lean_WHNF_4__getRecRuleFor(lean_object*, lean_object*); lean_object* lean_array_uset(lean_object*, size_t, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_checkFVar(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__8(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__cache___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__17; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_23__isSynthetic___boxed(lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_check___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_getExprMVarAssignment___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkMVar(lean_object*); extern lean_object* l_Array_empty___closed__1; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isDefEqBindingDomain___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_18__sameHeadSymbol___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_7__visit(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__21; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__processAssignmentFOApproxAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isDefEqBindingDomain___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__2; +uint8_t l___private_Init_Lean_WHNF_6__isIdRhsApp(lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_20__sameHeadSymbol___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__visit(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_name_eq(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__1; +uint8_t l_Lean_Expr_isApp(lean_object*); +lean_object* l_Lean_Meta_CheckAssignment_checkFVar___at_Lean_Meta_CheckAssignment_check___main___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_Lean_MonadCache; uint8_t l_Lean_LocalContext_containsFVar(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__19; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_22__isAssigned(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_LocalContext_findFVar(lean_object*, lean_object*); -lean_object* l_HashMapImp_insert___at_Lean_Meta_CheckAssignment_cache___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__5; +lean_object* lean_expr_instantiate1(lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isTypeCorrect(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; extern lean_object* l_Lean_Expr_getAppArgs___closed__1; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__8; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_25__etaEq___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_HashMapImp_moveEntries___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__4(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__21; lean_object* l_Array_umapMAux___main___at_Lean_MessageData_coeOfArrayExpr___spec__1(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__2; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__simpAssignmentArgAux(lean_object*, lean_object*, lean_object*); +uint8_t l_Array_contains___at_Lean_Meta_CheckAssignment_check___main___spec__2(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4; uint8_t l_Lean_isReducible(lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__1; uint8_t l_Lean_LocalContext_contains(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__simpAssignmentArgAux___main(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__1; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_7__findCached___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__4; +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isExprDefEqAuxImpl(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_getConst___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__12; -lean_object* l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__1; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_13__processAssignmentFOApproxAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__8; +lean_object* l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__2(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_updateLambdaE_x21___closed__1; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_26__isLetFVar(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_metavar_ctx_find_decl(lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); uint8_t lean_metavar_ctx_is_expr_assigned(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClass(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClass(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_check(lean_object*, lean_object*, lean_object*); uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_checkAssignment___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_CheckAssignment_cache(lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_checkFVar___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__1; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l_Lean_RecursorVal_getMajorIdx(lean_object*); +uint8_t l___private_Init_Lean_Meta_ExprDefEq_20__sameHeadSymbol(lean_object*, lean_object*); lean_object* lean_array_fget(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__12; uint8_t lean_nat_dec_eq(lean_object*, lean_object*); -lean_object* l_Lean_Meta_CheckAssignment_findCached(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isDefEqBindingDomain(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isListLevelDefEq___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_HashMapImp_expand___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__3(lean_object*, lean_object*); +lean_object* l_Lean_Meta_isDefEqBindingDomain(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_3__toCtorIfLit(lean_object*); lean_object* l___private_Init_Lean_Trace_1__addNode___rarg(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; lean_object* lean_nat_sub(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1; lean_object* l_Lean_Expr_constLevels_x21(lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__2; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_7__findCached(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__5; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Name_append___main(lean_object*, lean_object*); -uint8_t l___private_Init_Lean_Meta_ExprDefEq_18__sameHeadSymbol(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Literal_beq(lean_object*, lean_object*); +lean_object* l_Lean_Meta_isExprDefEqAuxImpl___closed__1; +lean_object* l_Lean_Meta_isLevelDefEqAux___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_hasExprMVar(lean_object*); +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, uint64_t, lean_object*, lean_object*); lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_16__unfold___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___closed__1; lean_object* l___private_Init_Lean_Expr_2__mkAppRangeAux___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_fvarId_x21(lean_object*); extern lean_object* l_Lean_formatEntry___closed__2; +lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_contains___at_Lean_Meta_CheckAssignment_check___main___spec__2___boxed(lean_object*, lean_object*); +lean_object* l_List_lengthAux___main___rarg(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__11; +lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_instantiate_lparams(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_ConstantInfo_name(lean_object*); -lean_object* l_Lean_Meta_isTypeCorrectAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; +lean_object* l_Lean_Meta_isExprDefEqAuxImpl___closed__2; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7___closed__1; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isDefEqOffset(lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_tracer___closed__3; extern lean_object* l_Lean_Meta_tracer; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_30__isDefEqWHNF___at_Lean_Meta_isExprDefEqAuxImpl___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(lean_object*, lean_object*, lean_object*); size_t l_Lean_Expr_hash(lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__11; -lean_object* l_Lean_Meta_CheckAssignment_findCached___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_CheckAssignment_checkMVar___at_Lean_Meta_CheckAssignment_check___main___spec__4(lean_object*, lean_object*, lean_object*); +uint8_t l_AssocList_contains___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__2(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_23__isSynthetic(lean_object*, lean_object*, lean_object*); +extern lean_object* l_PersistentArray_empty___closed__3; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_checkMVar(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_ConstantInfo_hasValue(lean_object*); lean_object* l_Lean_Meta_CheckAssignment_mkAuxMVar___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isEtaUnassignedMVar___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_metavar_ctx_assign_expr(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_MetavarContext_isWellFormed___main(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_30__isDefEqWHNF(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__19; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__restore(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_15__simpAssignmentArgAux___main(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Meta_TransparencyMode_beq(uint8_t, uint8_t); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_22__isAssigned___boxed(lean_object*, lean_object*, lean_object*); size_t lean_usize_modn(size_t, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__16; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_try(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_updateApp_x21___closed__1; +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Array_isEmpty___rarg(lean_object*); +uint8_t l_Lean_Expr_isConstOf(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1; lean_object* l_Lean_Meta_isEtaUnassignedMVar(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkLambda(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__4(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshId___rarg(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_checkAssignment(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_mkHashMapImp___rarg(lean_object*); +lean_object* l_Lean_getStuckMVar___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Expr_3__getAppArgsAux___main(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isDefEqBindingDomain___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_AssocList_replace___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__6(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isDefEqBindingDomain___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__7; lean_object* lean_expr_update_let(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__2___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkFVar(lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_24__isAssignable(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__16; lean_object* l_Lean_ConstantInfo_hints(lean_object*); -extern lean_object* l_Id_Monad; uint8_t l_Lean_Expr_isLambda(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__5; +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_update_proj(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_AssocList_contains___main___at_Lean_Meta_CheckAssignment_cache___spec__2___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_16__unfold(lean_object*); -lean_object* l_AssocList_replace___main___at_Lean_Meta_CheckAssignment_cache___spec__6(lean_object*, lean_object*, lean_object*); +lean_object* l_AssocList_foldlM___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__5(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_AssocList_contains___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__2___boxed(lean_object*, lean_object*); +uint8_t l_Array_contains___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isAuxDef_x3f(lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_updateProj_x21___closed__2; -lean_object* l_Lean_Meta_isDefEqBindingDomain___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__7; -uint8_t l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__2(lean_object*, lean_object*); +lean_object* l_Lean_Meta_isDefEqBindingDomain___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isListLevelDefEqAux___main(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_RecursorVal_getInduct(lean_object*); lean_object* l_Lean_LocalDecl_type(lean_object*); lean_object* l_Lean_LocalDecl_value_x3f(lean_object*); +lean_object* l_Lean_ConstantInfo_lparams(lean_object*); lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isExprDefEqAuxImpl___closed__3; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Meta_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7___closed__1; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__20; lean_object* l_Lean_Meta_CheckAssignment_getMCtx(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_instantiate_value_lparams(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_7__extractIdRhs(lean_object*); lean_object* l___private_Init_Lean_Trace_2__getResetTraces___rarg(lean_object*, lean_object*); extern lean_object* l_Lean_Meta_ParamInfo_inhabited; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_HashMapImp_insert___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); uint8_t lean_expr_eqv(lean_object*, lean_object*); -lean_object* l_Lean_Meta_usingDefault(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_isMVar(lean_object*); uint8_t lean_expr_equal(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_le(lean_object*, lean_object*); lean_object* l_Lean_mkApp(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_AssocList_contains___main___at_Lean_Meta_CheckAssignment_cache___spec__2(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferTypeAuxAux___main(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_CheckAssignment_cache___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnfUsingDefault(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +lean_object* l_Lean_Expr_betaRev(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_metavar_ctx_mk_decl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); +extern uint8_t l_Bool_Inhabited; lean_object* l_Lean_Meta_getConstAux(lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_panic(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; -lean_object* l_AssocList_find___main___at_Lean_Meta_CheckAssignment_findCached___spec__2___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__20; +lean_object* l_Lean_Meta_CheckAssignmentQuick_check(uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Bool_toLBool(uint8_t); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_updateFn___main(lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__6; +lean_object* l_AssocList_find___main___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__2___boxed(lean_object*, lean_object*); +lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_synthPending(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_check___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_isExprDefEqAuxRef; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_CheckAssignmentQuick_check___main(uint8_t, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_28__isDefEqProofIrrel(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_check___main(lean_object*, lean_object*, lean_object*); lean_object* lean_nat_mul(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_AssocList_find___main___at_Lean_Meta_CheckAssignment_findCached___spec__2(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_getFunInfoNArgs(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_16__simpAssignmentArg(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__5(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_ReaderT_pure___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_updateLet_x21___closed__1; lean_object* lean_expr_update_lambda(lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_simpleMonadTracerAdapter___rarg(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__1___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); +lean_object* lean_io_ref_set(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_instantiate_rev(lean_object*, lean_object*); uint8_t l_Lean_Meta_TransparencyMode_lt(uint8_t, uint8_t); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__17; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkLambda(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_HashMapImp_expand___at_Lean_Meta_CheckAssignment_cache___spec__3(lean_object*, lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Expr_Inhabited; lean_object* l_Lean_Meta_instantiateMVars(lean_object*, lean_object*, lean_object*); lean_object* lean_mk_array(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_object* l_Lean_Meta_checkAssignment___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(lean_object*, lean_object*, lean_object*); +lean_object* l_AssocList_find___main___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__2(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__cache(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_checkAssignment___closed__1; -lean_object* l_Lean_Meta_inferTypeAux(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_mkAuxMVar(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_checkFVar___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__3(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__3; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__7(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__8(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_24__isAssignable___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_mkHashMap___at_Lean_Meta_checkAssignment___spec__2(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_15__processAssignment(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_getMCtx___boxed(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6; +lean_object* l_HashMapImp_find___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__1(lean_object*, lean_object*); +lean_object* l_Lean_Meta_setIsExprDefEqAuxRef___closed__1; lean_object* l___private_Init_Lean_Expr_9__etaExpandedAux___main(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__5(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__2; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__8; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_metavar_ctx_get_expr_assignment(lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_check___main___closed__1; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15; lean_object* l___private_Init_Lean_Trace_3__addTrace___rarg(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__18; lean_object* l_Lean_MetavarContext_getDecl(lean_object*, lean_object*); -lean_object* l_AssocList_foldlM___main___at_Lean_Meta_CheckAssignment_cache___spec__5(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__3; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__2(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_tryL(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__22; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isSyntheticExprMVar(lean_object*, lean_object*, lean_object*); lean_object* lean_expr_update_app(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__13; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__5; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__14; +lean_object* l_Lean_Meta_CheckAssignmentQuick_check___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_getRevArgD___main(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isProp(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_HasBeq; lean_object* l_Lean_mkBVar(lean_object*); -lean_object* l_HashMapImp_find___at_Lean_Meta_CheckAssignment_findCached___spec__1(lean_object*, lean_object*); uint8_t l_Lean_Expr_hasFVar(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__processAssignmentFOApproxAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfoAuxAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_local_ctx_find(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15; +extern lean_object* l_Lean_smartUnfoldingSuffix; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__3; +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__10(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__18; extern lean_object* l_Lean_Expr_updateForallE_x21___closed__1; lean_object* lean_name_mk_numeral(lean_object*, lean_object*); uint8_t l_Lean_LocalContext_isSubPrefixOf(lean_object*, lean_object*); lean_object* l_Lean_Meta_CheckAssignment_getMCtx___rarg(lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__22; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__4; -lean_object* l___private_Init_Lean_Meta_ExprDefEq_13__simpAssignmentArg(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_ReducibilityHints_lt(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__14; -lean_object* l_HashMapImp_moveEntries___main___at_Lean_Meta_CheckAssignment_cache___spec__4(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_anyRangeMAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at_Lean_Meta_whnfImpl___main___spec__15(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_13__processAssignmentFOApproxAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_LocalDecl_isLet(lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__13; lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_monadInhabited___rarg(lean_object*, lean_object*); lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__5; -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1() { +lean_object* _init_l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___closed__1() { _start: { lean_object* x_1; lean_object* x_2; @@ -287,302 +430,537 @@ x_2 = l_Lean_mkBVar(x_1); return x_2; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint64_t x_5, lean_object* x_6, lean_object* x_7) { _start: { -uint8_t x_7; -x_7 = l_Lean_Expr_isLambda(x_3); -if (x_7 == 0) +uint8_t x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_8 = (uint8_t)((x_5 << 24) >> 61); +x_9 = l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___closed__1; +x_10 = l_Lean_mkApp(x_4, x_9); +x_11 = l_Lean_mkLambda(x_2, x_8, x_3, x_10); +x_12 = !lean_is_exclusive(x_7); +if (x_12 == 0) { -uint8_t x_8; lean_object* x_9; lean_object* x_10; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_8 = 0; -x_9 = lean_box(x_8); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_6); -return x_10; +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_25; +x_13 = lean_ctor_get(x_7, 0); +x_14 = lean_ctor_get(x_7, 1); +x_15 = lean_ctor_get(x_7, 5); +x_16 = l_PersistentArray_empty___closed__3; +lean_inc(x_14); +lean_inc(x_13); +lean_ctor_set(x_7, 5, x_16); +lean_inc(x_6); +x_25 = l_Lean_Meta_isExprDefEqAux(x_1, x_11, x_6, x_7); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; uint8_t x_27; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +x_27 = lean_unbox(x_26); +if (x_27 == 0) +{ +lean_object* x_28; lean_object* x_29; uint8_t x_30; +x_28 = lean_ctor_get(x_25, 1); +lean_inc(x_28); +lean_dec(x_25); +x_29 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_13, x_14, x_15, x_6, x_28); +lean_dec(x_6); +x_30 = !lean_is_exclusive(x_29); +if (x_30 == 0) +{ +lean_object* x_31; +x_31 = lean_ctor_get(x_29, 0); +lean_dec(x_31); +lean_ctor_set(x_29, 0, x_26); +return x_29; } else { -uint8_t x_11; -x_11 = l_Lean_Expr_isLambda(x_4); -if (x_11 == 0) +lean_object* x_32; lean_object* x_33; +x_32 = lean_ctor_get(x_29, 1); +lean_inc(x_32); +lean_dec(x_29); +x_33 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_33, 0, x_26); +lean_ctor_set(x_33, 1, x_32); +return x_33; +} +} +else { -lean_object* x_12; lean_object* x_13; -lean_inc(x_1); -x_12 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 1); -lean_closure_set(x_12, 0, x_1); -lean_inc(x_5); -x_13 = l_Lean_Meta_inferTypeAuxAux___main(x_12, x_4, x_5, x_6); +lean_object* x_34; lean_object* x_35; +lean_dec(x_26); +x_34 = lean_ctor_get(x_25, 1); +lean_inc(x_34); +lean_dec(x_25); +x_35 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_6, x_34); +if (lean_obj_tag(x_35) == 0) +{ +lean_object* x_36; uint8_t x_37; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +x_37 = lean_unbox(x_36); +if (x_37 == 0) +{ +lean_object* x_38; lean_object* x_39; uint8_t x_40; +x_38 = lean_ctor_get(x_35, 1); +lean_inc(x_38); +lean_dec(x_35); +x_39 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_13, x_14, x_15, x_6, x_38); +lean_dec(x_6); +x_40 = !lean_is_exclusive(x_39); +if (x_40 == 0) +{ +lean_object* x_41; +x_41 = lean_ctor_get(x_39, 0); +lean_dec(x_41); +lean_ctor_set(x_39, 0, x_36); +return x_39; +} +else +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_39, 1); +lean_inc(x_42); +lean_dec(x_39); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_36); +lean_ctor_set(x_43, 1, x_42); +return x_43; +} +} +else +{ +uint8_t x_44; +lean_dec(x_15); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_6); +x_44 = !lean_is_exclusive(x_35); +if (x_44 == 0) +{ +lean_object* x_45; +x_45 = lean_ctor_get(x_35, 0); +lean_dec(x_45); +return x_35; +} +else +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_35, 1); +lean_inc(x_46); +lean_dec(x_35); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_36); +lean_ctor_set(x_47, 1, x_46); +return x_47; +} +} +} +else +{ +lean_object* x_48; lean_object* x_49; +x_48 = lean_ctor_get(x_35, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_35, 1); +lean_inc(x_49); +lean_dec(x_35); +x_17 = x_48; +x_18 = x_49; +goto block_24; +} +} +} +else +{ +lean_object* x_50; lean_object* x_51; +x_50 = lean_ctor_get(x_25, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_25, 1); +lean_inc(x_51); +lean_dec(x_25); +x_17 = x_50; +x_18 = x_51; +goto block_24; +} +block_24: +{ +lean_object* x_19; uint8_t x_20; +x_19 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_13, x_14, x_15, x_6, x_18); +lean_dec(x_6); +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_19, 0); +lean_dec(x_21); +lean_ctor_set_tag(x_19, 1); +lean_ctor_set(x_19, 0, x_17); +return x_19; +} +else +{ +lean_object* x_22; lean_object* x_23; +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +lean_dec(x_19); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_17); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_67; +x_52 = lean_ctor_get(x_7, 0); +x_53 = lean_ctor_get(x_7, 1); +x_54 = lean_ctor_get(x_7, 2); +x_55 = lean_ctor_get(x_7, 3); +x_56 = lean_ctor_get(x_7, 4); +x_57 = lean_ctor_get(x_7, 5); +lean_inc(x_57); +lean_inc(x_56); +lean_inc(x_55); +lean_inc(x_54); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_7); +x_58 = l_PersistentArray_empty___closed__3; +lean_inc(x_53); +lean_inc(x_52); +x_59 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_59, 0, x_52); +lean_ctor_set(x_59, 1, x_53); +lean_ctor_set(x_59, 2, x_54); +lean_ctor_set(x_59, 3, x_55); +lean_ctor_set(x_59, 4, x_56); +lean_ctor_set(x_59, 5, x_58); +lean_inc(x_6); +x_67 = l_Lean_Meta_isExprDefEqAux(x_1, x_11, x_6, x_59); +if (lean_obj_tag(x_67) == 0) +{ +lean_object* x_68; uint8_t x_69; +x_68 = lean_ctor_get(x_67, 0); +lean_inc(x_68); +x_69 = lean_unbox(x_68); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_70 = lean_ctor_get(x_67, 1); +lean_inc(x_70); +lean_dec(x_67); +x_71 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_52, x_53, x_57, x_6, x_70); +lean_dec(x_6); +x_72 = lean_ctor_get(x_71, 1); +lean_inc(x_72); +if (lean_is_exclusive(x_71)) { + lean_ctor_release(x_71, 0); + lean_ctor_release(x_71, 1); + x_73 = x_71; +} else { + lean_dec_ref(x_71); + x_73 = lean_box(0); +} +if (lean_is_scalar(x_73)) { + x_74 = lean_alloc_ctor(0, 2, 0); +} else { + x_74 = x_73; +} +lean_ctor_set(x_74, 0, x_68); +lean_ctor_set(x_74, 1, x_72); +return x_74; +} +else +{ +lean_object* x_75; lean_object* x_76; +lean_dec(x_68); +x_75 = lean_ctor_get(x_67, 1); +lean_inc(x_75); +lean_dec(x_67); +x_76 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_6, x_75); +if (lean_obj_tag(x_76) == 0) +{ +lean_object* x_77; uint8_t x_78; +x_77 = lean_ctor_get(x_76, 0); +lean_inc(x_77); +x_78 = lean_unbox(x_77); +if (x_78 == 0) +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_79 = lean_ctor_get(x_76, 1); +lean_inc(x_79); +lean_dec(x_76); +x_80 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_52, x_53, x_57, x_6, x_79); +lean_dec(x_6); +x_81 = lean_ctor_get(x_80, 1); +lean_inc(x_81); +if (lean_is_exclusive(x_80)) { + lean_ctor_release(x_80, 0); + lean_ctor_release(x_80, 1); + x_82 = x_80; +} else { + lean_dec_ref(x_80); + x_82 = lean_box(0); +} +if (lean_is_scalar(x_82)) { + x_83 = lean_alloc_ctor(0, 2, 0); +} else { + x_83 = x_82; +} +lean_ctor_set(x_83, 0, x_77); +lean_ctor_set(x_83, 1, x_81); +return x_83; +} +else +{ +lean_object* x_84; lean_object* x_85; lean_object* x_86; +lean_dec(x_57); +lean_dec(x_53); +lean_dec(x_52); +lean_dec(x_6); +x_84 = lean_ctor_get(x_76, 1); +lean_inc(x_84); +if (lean_is_exclusive(x_76)) { + lean_ctor_release(x_76, 0); + lean_ctor_release(x_76, 1); + x_85 = x_76; +} else { + lean_dec_ref(x_76); + x_85 = lean_box(0); +} +if (lean_is_scalar(x_85)) { + x_86 = lean_alloc_ctor(0, 2, 0); +} else { + x_86 = x_85; +} +lean_ctor_set(x_86, 0, x_77); +lean_ctor_set(x_86, 1, x_84); +return x_86; +} +} +else +{ +lean_object* x_87; lean_object* x_88; +x_87 = lean_ctor_get(x_76, 0); +lean_inc(x_87); +x_88 = lean_ctor_get(x_76, 1); +lean_inc(x_88); +lean_dec(x_76); +x_60 = x_87; +x_61 = x_88; +goto block_66; +} +} +} +else +{ +lean_object* x_89; lean_object* x_90; +x_89 = lean_ctor_get(x_67, 0); +lean_inc(x_89); +x_90 = lean_ctor_get(x_67, 1); +lean_inc(x_90); +lean_dec(x_67); +x_60 = x_89; +x_61 = x_90; +goto block_66; +} +block_66: +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_62 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_52, x_53, x_57, x_6, x_61); +lean_dec(x_6); +x_63 = lean_ctor_get(x_62, 1); +lean_inc(x_63); +if (lean_is_exclusive(x_62)) { + lean_ctor_release(x_62, 0); + lean_ctor_release(x_62, 1); + x_64 = x_62; +} else { + lean_dec_ref(x_62); + x_64 = lean_box(0); +} +if (lean_is_scalar(x_64)) { + x_65 = lean_alloc_ctor(1, 2, 0); +} else { + x_65 = x_64; + lean_ctor_set_tag(x_65, 1); +} +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_63); +return x_65; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; +x_5 = l_Lean_Expr_isLambda(x_1); +if (x_5 == 0) +{ +uint8_t x_6; lean_object* x_7; lean_object* x_8; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_6 = 0; +x_7 = lean_box(x_6); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_4); +return x_8; +} +else +{ +uint8_t x_9; +x_9 = l_Lean_Expr_isLambda(x_2); +if (x_9 == 0) +{ +lean_object* x_10; +lean_inc(x_3); +x_10 = l_Lean_Meta_inferType(x_2, x_3, x_4); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +lean_inc(x_3); +x_13 = l_Lean_Meta_whnfUsingDefault(x_11, x_3, x_12); if (lean_obj_tag(x_13) == 0) { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; -x_14 = lean_ctor_get(x_5, 0); +lean_object* x_14; +x_14 = lean_ctor_get(x_13, 0); lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 0); +if (lean_obj_tag(x_14) == 7) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; uint64_t x_19; lean_object* x_20; +x_15 = lean_ctor_get(x_13, 1); lean_inc(x_15); -x_16 = lean_ctor_get(x_13, 1); -lean_inc(x_16); lean_dec(x_13); -x_17 = lean_ctor_get(x_5, 1); +x_16 = lean_ctor_get(x_14, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_14, 1); lean_inc(x_17); -x_18 = lean_ctor_get(x_5, 2); +x_18 = lean_ctor_get(x_14, 2); lean_inc(x_18); -x_19 = !lean_is_exclusive(x_14); -if (x_19 == 0) -{ -uint8_t x_20; lean_object* x_21; lean_object* x_22; -x_20 = 1; -lean_ctor_set_uint8(x_14, sizeof(void*)*1 + 4, x_20); -x_21 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_21, 0, x_14); -lean_ctor_set(x_21, 1, x_17); -lean_ctor_set(x_21, 2, x_18); -x_22 = lean_apply_3(x_1, x_15, x_21, x_16); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -if (lean_obj_tag(x_23) == 7) -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; uint64_t x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_ctor_get(x_23, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_23, 1); -lean_inc(x_26); -x_27 = lean_ctor_get(x_23, 2); -lean_inc(x_27); -x_28 = lean_ctor_get_uint64(x_23, sizeof(void*)*3); -lean_dec(x_23); -x_29 = (uint8_t)((x_28 << 24) >> 61); -x_30 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1; -x_31 = l_Lean_mkApp(x_27, x_30); -x_32 = l_Lean_mkLambda(x_25, x_29, x_26, x_31); -x_33 = lean_apply_2(x_2, x_3, x_32); -x_34 = l_Lean_Meta_try(x_33, x_5, x_24); -return x_34; -} -else -{ -uint8_t x_35; -lean_dec(x_23); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_35 = !lean_is_exclusive(x_22); -if (x_35 == 0) -{ -lean_object* x_36; uint8_t x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_22, 0); -lean_dec(x_36); -x_37 = 0; -x_38 = lean_box(x_37); -lean_ctor_set(x_22, 0, x_38); -return x_22; -} -else -{ -lean_object* x_39; uint8_t x_40; lean_object* x_41; lean_object* x_42; -x_39 = lean_ctor_get(x_22, 1); -lean_inc(x_39); -lean_dec(x_22); -x_40 = 0; -x_41 = lean_box(x_40); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_41); -lean_ctor_set(x_42, 1, x_39); -return x_42; -} -} -} -else -{ -uint8_t x_43; -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_43 = !lean_is_exclusive(x_22); -if (x_43 == 0) -{ -return x_22; -} -else -{ -lean_object* x_44; lean_object* x_45; lean_object* x_46; -x_44 = lean_ctor_get(x_22, 0); -x_45 = lean_ctor_get(x_22, 1); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_22); -x_46 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_45); -return x_46; -} -} -} -else -{ -lean_object* x_47; uint8_t x_48; uint8_t x_49; uint8_t x_50; uint8_t x_51; uint8_t x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_47 = lean_ctor_get(x_14, 0); -x_48 = lean_ctor_get_uint8(x_14, sizeof(void*)*1); -x_49 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 1); -x_50 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 2); -x_51 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 3); -lean_inc(x_47); +x_19 = lean_ctor_get_uint64(x_14, sizeof(void*)*3); lean_dec(x_14); -x_52 = 1; -x_53 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_53, 0, x_47); -lean_ctor_set_uint8(x_53, sizeof(void*)*1, x_48); -lean_ctor_set_uint8(x_53, sizeof(void*)*1 + 1, x_49); -lean_ctor_set_uint8(x_53, sizeof(void*)*1 + 2, x_50); -lean_ctor_set_uint8(x_53, sizeof(void*)*1 + 3, x_51); -lean_ctor_set_uint8(x_53, sizeof(void*)*1 + 4, x_52); -x_54 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_54, 0, x_53); -lean_ctor_set(x_54, 1, x_17); -lean_ctor_set(x_54, 2, x_18); -x_55 = lean_apply_3(x_1, x_15, x_54, x_16); -if (lean_obj_tag(x_55) == 0) -{ -lean_object* x_56; -x_56 = lean_ctor_get(x_55, 0); -lean_inc(x_56); -if (lean_obj_tag(x_56) == 7) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; uint64_t x_61; uint8_t x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_57 = lean_ctor_get(x_55, 1); -lean_inc(x_57); -lean_dec(x_55); -x_58 = lean_ctor_get(x_56, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_56, 1); -lean_inc(x_59); -x_60 = lean_ctor_get(x_56, 2); -lean_inc(x_60); -x_61 = lean_ctor_get_uint64(x_56, sizeof(void*)*3); -lean_dec(x_56); -x_62 = (uint8_t)((x_61 << 24) >> 61); -x_63 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1; -x_64 = l_Lean_mkApp(x_60, x_63); -x_65 = l_Lean_mkLambda(x_58, x_62, x_59, x_64); -x_66 = lean_apply_2(x_2, x_3, x_65); -x_67 = l_Lean_Meta_try(x_66, x_5, x_57); -return x_67; +x_20 = l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1(x_1, x_16, x_17, x_18, x_19, x_3, x_15); +return x_20; } else { -lean_object* x_68; lean_object* x_69; uint8_t x_70; lean_object* x_71; lean_object* x_72; -lean_dec(x_56); -lean_dec(x_5); +uint8_t x_21; +lean_dec(x_14); lean_dec(x_3); -lean_dec(x_2); -x_68 = lean_ctor_get(x_55, 1); -lean_inc(x_68); -if (lean_is_exclusive(x_55)) { - lean_ctor_release(x_55, 0); - lean_ctor_release(x_55, 1); - x_69 = x_55; -} else { - lean_dec_ref(x_55); - x_69 = lean_box(0); -} -x_70 = 0; -x_71 = lean_box(x_70); -if (lean_is_scalar(x_69)) { - x_72 = lean_alloc_ctor(0, 2, 0); -} else { - x_72 = x_69; -} -lean_ctor_set(x_72, 0, x_71); -lean_ctor_set(x_72, 1, x_68); -return x_72; -} -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_73 = lean_ctor_get(x_55, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_55, 1); -lean_inc(x_74); -if (lean_is_exclusive(x_55)) { - lean_ctor_release(x_55, 0); - lean_ctor_release(x_55, 1); - x_75 = x_55; -} else { - lean_dec_ref(x_55); - x_75 = lean_box(0); -} -if (lean_is_scalar(x_75)) { - x_76 = lean_alloc_ctor(1, 2, 0); -} else { - x_76 = x_75; -} -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_74); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); lean_dec(x_1); -x_77 = !lean_is_exclusive(x_13); -if (x_77 == 0) +x_21 = !lean_is_exclusive(x_13); +if (x_21 == 0) +{ +lean_object* x_22; uint8_t x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_13, 0); +lean_dec(x_22); +x_23 = 0; +x_24 = lean_box(x_23); +lean_ctor_set(x_13, 0, x_24); +return x_13; +} +else +{ +lean_object* x_25; uint8_t x_26; lean_object* x_27; lean_object* x_28; +x_25 = lean_ctor_get(x_13, 1); +lean_inc(x_25); +lean_dec(x_13); +x_26 = 0; +x_27 = lean_box(x_26); +x_28 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_28, 0, x_27); +lean_ctor_set(x_28, 1, x_25); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_dec(x_3); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_13); +if (x_29 == 0) { return x_13; } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_13, 0); -x_79 = lean_ctor_get(x_13, 1); -lean_inc(x_79); -lean_inc(x_78); +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_13, 0); +x_31 = lean_ctor_get(x_13, 1); +lean_inc(x_31); +lean_inc(x_30); lean_dec(x_13); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; } } } else { -uint8_t x_81; lean_object* x_82; lean_object* x_83; -lean_dec(x_5); -lean_dec(x_4); +uint8_t x_33; +lean_dec(x_3); +lean_dec(x_1); +x_33 = !lean_is_exclusive(x_10); +if (x_33 == 0) +{ +return x_10; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = lean_ctor_get(x_10, 0); +x_35 = lean_ctor_get(x_10, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_10); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +} +else +{ +uint8_t x_37; lean_object* x_38; lean_object* x_39; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_81 = 0; -x_82 = lean_box(x_81); -x_83 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_6); -return x_83; +x_37 = 0; +x_38 = lean_box(x_37); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_4); +return x_39; } } } } +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +uint64_t x_8; lean_object* x_9; +x_8 = lean_unbox_uint64(x_5); +lean_dec(x_5); +x_9 = l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1(x_1, x_2, x_3, x_4, x_8, x_6, x_7); +return x_9; +} +} lean_object* l_Lean_Meta_isEtaUnassignedMVar(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -754,649 +1132,650 @@ lean_dec(x_2); return x_4; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_array_get_size(x_2); -x_10 = lean_nat_dec_lt(x_5, x_9); -lean_dec(x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_1); -x_11 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_11, 0, x_6); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_8); -return x_12; -} -else -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; lean_object* x_18; uint8_t x_41; -x_13 = lean_array_fget(x_2, x_5); -x_14 = l_Lean_Expr_Inhabited; -x_15 = lean_array_get(x_14, x_3, x_5); -x_16 = lean_array_get(x_14, x_4, x_5); -x_41 = lean_ctor_get_uint8(x_13, sizeof(void*)*1); -if (x_41 == 0) -{ -uint8_t x_42; -x_42 = lean_ctor_get_uint8(x_13, sizeof(void*)*1 + 1); -lean_dec(x_13); -if (x_42 == 0) -{ -lean_object* x_43; -lean_inc(x_1); -lean_inc(x_7); -x_43 = lean_apply_4(x_1, x_15, x_16, x_7, x_8); -if (lean_obj_tag(x_43) == 0) -{ -lean_object* x_44; uint8_t x_45; -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -x_45 = lean_unbox(x_44); -lean_dec(x_44); -if (x_45 == 0) -{ -uint8_t x_46; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_46 = !lean_is_exclusive(x_43); -if (x_46 == 0) -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_43, 0); -lean_dec(x_47); -x_48 = lean_box(0); -lean_ctor_set(x_43, 0, x_48); -return x_43; -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_43, 1); -lean_inc(x_49); -lean_dec(x_43); -x_50 = lean_box(0); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_49); -return x_51; -} -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_43, 1); -lean_inc(x_52); -lean_dec(x_43); -x_53 = lean_unsigned_to_nat(1u); -x_54 = lean_nat_add(x_5, x_53); -lean_dec(x_5); -x_5 = x_54; -x_8 = x_52; -goto _start; -} -} -else -{ -uint8_t x_56; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_56 = !lean_is_exclusive(x_43); -if (x_56 == 0) -{ -return x_43; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_43, 0); -x_58 = lean_ctor_get(x_43, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_43); -x_59 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_59, 0, x_57); -lean_ctor_set(x_59, 1, x_58); -return x_59; -} -} -} -else -{ -lean_object* x_60; -lean_inc(x_15); -x_60 = l_Lean_Meta_isEtaUnassignedMVar(x_15, x_7, x_8); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; uint8_t x_62; -x_61 = lean_ctor_get(x_60, 0); -lean_inc(x_61); -x_62 = lean_unbox(x_61); -if (x_62 == 0) -{ -lean_object* x_63; lean_object* x_64; -lean_dec(x_61); -x_63 = lean_ctor_get(x_60, 1); -lean_inc(x_63); -lean_dec(x_60); -lean_inc(x_16); -x_64 = l_Lean_Meta_isEtaUnassignedMVar(x_16, x_7, x_63); -if (lean_obj_tag(x_64) == 0) -{ -lean_object* x_65; lean_object* x_66; uint8_t x_67; -x_65 = lean_ctor_get(x_64, 0); -lean_inc(x_65); -x_66 = lean_ctor_get(x_64, 1); -lean_inc(x_66); -lean_dec(x_64); -x_67 = lean_unbox(x_65); -lean_dec(x_65); -x_17 = x_67; -x_18 = x_66; -goto block_40; -} -else -{ -uint8_t x_68; -lean_dec(x_16); -lean_dec(x_15); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_68 = !lean_is_exclusive(x_64); -if (x_68 == 0) -{ -return x_64; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_64, 0); -x_70 = lean_ctor_get(x_64, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_64); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -else -{ -lean_object* x_72; uint8_t x_73; -x_72 = lean_ctor_get(x_60, 1); -lean_inc(x_72); -lean_dec(x_60); -x_73 = lean_unbox(x_61); -lean_dec(x_61); -x_17 = x_73; -x_18 = x_72; -goto block_40; -} -} -else -{ -uint8_t x_74; -lean_dec(x_16); -lean_dec(x_15); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_74 = !lean_is_exclusive(x_60); -if (x_74 == 0) -{ -return x_60; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_60, 0); -x_76 = lean_ctor_get(x_60, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_60); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -} -else -{ -lean_object* x_78; -lean_dec(x_13); -lean_inc(x_15); -x_78 = l_Lean_Meta_isEtaUnassignedMVar(x_15, x_7, x_8); -if (lean_obj_tag(x_78) == 0) -{ -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_78, 0); -lean_inc(x_79); -x_80 = lean_unbox(x_79); -if (x_80 == 0) -{ -lean_object* x_81; lean_object* x_82; -lean_dec(x_79); -x_81 = lean_ctor_get(x_78, 1); -lean_inc(x_81); -lean_dec(x_78); -lean_inc(x_16); -x_82 = l_Lean_Meta_isEtaUnassignedMVar(x_16, x_7, x_81); -if (lean_obj_tag(x_82) == 0) -{ -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_82, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_82, 1); -lean_inc(x_84); -lean_dec(x_82); -x_85 = lean_unbox(x_83); -lean_dec(x_83); -x_17 = x_85; -x_18 = x_84; -goto block_40; -} -else -{ -uint8_t x_86; -lean_dec(x_16); -lean_dec(x_15); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_86 = !lean_is_exclusive(x_82); -if (x_86 == 0) -{ -return x_82; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_82, 0); -x_88 = lean_ctor_get(x_82, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_82); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} -} -} -else -{ -lean_object* x_90; uint8_t x_91; -x_90 = lean_ctor_get(x_78, 1); -lean_inc(x_90); -lean_dec(x_78); -x_91 = lean_unbox(x_79); -lean_dec(x_79); -x_17 = x_91; -x_18 = x_90; -goto block_40; -} -} -else -{ -uint8_t x_92; -lean_dec(x_16); -lean_dec(x_15); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_92 = !lean_is_exclusive(x_78); -if (x_92 == 0) -{ -return x_78; -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_93 = lean_ctor_get(x_78, 0); -x_94 = lean_ctor_get(x_78, 1); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_78); -x_95 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_95, 0, x_93); -lean_ctor_set(x_95, 1, x_94); -return x_95; -} -} -} -block_40: -{ -if (x_17 == 0) -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_15); -x_19 = lean_unsigned_to_nat(1u); -x_20 = lean_nat_add(x_5, x_19); -x_21 = lean_array_push(x_6, x_5); -x_5 = x_20; -x_6 = x_21; -x_8 = x_18; -goto _start; -} -else -{ -lean_object* x_23; -lean_inc(x_1); -lean_inc(x_7); -x_23 = lean_apply_4(x_1, x_15, x_16, x_7, x_18); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; uint8_t x_25; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -x_25 = lean_unbox(x_24); -lean_dec(x_24); -if (x_25 == 0) -{ -uint8_t x_26; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_26 = !lean_is_exclusive(x_23); -if (x_26 == 0) -{ -lean_object* x_27; lean_object* x_28; -x_27 = lean_ctor_get(x_23, 0); -lean_dec(x_27); -x_28 = lean_box(0); -lean_ctor_set(x_23, 0, x_28); -return x_23; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_box(0); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_30); -lean_ctor_set(x_31, 1, x_29); -return x_31; -} -} -else -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_32 = lean_ctor_get(x_23, 1); -lean_inc(x_32); -lean_dec(x_23); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_5, x_33); -lean_dec(x_5); -x_5 = x_34; -x_8 = x_32; -goto _start; -} -} -else -{ -uint8_t x_36; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_36 = !lean_is_exclusive(x_23); -if (x_36 == 0) -{ -return x_23; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_23, 0); -x_38 = lean_ctor_get(x_23, 1); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_23); -x_39 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_39, 0, x_37); -lean_ctor_set(x_39, 1, x_38); -return x_39; -} -} -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -return x_9; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_9; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -return x_9; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_2); -x_9 = lean_nat_dec_lt(x_5, x_8); +x_8 = lean_array_get_size(x_1); +x_9 = lean_nat_dec_lt(x_4, x_8); lean_dec(x_8); if (x_9 == 0) { -uint8_t x_10; lean_object* x_11; lean_object* x_12; +lean_object* x_10; lean_object* x_11; lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_10 = 1; -x_11 = lean_box(x_10); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_7); -return x_12; +lean_dec(x_4); +x_10 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_10, 0, x_5); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_7); +return x_11; } else { -lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_13 = lean_array_fget(x_2, x_5); -x_14 = lean_array_fget(x_3, x_5); -lean_inc(x_1); +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; lean_object* x_17; uint8_t x_40; +x_12 = lean_array_fget(x_1, x_4); +x_13 = l_Lean_Expr_Inhabited; +x_14 = lean_array_get(x_13, x_2, x_4); +x_15 = lean_array_get(x_13, x_3, x_4); +x_40 = lean_ctor_get_uint8(x_12, sizeof(void*)*1); +if (x_40 == 0) +{ +uint8_t x_41; +x_41 = lean_ctor_get_uint8(x_12, sizeof(void*)*1 + 1); +lean_dec(x_12); +if (x_41 == 0) +{ +lean_object* x_42; lean_inc(x_6); -x_15 = lean_apply_4(x_1, x_13, x_14, x_6, x_7); -if (lean_obj_tag(x_15) == 0) +x_42 = l_Lean_Meta_isExprDefEqAux(x_14, x_15, x_6, x_7); +if (lean_obj_tag(x_42) == 0) { -lean_object* x_16; uint8_t x_17; -x_16 = lean_ctor_get(x_15, 0); -lean_inc(x_16); -x_17 = lean_unbox(x_16); -if (x_17 == 0) +lean_object* x_43; uint8_t x_44; +x_43 = lean_ctor_get(x_42, 0); +lean_inc(x_43); +x_44 = lean_unbox(x_43); +lean_dec(x_43); +if (x_44 == 0) { -uint8_t x_18; +uint8_t x_45; lean_dec(x_6); lean_dec(x_5); -lean_dec(x_1); -x_18 = !lean_is_exclusive(x_15); -if (x_18 == 0) +lean_dec(x_4); +x_45 = !lean_is_exclusive(x_42); +if (x_45 == 0) { -lean_object* x_19; -x_19 = lean_ctor_get(x_15, 0); -lean_dec(x_19); -return x_15; +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_42, 0); +lean_dec(x_46); +x_47 = lean_box(0); +lean_ctor_set(x_42, 0, x_47); +return x_42; } else { -lean_object* x_20; lean_object* x_21; -x_20 = lean_ctor_get(x_15, 1); -lean_inc(x_20); -lean_dec(x_15); -x_21 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_21, 0, x_16); -lean_ctor_set(x_21, 1, x_20); -return x_21; +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_42, 1); +lean_inc(x_48); +lean_dec(x_42); +x_49 = lean_box(0); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_49); +lean_ctor_set(x_50, 1, x_48); +return x_50; } } else { -lean_object* x_22; lean_object* x_23; lean_object* x_24; -lean_dec(x_16); -x_22 = lean_ctor_get(x_15, 1); -lean_inc(x_22); -lean_dec(x_15); -x_23 = lean_unsigned_to_nat(1u); -x_24 = lean_nat_add(x_5, x_23); -lean_dec(x_5); -x_4 = lean_box(0); -x_5 = x_24; -x_7 = x_22; +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_42, 1); +lean_inc(x_51); +lean_dec(x_42); +x_52 = lean_unsigned_to_nat(1u); +x_53 = lean_nat_add(x_4, x_52); +lean_dec(x_4); +x_4 = x_53; +x_7 = x_51; goto _start; } } else { -uint8_t x_26; +uint8_t x_55; lean_dec(x_6); lean_dec(x_5); -lean_dec(x_1); -x_26 = !lean_is_exclusive(x_15); -if (x_26 == 0) +lean_dec(x_4); +x_55 = !lean_is_exclusive(x_42); +if (x_55 == 0) { -return x_15; +return x_42; } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_27 = lean_ctor_get(x_15, 0); -x_28 = lean_ctor_get(x_15, 1); -lean_inc(x_28); -lean_inc(x_27); +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_42, 0); +x_57 = lean_ctor_get(x_42, 1); +lean_inc(x_57); +lean_inc(x_56); +lean_dec(x_42); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_56); +lean_ctor_set(x_58, 1, x_57); +return x_58; +} +} +} +else +{ +lean_object* x_59; +lean_inc(x_14); +x_59 = l_Lean_Meta_isEtaUnassignedMVar(x_14, x_6, x_7); +if (lean_obj_tag(x_59) == 0) +{ +lean_object* x_60; uint8_t x_61; +x_60 = lean_ctor_get(x_59, 0); +lean_inc(x_60); +x_61 = lean_unbox(x_60); +if (x_61 == 0) +{ +lean_object* x_62; lean_object* x_63; +lean_dec(x_60); +x_62 = lean_ctor_get(x_59, 1); +lean_inc(x_62); +lean_dec(x_59); +lean_inc(x_15); +x_63 = l_Lean_Meta_isEtaUnassignedMVar(x_15, x_6, x_62); +if (lean_obj_tag(x_63) == 0) +{ +lean_object* x_64; lean_object* x_65; uint8_t x_66; +x_64 = lean_ctor_get(x_63, 0); +lean_inc(x_64); +x_65 = lean_ctor_get(x_63, 1); +lean_inc(x_65); +lean_dec(x_63); +x_66 = lean_unbox(x_64); +lean_dec(x_64); +x_16 = x_66; +x_17 = x_65; +goto block_39; +} +else +{ +uint8_t x_67; lean_dec(x_15); -x_29 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_29, 0, x_27); -lean_ctor_set(x_29, 1, x_28); -return x_29; +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_67 = !lean_is_exclusive(x_63); +if (x_67 == 0) +{ +return x_63; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_63, 0); +x_69 = lean_ctor_get(x_63, 1); +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_63); +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; +} +} +} +else +{ +lean_object* x_71; uint8_t x_72; +x_71 = lean_ctor_get(x_59, 1); +lean_inc(x_71); +lean_dec(x_59); +x_72 = lean_unbox(x_60); +lean_dec(x_60); +x_16 = x_72; +x_17 = x_71; +goto block_39; +} +} +else +{ +uint8_t x_73; +lean_dec(x_15); +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_73 = !lean_is_exclusive(x_59); +if (x_73 == 0) +{ +return x_59; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_59, 0); +x_75 = lean_ctor_get(x_59, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_59); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +} +else +{ +lean_object* x_77; +lean_dec(x_12); +lean_inc(x_14); +x_77 = l_Lean_Meta_isEtaUnassignedMVar(x_14, x_6, x_7); +if (lean_obj_tag(x_77) == 0) +{ +lean_object* x_78; uint8_t x_79; +x_78 = lean_ctor_get(x_77, 0); +lean_inc(x_78); +x_79 = lean_unbox(x_78); +if (x_79 == 0) +{ +lean_object* x_80; lean_object* x_81; +lean_dec(x_78); +x_80 = lean_ctor_get(x_77, 1); +lean_inc(x_80); +lean_dec(x_77); +lean_inc(x_15); +x_81 = l_Lean_Meta_isEtaUnassignedMVar(x_15, x_6, x_80); +if (lean_obj_tag(x_81) == 0) +{ +lean_object* x_82; lean_object* x_83; uint8_t x_84; +x_82 = lean_ctor_get(x_81, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_81, 1); +lean_inc(x_83); +lean_dec(x_81); +x_84 = lean_unbox(x_82); +lean_dec(x_82); +x_16 = x_84; +x_17 = x_83; +goto block_39; +} +else +{ +uint8_t x_85; +lean_dec(x_15); +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_85 = !lean_is_exclusive(x_81); +if (x_85 == 0) +{ +return x_81; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_81, 0); +x_87 = lean_ctor_get(x_81, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_81); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +else +{ +lean_object* x_89; uint8_t x_90; +x_89 = lean_ctor_get(x_77, 1); +lean_inc(x_89); +lean_dec(x_77); +x_90 = lean_unbox(x_78); +lean_dec(x_78); +x_16 = x_90; +x_17 = x_89; +goto block_39; +} +} +else +{ +uint8_t x_91; +lean_dec(x_15); +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_91 = !lean_is_exclusive(x_77); +if (x_91 == 0) +{ +return x_77; +} +else +{ +lean_object* x_92; lean_object* x_93; lean_object* x_94; +x_92 = lean_ctor_get(x_77, 0); +x_93 = lean_ctor_get(x_77, 1); +lean_inc(x_93); +lean_inc(x_92); +lean_dec(x_77); +x_94 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_94, 0, x_92); +lean_ctor_set(x_94, 1, x_93); +return x_94; +} +} +} +block_39: +{ +if (x_16 == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +lean_dec(x_15); +lean_dec(x_14); +x_18 = lean_unsigned_to_nat(1u); +x_19 = lean_nat_add(x_4, x_18); +x_20 = lean_array_push(x_5, x_4); +x_4 = x_19; +x_5 = x_20; +x_7 = x_17; +goto _start; +} +else +{ +lean_object* x_22; +lean_inc(x_6); +x_22 = l_Lean_Meta_isExprDefEqAux(x_14, x_15, x_6, x_17); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; uint8_t x_24; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +x_24 = lean_unbox(x_23); +lean_dec(x_23); +if (x_24 == 0) +{ +uint8_t x_25; +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_25 = !lean_is_exclusive(x_22); +if (x_25 == 0) +{ +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_22, 0); +lean_dec(x_26); +x_27 = lean_box(0); +lean_ctor_set(x_22, 0, x_27); +return x_22; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_22, 1); +lean_inc(x_28); +lean_dec(x_22); +x_29 = lean_box(0); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_28); +return x_30; +} +} +else +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_31 = lean_ctor_get(x_22, 1); +lean_inc(x_31); +lean_dec(x_22); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_4, x_32); +lean_dec(x_4); +x_4 = x_33; +x_7 = x_31; +goto _start; +} +} +else +{ +uint8_t x_35; +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_35 = !lean_is_exclusive(x_22); +if (x_35 == 0) +{ +return x_22; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_22, 0); +x_37 = lean_ctor_get(x_22, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_22); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; } } } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_3); lean_dec(x_2); +lean_dec(x_1); return x_8; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(x_1, x_2, x_3, lean_box(0), x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); return x_8; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +x_8 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_3); lean_dec(x_2); +lean_dec(x_1); return x_8; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_100; lean_object* x_101; uint8_t x_102; -x_9 = l_Lean_Expr_Inhabited; -x_10 = lean_array_get(x_9, x_1, x_6); -x_11 = lean_array_get(x_9, x_2, x_6); +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_1); +x_8 = lean_nat_dec_lt(x_4, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +uint8_t x_9; lean_object* x_10; lean_object* x_11; +lean_dec(x_5); +lean_dec(x_4); +x_9 = 1; +x_10 = lean_box(x_9); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_6); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_array_fget(x_1, x_4); +x_13 = lean_array_fget(x_2, x_4); +lean_inc(x_5); +x_14 = l_Lean_Meta_isExprDefEqAux(x_12, x_13, x_5, x_6); +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_15; uint8_t x_16; +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +x_16 = lean_unbox(x_15); +if (x_16 == 0) +{ +uint8_t x_17; +lean_dec(x_5); +lean_dec(x_4); +x_17 = !lean_is_exclusive(x_14); +if (x_17 == 0) +{ +lean_object* x_18; +x_18 = lean_ctor_get(x_14, 0); +lean_dec(x_18); +return x_14; +} +else +{ +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_14, 1); +lean_inc(x_19); +lean_dec(x_14); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_15); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +lean_dec(x_15); +x_21 = lean_ctor_get(x_14, 1); +lean_inc(x_21); +lean_dec(x_14); +x_22 = lean_unsigned_to_nat(1u); +x_23 = lean_nat_add(x_4, x_22); +lean_dec(x_4); +x_3 = lean_box(0); +x_4 = x_23; +x_6 = x_21; +goto _start; +} +} +else +{ +uint8_t x_25; +lean_dec(x_5); +lean_dec(x_4); +x_25 = !lean_is_exclusive(x_14); +if (x_25 == 0) +{ +return x_14; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_14, 0); +x_27 = lean_ctor_get(x_14, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_14); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); +lean_dec(x_1); +return x_7; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(x_1, x_2, lean_box(0), x_4, x_5, x_6); +return x_7; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); +lean_dec(x_1); +return x_7; +} +} +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; +x_10 = lean_nat_dec_lt(x_7, x_6); +if (x_10 == 0) +{ +uint8_t x_11; lean_object* x_12; lean_object* x_13; +lean_dec(x_8); +lean_dec(x_7); +x_11 = 0; +x_12 = lean_box(x_11); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_9); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_100; lean_object* x_101; uint8_t x_102; +x_14 = lean_array_fget(x_5, x_7); +x_15 = l_Lean_Expr_Inhabited; +x_16 = lean_array_get(x_15, x_1, x_14); +x_17 = lean_array_get(x_15, x_2, x_14); x_100 = l_Lean_Meta_ParamInfo_inhabited; -x_101 = lean_array_get(x_100, x_4, x_6); +x_101 = lean_array_get(x_100, x_3, x_14); +lean_dec(x_14); x_102 = lean_ctor_get_uint8(x_101, sizeof(void*)*1 + 1); lean_dec(x_101); if (x_102 == 0) { -lean_dec(x_5); -x_12 = x_8; +x_18 = x_9; goto block_99; } else { lean_object* x_103; -lean_inc(x_5); -lean_inc(x_7); -lean_inc(x_10); -x_103 = lean_apply_3(x_5, x_10, x_7, x_8); +lean_inc(x_8); +lean_inc(x_16); +x_103 = l_Lean_Meta_synthPending(x_16, x_8, x_9); if (lean_obj_tag(x_103) == 0) { lean_object* x_104; lean_object* x_105; x_104 = lean_ctor_get(x_103, 1); lean_inc(x_104); lean_dec(x_103); -lean_inc(x_7); -lean_inc(x_11); -x_105 = lean_apply_3(x_5, x_11, x_7, x_104); +lean_inc(x_8); +lean_inc(x_17); +x_105 = l_Lean_Meta_synthPending(x_17, x_8, x_104); if (lean_obj_tag(x_105) == 0) { lean_object* x_106; x_106 = lean_ctor_get(x_105, 1); lean_inc(x_106); lean_dec(x_105); -x_12 = x_106; +x_18 = x_106; goto block_99; } else { uint8_t x_107; -lean_dec(x_11); -lean_dec(x_10); +lean_dec(x_17); +lean_dec(x_16); +lean_dec(x_8); lean_dec(x_7); -lean_dec(x_3); x_107 = !lean_is_exclusive(x_105); if (x_107 == 0) { @@ -1420,11 +1799,10 @@ return x_110; else { uint8_t x_111; -lean_dec(x_11); -lean_dec(x_10); +lean_dec(x_17); +lean_dec(x_16); +lean_dec(x_8); lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_3); x_111 = !lean_is_exclusive(x_103); if (x_111 == 0) { @@ -1447,382 +1825,331 @@ return x_114; } block_99: { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_7); -if (x_13 == 0) -{ -lean_object* x_14; uint8_t x_15; -x_14 = lean_ctor_get(x_7, 0); -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) -{ -uint8_t x_16; uint8_t x_17; uint8_t x_18; -x_16 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 4); -x_17 = 1; -x_18 = l_Lean_Meta_TransparencyMode_lt(x_16, x_17); -if (x_18 == 0) -{ -lean_object* x_19; -x_19 = lean_apply_4(x_3, x_10, x_11, x_7, x_12); -if (lean_obj_tag(x_19) == 0) -{ -uint8_t x_20; -x_20 = !lean_is_exclusive(x_19); -if (x_20 == 0) -{ -return x_19; -} -else -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_21 = lean_ctor_get(x_19, 0); -x_22 = lean_ctor_get(x_19, 1); -lean_inc(x_22); +lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; +x_19 = lean_ctor_get(x_8, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_8, 1); +lean_inc(x_20); +x_21 = lean_ctor_get(x_8, 2); lean_inc(x_21); -lean_dec(x_19); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_21); -lean_ctor_set(x_23, 1, x_22); -return x_23; -} -} -else +x_22 = !lean_is_exclusive(x_19); +if (x_22 == 0) { -uint8_t x_24; -x_24 = !lean_is_exclusive(x_19); -if (x_24 == 0) +uint8_t x_23; uint8_t x_24; uint8_t x_25; +x_23 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 5); +x_24 = 1; +x_25 = l_Lean_Meta_TransparencyMode_lt(x_23, x_24); +if (x_25 == 0) { -return x_19; -} -else +lean_object* x_26; lean_object* x_27; +x_26 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_26, 0, x_19); +lean_ctor_set(x_26, 1, x_20); +lean_ctor_set(x_26, 2, x_21); +x_27 = l_Lean_Meta_isExprDefEqAux(x_16, x_17, x_26, x_18); +if (lean_obj_tag(x_27) == 0) { -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_19, 0); -x_26 = lean_ctor_get(x_19, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_19); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -lean_object* x_28; -lean_ctor_set_uint8(x_14, sizeof(void*)*1 + 4, x_17); -x_28 = lean_apply_4(x_3, x_10, x_11, x_7, x_12); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_28); +lean_object* x_28; uint8_t x_29; +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +x_29 = lean_unbox(x_28); if (x_29 == 0) { -return x_28; -} -else -{ lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_30 = lean_ctor_get(x_28, 0); -x_31 = lean_ctor_get(x_28, 1); -lean_inc(x_31); +lean_dec(x_28); +x_30 = lean_ctor_get(x_27, 1); lean_inc(x_30); -lean_dec(x_28); -x_32 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_32, 0, x_30); -lean_ctor_set(x_32, 1, x_31); -return x_32; -} -} -else -{ -uint8_t x_33; -x_33 = !lean_is_exclusive(x_28); -if (x_33 == 0) -{ -return x_28; -} -else -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_28, 0); -x_35 = lean_ctor_get(x_28, 1); -lean_inc(x_35); -lean_inc(x_34); -lean_dec(x_28); -x_36 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_36, 0, x_34); -lean_ctor_set(x_36, 1, x_35); -return x_36; -} -} -} -} -else -{ -lean_object* x_37; uint8_t x_38; uint8_t x_39; uint8_t x_40; uint8_t x_41; uint8_t x_42; uint8_t x_43; uint8_t x_44; -x_37 = lean_ctor_get(x_14, 0); -x_38 = lean_ctor_get_uint8(x_14, sizeof(void*)*1); -x_39 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 1); -x_40 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 2); -x_41 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 3); -x_42 = lean_ctor_get_uint8(x_14, sizeof(void*)*1 + 4); -lean_inc(x_37); -lean_dec(x_14); -x_43 = 1; -x_44 = l_Lean_Meta_TransparencyMode_lt(x_42, x_43); -if (x_44 == 0) -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_45, 0, x_37); -lean_ctor_set_uint8(x_45, sizeof(void*)*1, x_38); -lean_ctor_set_uint8(x_45, sizeof(void*)*1 + 1, x_39); -lean_ctor_set_uint8(x_45, sizeof(void*)*1 + 2, x_40); -lean_ctor_set_uint8(x_45, sizeof(void*)*1 + 3, x_41); -lean_ctor_set_uint8(x_45, sizeof(void*)*1 + 4, x_42); -lean_ctor_set(x_7, 0, x_45); -x_46 = lean_apply_4(x_3, x_10, x_11, x_7, x_12); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -if (lean_is_exclusive(x_46)) { - lean_ctor_release(x_46, 0); - lean_ctor_release(x_46, 1); - x_49 = x_46; -} else { - lean_dec_ref(x_46); - x_49 = lean_box(0); -} -if (lean_is_scalar(x_49)) { - x_50 = lean_alloc_ctor(0, 2, 0); -} else { - x_50 = x_49; -} -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_48); -return x_50; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_51 = lean_ctor_get(x_46, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -if (lean_is_exclusive(x_46)) { - lean_ctor_release(x_46, 0); - lean_ctor_release(x_46, 1); - x_53 = x_46; -} else { - lean_dec_ref(x_46); - x_53 = lean_box(0); -} -if (lean_is_scalar(x_53)) { - x_54 = lean_alloc_ctor(1, 2, 0); -} else { - x_54 = x_53; -} -lean_ctor_set(x_54, 0, x_51); -lean_ctor_set(x_54, 1, x_52); -return x_54; -} -} -else -{ -lean_object* x_55; lean_object* x_56; -x_55 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_55, 0, x_37); -lean_ctor_set_uint8(x_55, sizeof(void*)*1, x_38); -lean_ctor_set_uint8(x_55, sizeof(void*)*1 + 1, x_39); -lean_ctor_set_uint8(x_55, sizeof(void*)*1 + 2, x_40); -lean_ctor_set_uint8(x_55, sizeof(void*)*1 + 3, x_41); -lean_ctor_set_uint8(x_55, sizeof(void*)*1 + 4, x_43); -lean_ctor_set(x_7, 0, x_55); -x_56 = lean_apply_4(x_3, x_10, x_11, x_7, x_12); -if (lean_obj_tag(x_56) == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_56, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_56, 1); -lean_inc(x_58); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - x_59 = x_56; -} else { - lean_dec_ref(x_56); - x_59 = lean_box(0); -} -if (lean_is_scalar(x_59)) { - x_60 = lean_alloc_ctor(0, 2, 0); -} else { - x_60 = x_59; -} -lean_ctor_set(x_60, 0, x_57); -lean_ctor_set(x_60, 1, x_58); -return x_60; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_61 = lean_ctor_get(x_56, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_56, 1); -lean_inc(x_62); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - x_63 = x_56; -} else { - lean_dec_ref(x_56); - x_63 = lean_box(0); -} -if (lean_is_scalar(x_63)) { - x_64 = lean_alloc_ctor(1, 2, 0); -} else { - x_64 = x_63; -} -lean_ctor_set(x_64, 0, x_61); -lean_ctor_set(x_64, 1, x_62); -return x_64; -} -} -} -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; uint8_t x_70; uint8_t x_71; uint8_t x_72; uint8_t x_73; lean_object* x_74; uint8_t x_75; uint8_t x_76; -x_65 = lean_ctor_get(x_7, 0); -x_66 = lean_ctor_get(x_7, 1); -x_67 = lean_ctor_get(x_7, 2); -lean_inc(x_67); -lean_inc(x_66); -lean_inc(x_65); +lean_dec(x_27); +x_31 = lean_unsigned_to_nat(1u); +x_32 = lean_nat_add(x_7, x_31); lean_dec(x_7); -x_68 = lean_ctor_get(x_65, 0); -lean_inc(x_68); -x_69 = lean_ctor_get_uint8(x_65, sizeof(void*)*1); -x_70 = lean_ctor_get_uint8(x_65, sizeof(void*)*1 + 1); -x_71 = lean_ctor_get_uint8(x_65, sizeof(void*)*1 + 2); -x_72 = lean_ctor_get_uint8(x_65, sizeof(void*)*1 + 3); -x_73 = lean_ctor_get_uint8(x_65, sizeof(void*)*1 + 4); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - x_74 = x_65; -} else { - lean_dec_ref(x_65); - x_74 = lean_box(0); +x_7 = x_32; +x_9 = x_30; +goto _start; } -x_75 = 1; -x_76 = l_Lean_Meta_TransparencyMode_lt(x_73, x_75); -if (x_76 == 0) +else { -lean_object* x_77; lean_object* x_78; lean_object* x_79; -if (lean_is_scalar(x_74)) { - x_77 = lean_alloc_ctor(0, 1, 5); -} else { - x_77 = x_74; +uint8_t x_34; +lean_dec(x_8); +lean_dec(x_7); +x_34 = !lean_is_exclusive(x_27); +if (x_34 == 0) +{ +lean_object* x_35; +x_35 = lean_ctor_get(x_27, 0); +lean_dec(x_35); +return x_27; } -lean_ctor_set(x_77, 0, x_68); -lean_ctor_set_uint8(x_77, sizeof(void*)*1, x_69); -lean_ctor_set_uint8(x_77, sizeof(void*)*1 + 1, x_70); -lean_ctor_set_uint8(x_77, sizeof(void*)*1 + 2, x_71); -lean_ctor_set_uint8(x_77, sizeof(void*)*1 + 3, x_72); -lean_ctor_set_uint8(x_77, sizeof(void*)*1 + 4, x_73); -x_78 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_66); -lean_ctor_set(x_78, 2, x_67); -x_79 = lean_apply_4(x_3, x_10, x_11, x_78, x_12); -if (lean_obj_tag(x_79) == 0) +else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_80 = lean_ctor_get(x_79, 0); +lean_object* x_36; lean_object* x_37; +x_36 = lean_ctor_get(x_27, 1); +lean_inc(x_36); +lean_dec(x_27); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_28); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +} +else +{ +uint8_t x_38; +lean_dec(x_8); +lean_dec(x_7); +x_38 = !lean_is_exclusive(x_27); +if (x_38 == 0) +{ +return x_27; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_27, 0); +x_40 = lean_ctor_get(x_27, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_27); +x_41 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_41, 0, x_39); +lean_ctor_set(x_41, 1, x_40); +return x_41; +} +} +} +else +{ +lean_object* x_42; lean_object* x_43; +lean_ctor_set_uint8(x_19, sizeof(void*)*1 + 5, x_24); +x_42 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_42, 0, x_19); +lean_ctor_set(x_42, 1, x_20); +lean_ctor_set(x_42, 2, x_21); +x_43 = l_Lean_Meta_isExprDefEqAux(x_16, x_17, x_42, x_18); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; uint8_t x_45; +x_44 = lean_ctor_get(x_43, 0); +lean_inc(x_44); +x_45 = lean_unbox(x_44); +if (x_45 == 0) +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; +lean_dec(x_44); +x_46 = lean_ctor_get(x_43, 1); +lean_inc(x_46); +lean_dec(x_43); +x_47 = lean_unsigned_to_nat(1u); +x_48 = lean_nat_add(x_7, x_47); +lean_dec(x_7); +x_7 = x_48; +x_9 = x_46; +goto _start; +} +else +{ +uint8_t x_50; +lean_dec(x_8); +lean_dec(x_7); +x_50 = !lean_is_exclusive(x_43); +if (x_50 == 0) +{ +lean_object* x_51; +x_51 = lean_ctor_get(x_43, 0); +lean_dec(x_51); +return x_43; +} +else +{ +lean_object* x_52; lean_object* x_53; +x_52 = lean_ctor_get(x_43, 1); +lean_inc(x_52); +lean_dec(x_43); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_44); +lean_ctor_set(x_53, 1, x_52); +return x_53; +} +} +} +else +{ +uint8_t x_54; +lean_dec(x_8); +lean_dec(x_7); +x_54 = !lean_is_exclusive(x_43); +if (x_54 == 0) +{ +return x_43; +} +else +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_55 = lean_ctor_get(x_43, 0); +x_56 = lean_ctor_get(x_43, 1); +lean_inc(x_56); +lean_inc(x_55); +lean_dec(x_43); +x_57 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_57, 0, x_55); +lean_ctor_set(x_57, 1, x_56); +return x_57; +} +} +} +} +else +{ +lean_object* x_58; uint8_t x_59; uint8_t x_60; uint8_t x_61; uint8_t x_62; uint8_t x_63; uint8_t x_64; uint8_t x_65; uint8_t x_66; +x_58 = lean_ctor_get(x_19, 0); +x_59 = lean_ctor_get_uint8(x_19, sizeof(void*)*1); +x_60 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 1); +x_61 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 2); +x_62 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 3); +x_63 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 4); +x_64 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 5); +lean_inc(x_58); +lean_dec(x_19); +x_65 = 1; +x_66 = l_Lean_Meta_TransparencyMode_lt(x_64, x_65); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_67 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_67, 0, x_58); +lean_ctor_set_uint8(x_67, sizeof(void*)*1, x_59); +lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 1, x_60); +lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 2, x_61); +lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 3, x_62); +lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 4, x_63); +lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 5, x_64); +x_68 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_68, 0, x_67); +lean_ctor_set(x_68, 1, x_20); +lean_ctor_set(x_68, 2, x_21); +x_69 = l_Lean_Meta_isExprDefEqAux(x_16, x_17, x_68, x_18); +if (lean_obj_tag(x_69) == 0) +{ +lean_object* x_70; uint8_t x_71; +x_70 = lean_ctor_get(x_69, 0); +lean_inc(x_70); +x_71 = lean_unbox(x_70); +if (x_71 == 0) +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; +lean_dec(x_70); +x_72 = lean_ctor_get(x_69, 1); +lean_inc(x_72); +lean_dec(x_69); +x_73 = lean_unsigned_to_nat(1u); +x_74 = lean_nat_add(x_7, x_73); +lean_dec(x_7); +x_7 = x_74; +x_9 = x_72; +goto _start; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +lean_dec(x_8); +lean_dec(x_7); +x_76 = lean_ctor_get(x_69, 1); +lean_inc(x_76); +if (lean_is_exclusive(x_69)) { + lean_ctor_release(x_69, 0); + lean_ctor_release(x_69, 1); + x_77 = x_69; +} else { + lean_dec_ref(x_69); + x_77 = lean_box(0); +} +if (lean_is_scalar(x_77)) { + x_78 = lean_alloc_ctor(0, 2, 0); +} else { + x_78 = x_77; +} +lean_ctor_set(x_78, 0, x_70); +lean_ctor_set(x_78, 1, x_76); +return x_78; +} +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; +lean_dec(x_8); +lean_dec(x_7); +x_79 = lean_ctor_get(x_69, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_69, 1); lean_inc(x_80); -x_81 = lean_ctor_get(x_79, 1); -lean_inc(x_81); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - x_82 = x_79; +if (lean_is_exclusive(x_69)) { + lean_ctor_release(x_69, 0); + lean_ctor_release(x_69, 1); + x_81 = x_69; } else { - lean_dec_ref(x_79); - x_82 = lean_box(0); + lean_dec_ref(x_69); + x_81 = lean_box(0); } -if (lean_is_scalar(x_82)) { - x_83 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_81)) { + x_82 = lean_alloc_ctor(1, 2, 0); } else { - x_83 = x_82; + x_82 = x_81; +} +lean_ctor_set(x_82, 0, x_79); +lean_ctor_set(x_82, 1, x_80); +return x_82; } -lean_ctor_set(x_83, 0, x_80); -lean_ctor_set(x_83, 1, x_81); -return x_83; } else { -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_79, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_79, 1); -lean_inc(x_85); -if (lean_is_exclusive(x_79)) { - lean_ctor_release(x_79, 0); - lean_ctor_release(x_79, 1); - x_86 = x_79; -} else { - lean_dec_ref(x_79); - x_86 = lean_box(0); -} -if (lean_is_scalar(x_86)) { - x_87 = lean_alloc_ctor(1, 2, 0); -} else { - x_87 = x_86; -} -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_85); -return x_87; -} -} -else +lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_83 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_83, 0, x_58); +lean_ctor_set_uint8(x_83, sizeof(void*)*1, x_59); +lean_ctor_set_uint8(x_83, sizeof(void*)*1 + 1, x_60); +lean_ctor_set_uint8(x_83, sizeof(void*)*1 + 2, x_61); +lean_ctor_set_uint8(x_83, sizeof(void*)*1 + 3, x_62); +lean_ctor_set_uint8(x_83, sizeof(void*)*1 + 4, x_63); +lean_ctor_set_uint8(x_83, sizeof(void*)*1 + 5, x_65); +x_84 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_20); +lean_ctor_set(x_84, 2, x_21); +x_85 = l_Lean_Meta_isExprDefEqAux(x_16, x_17, x_84, x_18); +if (lean_obj_tag(x_85) == 0) +{ +lean_object* x_86; uint8_t x_87; +x_86 = lean_ctor_get(x_85, 0); +lean_inc(x_86); +x_87 = lean_unbox(x_86); +if (x_87 == 0) { lean_object* x_88; lean_object* x_89; lean_object* x_90; -if (lean_is_scalar(x_74)) { - x_88 = lean_alloc_ctor(0, 1, 5); -} else { - x_88 = x_74; +lean_dec(x_86); +x_88 = lean_ctor_get(x_85, 1); +lean_inc(x_88); +lean_dec(x_85); +x_89 = lean_unsigned_to_nat(1u); +x_90 = lean_nat_add(x_7, x_89); +lean_dec(x_7); +x_7 = x_90; +x_9 = x_88; +goto _start; } -lean_ctor_set(x_88, 0, x_68); -lean_ctor_set_uint8(x_88, sizeof(void*)*1, x_69); -lean_ctor_set_uint8(x_88, sizeof(void*)*1 + 1, x_70); -lean_ctor_set_uint8(x_88, sizeof(void*)*1 + 2, x_71); -lean_ctor_set_uint8(x_88, sizeof(void*)*1 + 3, x_72); -lean_ctor_set_uint8(x_88, sizeof(void*)*1 + 4, x_75); -x_89 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_89, 0, x_88); -lean_ctor_set(x_89, 1, x_66); -lean_ctor_set(x_89, 2, x_67); -x_90 = lean_apply_4(x_3, x_10, x_11, x_89, x_12); -if (lean_obj_tag(x_90) == 0) +else { -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; -x_91 = lean_ctor_get(x_90, 0); -lean_inc(x_91); -x_92 = lean_ctor_get(x_90, 1); +lean_object* x_92; lean_object* x_93; lean_object* x_94; +lean_dec(x_8); +lean_dec(x_7); +x_92 = lean_ctor_get(x_85, 1); lean_inc(x_92); -if (lean_is_exclusive(x_90)) { - lean_ctor_release(x_90, 0); - lean_ctor_release(x_90, 1); - x_93 = x_90; +if (lean_is_exclusive(x_85)) { + lean_ctor_release(x_85, 0); + lean_ctor_release(x_85, 1); + x_93 = x_85; } else { - lean_dec_ref(x_90); + lean_dec_ref(x_85); x_93 = lean_box(0); } if (lean_is_scalar(x_93)) { @@ -1830,23 +2157,26 @@ if (lean_is_scalar(x_93)) { } else { x_94 = x_93; } -lean_ctor_set(x_94, 0, x_91); +lean_ctor_set(x_94, 0, x_86); lean_ctor_set(x_94, 1, x_92); return x_94; } +} else { lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; -x_95 = lean_ctor_get(x_90, 0); +lean_dec(x_8); +lean_dec(x_7); +x_95 = lean_ctor_get(x_85, 0); lean_inc(x_95); -x_96 = lean_ctor_get(x_90, 1); +x_96 = lean_ctor_get(x_85, 1); lean_inc(x_96); -if (lean_is_exclusive(x_90)) { - lean_ctor_release(x_90, 0); - lean_ctor_release(x_90, 1); - x_97 = x_90; +if (lean_is_exclusive(x_85)) { + lean_ctor_release(x_85, 0); + lean_ctor_release(x_85, 1); + x_97 = x_85; } else { - lean_dec_ref(x_90); + lean_dec_ref(x_85); x_97 = lean_box(0); } if (lean_is_scalar(x_97)) { @@ -1863,518 +2193,186 @@ return x_98; } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_9 = lean_array_get_size(x_5); -x_10 = lean_array_get_size(x_6); -x_11 = lean_nat_dec_eq(x_9, x_10); -lean_dec(x_10); -if (x_11 == 0) -{ -uint8_t x_12; lean_object* x_13; lean_object* x_14; -lean_dec(x_9); +lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_6 = lean_array_get_size(x_2); +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_eq(x_6, x_7); lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_12 = 0; -x_13 = lean_box(x_12); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_8); -return x_14; -} -else +if (x_8 == 0) { -lean_object* x_15; lean_object* x_16; -x_15 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_15, 0, x_9); -lean_inc(x_7); -x_16 = l_Lean_Meta_getFunInfoAuxAux(x_1, x_4, x_15, x_7, x_8); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -x_19 = lean_ctor_get(x_17, 0); -lean_inc(x_19); -lean_dec(x_17); -x_20 = lean_array_get_size(x_19); -lean_inc(x_7); -lean_inc(x_2); -x_21 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(x_2, x_5, x_6, lean_box(0), x_20, x_7, x_18); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 1); -lean_inc(x_22); -lean_dec(x_21); -x_23 = lean_unsigned_to_nat(0u); -x_24 = l_Array_empty___closed__1; -lean_inc(x_7); -lean_inc(x_2); -x_25 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(x_2, x_19, x_5, x_6, x_23, x_24, x_7, x_22); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -if (lean_obj_tag(x_26) == 0) -{ -uint8_t x_27; -lean_dec(x_19); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_27 = !lean_is_exclusive(x_25); -if (x_27 == 0) -{ -lean_object* x_28; uint8_t x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_25, 0); -lean_dec(x_28); -x_29 = 0; -x_30 = lean_box(x_29); -lean_ctor_set(x_25, 0, x_30); -return x_25; -} -else -{ -lean_object* x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = 0; -x_33 = lean_box(x_32); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_33); -lean_ctor_set(x_34, 1, x_31); -return x_34; -} -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_35 = lean_ctor_get(x_25, 1); -lean_inc(x_35); -lean_dec(x_25); -x_36 = lean_ctor_get(x_26, 0); -lean_inc(x_36); -lean_dec(x_26); -x_37 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___lambda__1___boxed), 8, 5); -lean_closure_set(x_37, 0, x_5); -lean_closure_set(x_37, 1, x_6); -lean_closure_set(x_37, 2, x_2); -lean_closure_set(x_37, 3, x_19); -lean_closure_set(x_37, 4, x_3); -x_38 = lean_array_get_size(x_36); -x_39 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_40 = l_Array_anyRangeMAux___main___rarg(x_39, x_36, x_38, lean_box(0), x_37, x_23); -x_41 = lean_apply_2(x_40, x_7, x_35); -if (lean_obj_tag(x_41) == 0) -{ -lean_object* x_42; uint8_t x_43; -x_42 = lean_ctor_get(x_41, 0); -lean_inc(x_42); -x_43 = lean_unbox(x_42); -lean_dec(x_42); -if (x_43 == 0) -{ -uint8_t x_44; -x_44 = !lean_is_exclusive(x_41); -if (x_44 == 0) -{ -lean_object* x_45; uint8_t x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_41, 0); -lean_dec(x_45); -x_46 = 1; -x_47 = lean_box(x_46); -lean_ctor_set(x_41, 0, x_47); -return x_41; -} -else -{ -lean_object* x_48; uint8_t x_49; lean_object* x_50; lean_object* x_51; -x_48 = lean_ctor_get(x_41, 1); -lean_inc(x_48); -lean_dec(x_41); -x_49 = 1; -x_50 = lean_box(x_49); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_48); -return x_51; -} -} -else -{ -uint8_t x_52; -x_52 = !lean_is_exclusive(x_41); -if (x_52 == 0) -{ -lean_object* x_53; uint8_t x_54; lean_object* x_55; -x_53 = lean_ctor_get(x_41, 0); -lean_dec(x_53); -x_54 = 0; -x_55 = lean_box(x_54); -lean_ctor_set(x_41, 0, x_55); -return x_41; -} -else -{ -lean_object* x_56; uint8_t x_57; lean_object* x_58; lean_object* x_59; -x_56 = lean_ctor_get(x_41, 1); -lean_inc(x_56); -lean_dec(x_41); -x_57 = 0; -x_58 = lean_box(x_57); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_58); -lean_ctor_set(x_59, 1, x_56); -return x_59; -} -} -} -else -{ -uint8_t x_60; -x_60 = !lean_is_exclusive(x_41); -if (x_60 == 0) -{ -return x_41; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_41, 0); -x_62 = lean_ctor_get(x_41, 1); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_41); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_61); -lean_ctor_set(x_63, 1, x_62); -return x_63; -} -} -} -} -else -{ -uint8_t x_64; -lean_dec(x_19); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_64 = !lean_is_exclusive(x_25); -if (x_64 == 0) -{ -return x_25; -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_65 = lean_ctor_get(x_25, 0); -x_66 = lean_ctor_get(x_25, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_25); -x_67 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_67, 0, x_65); -lean_ctor_set(x_67, 1, x_66); -return x_67; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_19); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_68 = !lean_is_exclusive(x_21); -if (x_68 == 0) -{ -return x_21; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_21, 0); -x_70 = lean_ctor_get(x_21, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_21); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -x_72 = !lean_is_exclusive(x_16); -if (x_72 == 0) -{ -return x_16; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_16, 0); -x_74 = lean_ctor_get(x_16, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_16); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +uint8_t x_9; lean_object* x_10; lean_object* x_11; lean_dec(x_6); lean_dec(x_4); -lean_dec(x_2); lean_dec(x_1); -return x_9; -} -} -lean_object* l_Lean_Meta_isDefEqBindingDomain___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_array_get_size(x_3); -x_10 = lean_nat_dec_lt(x_5, x_9); -lean_dec(x_9); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_11 = lean_apply_2(x_6, x_7, x_8); +x_9 = 0; +x_10 = lean_box(x_9); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_5); return x_11; } else { -lean_object* x_12; lean_object* x_13; -x_12 = lean_array_fget(x_3, x_5); -lean_inc(x_7); -x_13 = l_Lean_Meta_getFVarLocalDecl(x_12, x_7, x_8); -if (lean_obj_tag(x_13) == 0) +lean_object* x_12; +lean_inc(x_4); +x_12 = l_Lean_Meta_getFunInfoNArgs(x_1, x_6, x_4, x_5); +if (lean_obj_tag(x_12) == 0) { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_14 = lean_ctor_get(x_13, 0); +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 1); lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); +lean_dec(x_12); +x_15 = lean_ctor_get(x_13, 0); lean_inc(x_15); lean_dec(x_13); -x_16 = l_Lean_LocalDecl_type(x_14); -lean_dec(x_14); -x_17 = l_Lean_Expr_Inhabited; -x_18 = lean_array_get(x_17, x_4, x_5); -lean_inc(x_2); -lean_inc(x_7); -lean_inc(x_16); -x_19 = lean_apply_4(x_2, x_16, x_18, x_7, x_15); -if (lean_obj_tag(x_19) == 0) +x_16 = lean_array_get_size(x_15); +lean_inc(x_4); +x_17 = l___private_Init_Lean_Meta_ExprDefEq_3__isDefEqArgsAux___main(x_2, x_3, lean_box(0), x_16, x_4, x_14); +if (lean_obj_tag(x_17) == 0) { -lean_object* x_20; uint8_t x_21; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_unbox(x_20); -if (x_21 == 0) +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_18 = lean_ctor_get(x_17, 1); +lean_inc(x_18); +lean_dec(x_17); +x_19 = lean_unsigned_to_nat(0u); +x_20 = l_Array_empty___closed__1; +lean_inc(x_4); +x_21 = l___private_Init_Lean_Meta_ExprDefEq_2__isDefEqArgsFirstPass___main(x_15, x_2, x_3, x_19, x_20, x_4, x_18); +if (lean_obj_tag(x_21) == 0) { -uint8_t x_22; -lean_dec(x_16); -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_22 = !lean_is_exclusive(x_19); -if (x_22 == 0) +lean_object* x_22; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +if (lean_obj_tag(x_22) == 0) { -lean_object* x_23; -x_23 = lean_ctor_get(x_19, 0); -lean_dec(x_23); -return x_19; +uint8_t x_23; +lean_dec(x_15); +lean_dec(x_4); +x_23 = !lean_is_exclusive(x_21); +if (x_23 == 0) +{ +lean_object* x_24; uint8_t x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_21, 0); +lean_dec(x_24); +x_25 = 0; +x_26 = lean_box(x_25); +lean_ctor_set(x_21, 0, x_26); +return x_21; } else { -lean_object* x_24; lean_object* x_25; -x_24 = lean_ctor_get(x_19, 1); -lean_inc(x_24); -lean_dec(x_19); -x_25 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_25, 0, x_20); -lean_ctor_set(x_25, 1, x_24); -return x_25; +lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; +x_27 = lean_ctor_get(x_21, 1); +lean_inc(x_27); +lean_dec(x_21); +x_28 = 0; +x_29 = lean_box(x_28); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_27); +return x_30; } } else { -lean_object* x_26; lean_object* x_27; -lean_dec(x_20); -x_26 = lean_ctor_get(x_19, 1); -lean_inc(x_26); -lean_dec(x_19); -lean_inc(x_7); -lean_inc(x_1); -x_27 = l_Lean_Meta_isClass(x_1, x_16, x_7, x_26); -if (lean_obj_tag(x_27) == 0) +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_31 = lean_ctor_get(x_21, 1); +lean_inc(x_31); +lean_dec(x_21); +x_32 = lean_ctor_get(x_22, 0); +lean_inc(x_32); +lean_dec(x_22); +x_33 = lean_array_get_size(x_32); +x_34 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___spec__1(x_2, x_3, x_15, x_32, x_32, x_33, x_19, x_4, x_31); +lean_dec(x_33); +lean_dec(x_32); +lean_dec(x_15); +if (lean_obj_tag(x_34) == 0) { -lean_object* x_28; -x_28 = lean_ctor_get(x_27, 0); -lean_inc(x_28); -if (lean_obj_tag(x_28) == 0) +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_unbox(x_35); +lean_dec(x_35); +if (x_36 == 0) { -lean_object* x_29; lean_object* x_30; lean_object* x_31; -lean_dec(x_12); -x_29 = lean_ctor_get(x_27, 1); -lean_inc(x_29); -lean_dec(x_27); -x_30 = lean_unsigned_to_nat(1u); -x_31 = lean_nat_add(x_5, x_30); -lean_dec(x_5); -x_5 = x_31; -x_8 = x_29; -goto _start; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_37; -x_33 = lean_ctor_get(x_27, 1); -lean_inc(x_33); -lean_dec(x_27); -x_34 = lean_ctor_get(x_28, 0); -lean_inc(x_34); -lean_dec(x_28); -x_35 = lean_unsigned_to_nat(1u); -x_36 = lean_nat_add(x_5, x_35); -lean_dec(x_5); -x_37 = !lean_is_exclusive(x_7); +uint8_t x_37; +x_37 = !lean_is_exclusive(x_34); if (x_37 == 0) { -lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_38 = lean_ctor_get(x_7, 2); -x_39 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_39, 0, x_34); -lean_ctor_set(x_39, 1, x_12); -x_40 = lean_array_push(x_38, x_39); -lean_ctor_set(x_7, 2, x_40); -x_5 = x_36; -x_8 = x_33; -goto _start; +lean_object* x_38; uint8_t x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_34, 0); +lean_dec(x_38); +x_39 = 1; +x_40 = lean_box(x_39); +lean_ctor_set(x_34, 0, x_40); +return x_34; } else { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_42 = lean_ctor_get(x_7, 0); -x_43 = lean_ctor_get(x_7, 1); -x_44 = lean_ctor_get(x_7, 2); -lean_inc(x_44); -lean_inc(x_43); -lean_inc(x_42); -lean_dec(x_7); -x_45 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_45, 0, x_34); -lean_ctor_set(x_45, 1, x_12); -x_46 = lean_array_push(x_44, x_45); -x_47 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_47, 0, x_42); -lean_ctor_set(x_47, 1, x_43); -lean_ctor_set(x_47, 2, x_46); -x_5 = x_36; -x_7 = x_47; -x_8 = x_33; -goto _start; -} +lean_object* x_41; uint8_t x_42; lean_object* x_43; lean_object* x_44; +x_41 = lean_ctor_get(x_34, 1); +lean_inc(x_41); +lean_dec(x_34); +x_42 = 1; +x_43 = lean_box(x_42); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_41); +return x_44; } } else { -uint8_t x_49; -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_49 = !lean_is_exclusive(x_27); -if (x_49 == 0) +uint8_t x_45; +x_45 = !lean_is_exclusive(x_34); +if (x_45 == 0) { -return x_27; +lean_object* x_46; uint8_t x_47; lean_object* x_48; +x_46 = lean_ctor_get(x_34, 0); +lean_dec(x_46); +x_47 = 0; +x_48 = lean_box(x_47); +lean_ctor_set(x_34, 0, x_48); +return x_34; } else { -lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_27, 0); -x_51 = lean_ctor_get(x_27, 1); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_27); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); +lean_object* x_49; uint8_t x_50; lean_object* x_51; lean_object* x_52; +x_49 = lean_ctor_get(x_34, 1); +lean_inc(x_49); +lean_dec(x_34); +x_50 = 0; +x_51 = lean_box(x_50); +x_52 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_52, 0, x_51); +lean_ctor_set(x_52, 1, x_49); return x_52; } } } -} else { uint8_t x_53; -lean_dec(x_16); -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_53 = !lean_is_exclusive(x_19); +x_53 = !lean_is_exclusive(x_34); if (x_53 == 0) { -return x_19; +return x_34; } else { lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_19, 0); -x_55 = lean_ctor_get(x_19, 1); +x_54 = lean_ctor_get(x_34, 0); +x_55 = lean_ctor_get(x_34, 1); lean_inc(x_55); lean_inc(x_54); -lean_dec(x_19); +lean_dec(x_34); x_56 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_56, 0, x_54); lean_ctor_set(x_56, 1, x_55); @@ -2382,28 +2380,25 @@ return x_56; } } } +} else { uint8_t x_57; -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_57 = !lean_is_exclusive(x_13); +lean_dec(x_15); +lean_dec(x_4); +x_57 = !lean_is_exclusive(x_21); if (x_57 == 0) { -return x_13; +return x_21; } else { lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_13, 0); -x_59 = lean_ctor_get(x_13, 1); +x_58 = lean_ctor_get(x_21, 0); +x_59 = lean_ctor_get(x_21, 1); lean_inc(x_59); lean_inc(x_58); -lean_dec(x_13); +lean_dec(x_21); x_60 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_60, 0, x_58); lean_ctor_set(x_60, 1, x_59); @@ -2411,229 +2406,778 @@ return x_60; } } } -} -} -lean_object* l_Lean_Meta_isDefEqBindingDomain___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -lean_dec(x_3); -return x_9; -} -} -lean_object* l_Lean_Meta_isDefEqBindingDomain(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_9; -} -} -lean_object* l_Lean_Meta_isDefEqBindingDomain___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_Meta_isDefEqBindingDomain(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -lean_dec(x_3); -return x_9; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -switch (lean_obj_tag(x_5)) { -case 6: -{ -if (lean_obj_tag(x_6) == 6) -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_24 = lean_ctor_get(x_5, 0); -lean_inc(x_24); -x_25 = lean_ctor_get(x_5, 1); -lean_inc(x_25); -x_26 = lean_ctor_get(x_5, 2); -lean_inc(x_26); -lean_dec(x_5); -x_27 = lean_ctor_get(x_6, 1); -x_28 = lean_ctor_get(x_6, 2); -x_29 = lean_expr_instantiate_rev(x_25, x_4); -lean_dec(x_25); -x_30 = lean_expr_instantiate_rev(x_27, x_4); -x_31 = l_Lean_Meta_mkFreshId___rarg(x_9); -x_32 = lean_ctor_get(x_31, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_31, 1); -lean_inc(x_33); -lean_dec(x_31); -x_34 = 0; -lean_inc(x_32); -x_35 = lean_local_ctx_mk_local_decl(x_3, x_32, x_24, x_29, x_34); -x_36 = l_Lean_mkFVar(x_32); -x_37 = lean_array_push(x_4, x_36); -x_38 = lean_array_push(x_7, x_30); -x_3 = x_35; -x_4 = x_37; -x_5 = x_26; -x_6 = x_28; -x_7 = x_38; -x_9 = x_33; -goto _start; -} else { -lean_object* x_40; -x_40 = lean_box(0); -x_10 = x_40; -goto block_23; -} -} -case 7: -{ -if (lean_obj_tag(x_6) == 7) -{ -lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; uint8_t x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_41 = lean_ctor_get(x_5, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_5, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_5, 2); -lean_inc(x_43); -lean_dec(x_5); -x_44 = lean_ctor_get(x_6, 1); -x_45 = lean_ctor_get(x_6, 2); -x_46 = lean_expr_instantiate_rev(x_42, x_4); -lean_dec(x_42); -x_47 = lean_expr_instantiate_rev(x_44, x_4); -x_48 = l_Lean_Meta_mkFreshId___rarg(x_9); -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = 0; -lean_inc(x_49); -x_52 = lean_local_ctx_mk_local_decl(x_3, x_49, x_41, x_46, x_51); -x_53 = l_Lean_mkFVar(x_49); -x_54 = lean_array_push(x_4, x_53); -x_55 = lean_array_push(x_7, x_47); -x_3 = x_52; -x_4 = x_54; -x_5 = x_43; -x_6 = x_45; -x_7 = x_55; -x_9 = x_50; -goto _start; -} -else -{ -lean_object* x_57; -x_57 = lean_box(0); -x_10 = x_57; -goto block_23; -} -} -default: -{ -lean_object* x_58; -x_58 = lean_box(0); -x_10 = x_58; -goto block_23; -} -} -block_23: -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; -lean_dec(x_10); -x_11 = lean_expr_instantiate_rev(x_5, x_4); -lean_dec(x_5); -x_12 = lean_expr_instantiate_rev(x_6, x_4); -lean_inc(x_2); -x_13 = lean_apply_2(x_2, x_11, x_12); -x_14 = !lean_is_exclusive(x_8); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_8, 1); +uint8_t x_61; lean_dec(x_15); -lean_ctor_set(x_8, 1, x_3); -x_16 = lean_unsigned_to_nat(0u); -x_17 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_4, x_7, x_16, x_13, x_8, x_9); -lean_dec(x_7); lean_dec(x_4); +x_61 = !lean_is_exclusive(x_17); +if (x_61 == 0) +{ return x_17; } else { -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_8, 0); -x_19 = lean_ctor_get(x_8, 2); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_8); -x_20 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_3); -lean_ctor_set(x_20, 2, x_19); -x_21 = lean_unsigned_to_nat(0u); -x_22 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_4, x_7, x_21, x_13, x_20, x_9); -lean_dec(x_7); +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_17, 0); +x_63 = lean_ctor_get(x_17, 1); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_17); +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +return x_64; +} +} +} +else +{ +uint8_t x_65; lean_dec(x_4); -return x_22; +x_65 = !lean_is_exclusive(x_12); +if (x_65 == 0) +{ +return x_12; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_66 = lean_ctor_get(x_12, 0); +x_67 = lean_ctor_get(x_12, 1); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_12); +x_68 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +return x_68; } } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +} +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +x_10 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); return x_10; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_10; +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +lean_dec(x_2); +return x_6; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l_Lean_Meta_isDefEqBindingDomain___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_6); -return x_10; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_1); +x_8 = lean_nat_dec_lt(x_3, x_7); +lean_dec(x_7); +if (x_8 == 0) { -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = lean_ctor_get(x_5, 1); -lean_inc(x_7); -x_8 = l_Array_empty___closed__1; -x_9 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(x_1, x_2, x_7, x_8, x_3, x_4, x_8, x_5, x_6); +lean_object* x_9; +lean_dec(x_3); +x_9 = lean_apply_2(x_4, x_5, x_6); return x_9; } +else +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_array_fget(x_1, x_3); +lean_inc(x_5); +x_11 = l_Lean_Meta_getFVarLocalDecl(x_10, x_5, x_6); +if (lean_obj_tag(x_11) == 0) +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_11, 1); +lean_inc(x_13); +lean_dec(x_11); +x_14 = l_Lean_LocalDecl_type(x_12); +lean_dec(x_12); +x_15 = l_Lean_Expr_Inhabited; +x_16 = lean_array_get(x_15, x_2, x_3); +lean_inc(x_5); +lean_inc(x_14); +x_17 = l_Lean_Meta_isExprDefEqAux(x_14, x_16, x_5, x_13); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; uint8_t x_19; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_unbox(x_18); +if (x_19 == 0) +{ +uint8_t x_20; +lean_dec(x_14); +lean_dec(x_10); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_20 = !lean_is_exclusive(x_17); +if (x_20 == 0) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_17, 0); +lean_dec(x_21); +return x_17; } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +else +{ +lean_object* x_22; lean_object* x_23; +x_22 = lean_ctor_get(x_17, 1); +lean_inc(x_22); +lean_dec(x_17); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_18); +lean_ctor_set(x_23, 1, x_22); +return x_23; +} +} +else +{ +lean_object* x_24; lean_object* x_25; +lean_dec(x_18); +x_24 = lean_ctor_get(x_17, 1); +lean_inc(x_24); +lean_dec(x_17); +lean_inc(x_5); +x_25 = l_Lean_Meta_isClass(x_14, x_5, x_24); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; +x_26 = lean_ctor_get(x_25, 0); +lean_inc(x_26); +if (lean_obj_tag(x_26) == 0) +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +lean_dec(x_10); +x_27 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +lean_dec(x_25); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_add(x_3, x_28); +lean_dec(x_3); +x_3 = x_29; +x_6 = x_27; +goto _start; +} +else +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; +x_31 = lean_ctor_get(x_25, 1); +lean_inc(x_31); +lean_dec(x_25); +x_32 = lean_ctor_get(x_26, 0); +lean_inc(x_32); +lean_dec(x_26); +x_33 = lean_unsigned_to_nat(1u); +x_34 = lean_nat_add(x_3, x_33); +lean_dec(x_3); +x_35 = !lean_is_exclusive(x_5); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_5, 2); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_32); +lean_ctor_set(x_37, 1, x_10); +x_38 = lean_array_push(x_36, x_37); +lean_ctor_set(x_5, 2, x_38); +x_3 = x_34; +x_6 = x_31; +goto _start; +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_40 = lean_ctor_get(x_5, 0); +x_41 = lean_ctor_get(x_5, 1); +x_42 = lean_ctor_get(x_5, 2); +lean_inc(x_42); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_5); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_32); +lean_ctor_set(x_43, 1, x_10); +x_44 = lean_array_push(x_42, x_43); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_40); +lean_ctor_set(x_45, 1, x_41); +lean_ctor_set(x_45, 2, x_44); +x_3 = x_34; +x_5 = x_45; +x_6 = x_31; +goto _start; +} +} +} +else +{ +uint8_t x_47; +lean_dec(x_10); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_47 = !lean_is_exclusive(x_25); +if (x_47 == 0) +{ +return x_25; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_25, 0); +x_49 = lean_ctor_get(x_25, 1); +lean_inc(x_49); +lean_inc(x_48); +lean_dec(x_25); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; +} +} +} +} +else +{ +uint8_t x_51; +lean_dec(x_14); +lean_dec(x_10); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_51 = !lean_is_exclusive(x_17); +if (x_51 == 0) +{ +return x_17; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_17, 0); +x_53 = lean_ctor_get(x_17, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_17); +x_54 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} +else +{ +uint8_t x_55; +lean_dec(x_10); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_55 = !lean_is_exclusive(x_11); +if (x_55 == 0) +{ +return x_11; +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_11, 0); +x_57 = lean_ctor_get(x_11, 1); +lean_inc(x_57); +lean_inc(x_56); +lean_dec(x_11); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_56); +lean_ctor_set(x_58, 1, x_57); +return x_58; +} +} +} +} +} +lean_object* l_Lean_Meta_isDefEqBindingDomain___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_4); +x_7 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); +lean_dec(x_1); return x_7; } } -lean_object* l_AssocList_find___main___at_Lean_Meta_CheckAssignment_findCached___spec__2(lean_object* x_1, lean_object* x_2) { +lean_object* l_Lean_Meta_isDefEqBindingDomain(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_Lean_Meta_isDefEqBindingDomain___main(x_1, x_2, x_3, x_4, x_5, x_6); +return x_7; +} +} +lean_object* l_Lean_Meta_isDefEqBindingDomain___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_Lean_Meta_isDefEqBindingDomain(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); +lean_dec(x_1); +return x_7; +} +} +lean_object* l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_9 = lean_expr_instantiate_rev(x_2, x_1); +x_10 = lean_expr_instantiate_rev(x_3, x_1); +x_11 = lean_array_get_size(x_4); +x_12 = lean_nat_dec_lt(x_6, x_11); +lean_dec(x_11); +if (x_12 == 0) +{ +lean_object* x_13; +lean_dec(x_6); +x_13 = l_Lean_Meta_isExprDefEqAux(x_9, x_10, x_7, x_8); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_10); +lean_dec(x_9); +x_14 = lean_array_fget(x_4, x_6); +lean_inc(x_7); +x_15 = l_Lean_Meta_getFVarLocalDecl(x_14, x_7, x_8); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +x_18 = l_Lean_LocalDecl_type(x_16); +lean_dec(x_16); +x_19 = l_Lean_Expr_Inhabited; +x_20 = lean_array_get(x_19, x_5, x_6); +lean_inc(x_7); +lean_inc(x_18); +x_21 = l_Lean_Meta_isExprDefEqAux(x_18, x_20, x_7, x_17); +if (lean_obj_tag(x_21) == 0) +{ +lean_object* x_22; uint8_t x_23; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +x_23 = lean_unbox(x_22); +if (x_23 == 0) +{ +uint8_t x_24; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +x_24 = !lean_is_exclusive(x_21); +if (x_24 == 0) +{ +lean_object* x_25; +x_25 = lean_ctor_get(x_21, 0); +lean_dec(x_25); +return x_21; +} +else +{ +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_21, 1); +lean_inc(x_26); +lean_dec(x_21); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_22); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +else +{ +lean_object* x_28; lean_object* x_29; +lean_dec(x_22); +x_28 = lean_ctor_get(x_21, 1); +lean_inc(x_28); +lean_dec(x_21); +lean_inc(x_7); +x_29 = l_Lean_Meta_isClass(x_18, x_7, x_28); +if (lean_obj_tag(x_29) == 0) +{ +lean_object* x_30; +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +if (lean_obj_tag(x_30) == 0) +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; +lean_dec(x_14); +x_31 = lean_ctor_get(x_29, 1); +lean_inc(x_31); +lean_dec(x_29); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_6, x_32); +lean_dec(x_6); +x_6 = x_33; +x_8 = x_31; +goto _start; +} +else +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_35 = lean_ctor_get(x_29, 1); +lean_inc(x_35); +lean_dec(x_29); +x_36 = lean_ctor_get(x_30, 0); +lean_inc(x_36); +lean_dec(x_30); +x_37 = lean_unsigned_to_nat(1u); +x_38 = lean_nat_add(x_6, x_37); +lean_dec(x_6); +x_39 = !lean_is_exclusive(x_7); +if (x_39 == 0) +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_40 = lean_ctor_get(x_7, 2); +x_41 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_41, 0, x_36); +lean_ctor_set(x_41, 1, x_14); +x_42 = lean_array_push(x_40, x_41); +lean_ctor_set(x_7, 2, x_42); +x_6 = x_38; +x_8 = x_35; +goto _start; +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_44 = lean_ctor_get(x_7, 0); +x_45 = lean_ctor_get(x_7, 1); +x_46 = lean_ctor_get(x_7, 2); +lean_inc(x_46); +lean_inc(x_45); +lean_inc(x_44); +lean_dec(x_7); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_36); +lean_ctor_set(x_47, 1, x_14); +x_48 = lean_array_push(x_46, x_47); +x_49 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_49, 0, x_44); +lean_ctor_set(x_49, 1, x_45); +lean_ctor_set(x_49, 2, x_48); +x_6 = x_38; +x_7 = x_49; +x_8 = x_35; +goto _start; +} +} +} +else +{ +uint8_t x_51; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +x_51 = !lean_is_exclusive(x_29); +if (x_51 == 0) +{ +return x_29; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_29, 0); +x_53 = lean_ctor_get(x_29, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_29); +x_54 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} +} +else +{ +uint8_t x_55; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +x_55 = !lean_is_exclusive(x_21); +if (x_55 == 0) +{ +return x_21; +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_21, 0); +x_57 = lean_ctor_get(x_21, 1); +lean_inc(x_57); +lean_inc(x_56); +lean_dec(x_21); +x_58 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_58, 0, x_56); +lean_ctor_set(x_58, 1, x_57); +return x_58; +} +} +} +else +{ +uint8_t x_59; +lean_dec(x_14); +lean_dec(x_7); +lean_dec(x_6); +x_59 = !lean_is_exclusive(x_15); +if (x_59 == 0) +{ +return x_15; +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_60 = lean_ctor_get(x_15, 0); +x_61 = lean_ctor_get(x_15, 1); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_15); +x_62 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_62, 0, x_60); +lean_ctor_set(x_62, 1, x_61); +return x_62; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +switch (lean_obj_tag(x_3)) { +case 6: +{ +if (lean_obj_tag(x_4) == 6) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_19 = lean_ctor_get(x_3, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_3, 1); +lean_inc(x_20); +x_21 = lean_ctor_get(x_3, 2); +lean_inc(x_21); +lean_dec(x_3); +x_22 = lean_ctor_get(x_4, 1); +x_23 = lean_ctor_get(x_4, 2); +x_24 = lean_expr_instantiate_rev(x_20, x_2); +lean_dec(x_20); +x_25 = lean_expr_instantiate_rev(x_22, x_2); +x_26 = l_Lean_Meta_mkFreshId___rarg(x_7); +x_27 = lean_ctor_get(x_26, 0); +lean_inc(x_27); +x_28 = lean_ctor_get(x_26, 1); +lean_inc(x_28); +lean_dec(x_26); +x_29 = 0; +lean_inc(x_27); +x_30 = lean_local_ctx_mk_local_decl(x_1, x_27, x_19, x_24, x_29); +x_31 = l_Lean_mkFVar(x_27); +x_32 = lean_array_push(x_2, x_31); +x_33 = lean_array_push(x_5, x_25); +x_1 = x_30; +x_2 = x_32; +x_3 = x_21; +x_4 = x_23; +x_5 = x_33; +x_7 = x_28; +goto _start; +} +else +{ +lean_object* x_35; +x_35 = lean_box(0); +x_8 = x_35; +goto block_18; +} +} +case 7: +{ +if (lean_obj_tag(x_4) == 7) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_36 = lean_ctor_get(x_3, 0); +lean_inc(x_36); +x_37 = lean_ctor_get(x_3, 1); +lean_inc(x_37); +x_38 = lean_ctor_get(x_3, 2); +lean_inc(x_38); +lean_dec(x_3); +x_39 = lean_ctor_get(x_4, 1); +x_40 = lean_ctor_get(x_4, 2); +x_41 = lean_expr_instantiate_rev(x_37, x_2); +lean_dec(x_37); +x_42 = lean_expr_instantiate_rev(x_39, x_2); +x_43 = l_Lean_Meta_mkFreshId___rarg(x_7); +x_44 = lean_ctor_get(x_43, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_43, 1); +lean_inc(x_45); +lean_dec(x_43); +x_46 = 0; +lean_inc(x_44); +x_47 = lean_local_ctx_mk_local_decl(x_1, x_44, x_36, x_41, x_46); +x_48 = l_Lean_mkFVar(x_44); +x_49 = lean_array_push(x_2, x_48); +x_50 = lean_array_push(x_5, x_42); +x_1 = x_47; +x_2 = x_49; +x_3 = x_38; +x_4 = x_40; +x_5 = x_50; +x_7 = x_45; +goto _start; +} +else +{ +lean_object* x_52; +x_52 = lean_box(0); +x_8 = x_52; +goto block_18; +} +} +default: +{ +lean_object* x_53; +x_53 = lean_box(0); +x_8 = x_53; +goto block_18; +} +} +block_18: +{ +uint8_t x_9; +lean_dec(x_8); +x_9 = !lean_is_exclusive(x_6); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_6, 1); +lean_dec(x_10); +lean_ctor_set(x_6, 1, x_1); +x_11 = lean_unsigned_to_nat(0u); +x_12 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___spec__1(x_2, x_3, x_4, x_2, x_5, x_11, x_6, x_7); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_13 = lean_ctor_get(x_6, 0); +x_14 = lean_ctor_get(x_6, 2); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_6); +x_15 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_1); +lean_ctor_set(x_15, 2, x_14); +x_16 = lean_unsigned_to_nat(0u); +x_17 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___spec__1(x_2, x_3, x_4, x_2, x_5, x_16, x_15, x_7); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +return x_17; +} +} +} +} +lean_object* l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_Meta_isDefEqBindingDomain___main___at___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_9; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = lean_ctor_get(x_3, 1); +lean_inc(x_5); +x_6 = l_Array_empty___closed__1; +x_7 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(x_5, x_6, x_1, x_2, x_6, x_3, x_4); +return x_7; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Init_Lean_Meta_ExprDefEq_6__isDefEqBinding(x_1, x_2, x_3, x_4); +lean_dec(x_2); +return x_5; +} +} +lean_object* l_AssocList_find___main___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__2(lean_object* x_1, lean_object* x_2) { _start: { if (lean_obj_tag(x_2) == 0) @@ -2665,7 +3209,7 @@ return x_9; } } } -lean_object* l_HashMapImp_find___at_Lean_Meta_CheckAssignment_findCached___spec__1(lean_object* x_1, lean_object* x_2) { +lean_object* l_HashMapImp_find___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__1(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; lean_object* x_4; size_t x_5; size_t x_6; lean_object* x_7; lean_object* x_8; @@ -2675,18 +3219,18 @@ x_5 = l_Lean_Expr_hash(x_2); x_6 = lean_usize_modn(x_5, x_4); lean_dec(x_4); x_7 = lean_array_uget(x_3, x_6); -x_8 = l_AssocList_find___main___at_Lean_Meta_CheckAssignment_findCached___spec__2(x_2, x_7); +x_8 = l_AssocList_find___main___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__2(x_2, x_7); lean_dec(x_7); return x_8; } } -lean_object* l_Lean_Meta_CheckAssignment_findCached(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_7__findCached(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; lean_object* x_5; lean_object* x_6; x_4 = lean_ctor_get(x_3, 2); lean_inc(x_4); -x_5 = l_HashMapImp_find___at_Lean_Meta_CheckAssignment_findCached___spec__1(x_4, x_1); +x_5 = l_HashMapImp_find___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__1(x_4, x_1); lean_dec(x_4); x_6 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_6, 0, x_5); @@ -2694,37 +3238,37 @@ lean_ctor_set(x_6, 1, x_3); return x_6; } } -lean_object* l_AssocList_find___main___at_Lean_Meta_CheckAssignment_findCached___spec__2___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l_AssocList_find___main___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__2___boxed(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; -x_3 = l_AssocList_find___main___at_Lean_Meta_CheckAssignment_findCached___spec__2(x_1, x_2); +x_3 = l_AssocList_find___main___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__2(x_1, x_2); lean_dec(x_2); lean_dec(x_1); return x_3; } } -lean_object* l_HashMapImp_find___at_Lean_Meta_CheckAssignment_findCached___spec__1___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l_HashMapImp_find___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__1___boxed(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; -x_3 = l_HashMapImp_find___at_Lean_Meta_CheckAssignment_findCached___spec__1(x_1, x_2); +x_3 = l_HashMapImp_find___at___private_Init_Lean_Meta_ExprDefEq_7__findCached___spec__1(x_1, x_2); lean_dec(x_2); lean_dec(x_1); return x_3; } } -lean_object* l_Lean_Meta_CheckAssignment_findCached___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_7__findCached___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Lean_Meta_CheckAssignment_findCached(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_1, x_2, x_3); lean_dec(x_2); lean_dec(x_1); return x_4; } } -uint8_t l_AssocList_contains___main___at_Lean_Meta_CheckAssignment_cache___spec__2(lean_object* x_1, lean_object* x_2) { +uint8_t l_AssocList_contains___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__2(lean_object* x_1, lean_object* x_2) { _start: { if (lean_obj_tag(x_2) == 0) @@ -2753,7 +3297,7 @@ return x_8; } } } -lean_object* l_AssocList_foldlM___main___at_Lean_Meta_CheckAssignment_cache___spec__5(lean_object* x_1, lean_object* x_2) { +lean_object* l_AssocList_foldlM___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__5(lean_object* x_1, lean_object* x_2) { _start: { if (lean_obj_tag(x_2) == 0) @@ -2807,7 +3351,7 @@ goto _start; } } } -lean_object* l_HashMapImp_moveEntries___main___at_Lean_Meta_CheckAssignment_cache___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_HashMapImp_moveEntries___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; uint8_t x_5; @@ -2826,7 +3370,7 @@ lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_obj x_6 = lean_array_fget(x_2, x_1); x_7 = lean_box(0); x_8 = lean_array_fset(x_2, x_1, x_7); -x_9 = l_AssocList_foldlM___main___at_Lean_Meta_CheckAssignment_cache___spec__5(x_3, x_6); +x_9 = l_AssocList_foldlM___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__5(x_3, x_6); x_10 = lean_unsigned_to_nat(1u); x_11 = lean_nat_add(x_1, x_10); lean_dec(x_1); @@ -2837,7 +3381,7 @@ goto _start; } } } -lean_object* l_HashMapImp_expand___at_Lean_Meta_CheckAssignment_cache___spec__3(lean_object* x_1, lean_object* x_2) { +lean_object* l_HashMapImp_expand___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__3(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; @@ -2848,14 +3392,14 @@ lean_dec(x_3); x_6 = lean_box(0); x_7 = lean_mk_array(x_5, x_6); x_8 = lean_unsigned_to_nat(0u); -x_9 = l_HashMapImp_moveEntries___main___at_Lean_Meta_CheckAssignment_cache___spec__4(x_8, x_2, x_7); +x_9 = l_HashMapImp_moveEntries___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__4(x_8, x_2, x_7); x_10 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_10, 0, x_1); lean_ctor_set(x_10, 1, x_9); return x_10; } } -lean_object* l_AssocList_replace___main___at_Lean_Meta_CheckAssignment_cache___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_AssocList_replace___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { if (lean_obj_tag(x_3) == 0) @@ -2878,7 +3422,7 @@ x_8 = lean_expr_equal(x_5, x_1); if (x_8 == 0) { lean_object* x_9; -x_9 = l_AssocList_replace___main___at_Lean_Meta_CheckAssignment_cache___spec__6(x_1, x_2, x_7); +x_9 = l_AssocList_replace___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__6(x_1, x_2, x_7); lean_ctor_set(x_3, 2, x_9); return x_3; } @@ -2905,7 +3449,7 @@ x_13 = lean_expr_equal(x_10, x_1); if (x_13 == 0) { lean_object* x_14; lean_object* x_15; -x_14 = l_AssocList_replace___main___at_Lean_Meta_CheckAssignment_cache___spec__6(x_1, x_2, x_12); +x_14 = l_AssocList_replace___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__6(x_1, x_2, x_12); x_15 = lean_alloc_ctor(1, 3, 0); lean_ctor_set(x_15, 0, x_10); lean_ctor_set(x_15, 1, x_11); @@ -2927,7 +3471,7 @@ return x_16; } } } -lean_object* l_HashMapImp_insert___at_Lean_Meta_CheckAssignment_cache___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_HashMapImp_insert___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { uint8_t x_4; @@ -2941,7 +3485,7 @@ x_7 = lean_array_get_size(x_6); x_8 = l_Lean_Expr_hash(x_2); x_9 = lean_usize_modn(x_8, x_7); x_10 = lean_array_uget(x_6, x_9); -x_11 = l_AssocList_contains___main___at_Lean_Meta_CheckAssignment_cache___spec__2(x_2, x_10); +x_11 = l_AssocList_contains___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__2(x_2, x_10); if (x_11 == 0) { lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; @@ -2959,7 +3503,7 @@ if (x_16 == 0) { lean_object* x_17; lean_free_object(x_1); -x_17 = l_HashMapImp_expand___at_Lean_Meta_CheckAssignment_cache___spec__3(x_13, x_15); +x_17 = l_HashMapImp_expand___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__3(x_13, x_15); return x_17; } else @@ -2973,7 +3517,7 @@ else { lean_object* x_18; lean_object* x_19; lean_dec(x_7); -x_18 = l_AssocList_replace___main___at_Lean_Meta_CheckAssignment_cache___spec__6(x_2, x_3, x_10); +x_18 = l_AssocList_replace___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__6(x_2, x_3, x_10); x_19 = lean_array_uset(x_6, x_9, x_18); lean_ctor_set(x_1, 1, x_19); return x_1; @@ -2991,7 +3535,7 @@ x_22 = lean_array_get_size(x_21); x_23 = l_Lean_Expr_hash(x_2); x_24 = lean_usize_modn(x_23, x_22); x_25 = lean_array_uget(x_21, x_24); -x_26 = l_AssocList_contains___main___at_Lean_Meta_CheckAssignment_cache___spec__2(x_2, x_25); +x_26 = l_AssocList_contains___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__2(x_2, x_25); if (x_26 == 0) { lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; @@ -3008,7 +3552,7 @@ lean_dec(x_22); if (x_31 == 0) { lean_object* x_32; -x_32 = l_HashMapImp_expand___at_Lean_Meta_CheckAssignment_cache___spec__3(x_28, x_30); +x_32 = l_HashMapImp_expand___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__3(x_28, x_30); return x_32; } else @@ -3024,7 +3568,7 @@ else { lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_dec(x_22); -x_34 = l_AssocList_replace___main___at_Lean_Meta_CheckAssignment_cache___spec__6(x_2, x_3, x_25); +x_34 = l_AssocList_replace___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__6(x_2, x_3, x_25); x_35 = lean_array_uset(x_21, x_24, x_34); x_36 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_36, 0, x_20); @@ -3034,7 +3578,7 @@ return x_36; } } } -lean_object* l_Lean_Meta_CheckAssignment_cache(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__cache(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { uint8_t x_5; @@ -3043,7 +3587,7 @@ if (x_5 == 0) { lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; x_6 = lean_ctor_get(x_4, 2); -x_7 = l_HashMapImp_insert___at_Lean_Meta_CheckAssignment_cache___spec__1(x_6, x_1, x_2); +x_7 = l_HashMapImp_insert___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__1(x_6, x_1, x_2); lean_ctor_set(x_4, 2, x_7); x_8 = lean_box(0); x_9 = lean_alloc_ctor(0, 2, 0); @@ -3061,7 +3605,7 @@ lean_inc(x_12); lean_inc(x_11); lean_inc(x_10); lean_dec(x_4); -x_13 = l_HashMapImp_insert___at_Lean_Meta_CheckAssignment_cache___spec__1(x_12, x_1, x_2); +x_13 = l_HashMapImp_insert___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__1(x_12, x_1, x_2); x_14 = lean_alloc_ctor(0, 3, 0); lean_ctor_set(x_14, 0, x_10); lean_ctor_set(x_14, 1, x_11); @@ -3074,22 +3618,22 @@ return x_16; } } } -lean_object* l_AssocList_contains___main___at_Lean_Meta_CheckAssignment_cache___spec__2___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l_AssocList_contains___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__2___boxed(lean_object* x_1, lean_object* x_2) { _start: { uint8_t x_3; lean_object* x_4; -x_3 = l_AssocList_contains___main___at_Lean_Meta_CheckAssignment_cache___spec__2(x_1, x_2); +x_3 = l_AssocList_contains___main___at___private_Init_Lean_Meta_ExprDefEq_8__cache___spec__2(x_1, x_2); lean_dec(x_2); lean_dec(x_1); x_4 = lean_box(x_3); return x_4; } } -lean_object* l_Lean_Meta_CheckAssignment_cache___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__cache___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l_Lean_Meta_CheckAssignment_cache(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_1, x_2, x_3, x_4); lean_dec(x_3); return x_5; } @@ -3098,7 +3642,7 @@ lean_object* _init_l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__1() { _start: { lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l_Lean_Meta_CheckAssignment_findCached___boxed), 3, 0); +x_1 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_7__findCached___boxed), 3, 0); return x_1; } } @@ -3106,7 +3650,7 @@ lean_object* _init_l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__2() { _start: { lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l_Lean_Meta_CheckAssignment_cache___boxed), 4, 0); +x_1 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_8__cache___boxed), 4, 0); return x_1; } } @@ -3130,7 +3674,7 @@ x_1 = l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__3; return x_1; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_7__visit(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__visit(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; uint8_t x_28; @@ -3168,7 +3712,7 @@ block_27: { lean_object* x_6; lean_object* x_7; lean_dec(x_5); -x_6 = l_Lean_Meta_CheckAssignment_findCached(x_2, x_3, x_4); +x_6 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_2, x_3, x_4); x_7 = lean_ctor_get(x_6, 0); lean_inc(x_7); if (lean_obj_tag(x_7) == 0) @@ -3189,7 +3733,7 @@ x_11 = lean_ctor_get(x_9, 1); lean_inc(x_11); lean_dec(x_9); lean_inc(x_10); -x_12 = l_Lean_Meta_CheckAssignment_cache(x_2, x_10, x_3, x_11); +x_12 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_2, x_10, x_3, x_11); lean_dec(x_3); x_13 = !lean_is_exclusive(x_12); if (x_13 == 0) @@ -3273,52 +3817,6 @@ return x_26; } } } -uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_checkFVar___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -uint8_t x_6; -x_6 = lean_nat_dec_lt(x_5, x_4); -if (x_6 == 0) -{ -uint8_t x_7; -lean_dec(x_5); -x_7 = 0; -return x_7; -} -else -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_fget(x_3, x_5); -x_9 = lean_expr_eqv(x_2, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; lean_object* x_11; -x_10 = lean_unsigned_to_nat(1u); -x_11 = lean_nat_add(x_5, x_10); -lean_dec(x_5); -x_5 = x_11; -goto _start; -} -else -{ -lean_dec(x_5); -return x_9; -} -} -} -} -uint8_t l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(lean_object* x_1, lean_object* x_2) { -_start: -{ -lean_object* x_3; lean_object* x_4; uint8_t x_5; -x_3 = lean_array_get_size(x_1); -x_4 = lean_unsigned_to_nat(0u); -x_5 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_checkFVar___spec__2(x_1, x_2, x_1, x_3, x_4); -lean_dec(x_3); -return x_5; -} -} lean_object* l_Lean_Meta_CheckAssignment_checkFVar(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -3338,253 +3836,233 @@ lean_inc(x_8); x_9 = l_Lean_LocalContext_findFVar(x_8, x_2); if (lean_obj_tag(x_9) == 0) { -lean_object* x_10; uint8_t x_11; +lean_object* x_10; lean_object* x_11; uint8_t x_12; lean_dec(x_1); x_10 = lean_ctor_get(x_3, 3); lean_inc(x_10); lean_dec(x_3); -x_11 = l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(x_10, x_2); +x_11 = l_Lean_Expr_HasBeq; +lean_inc(x_2); +x_12 = l_Array_contains___rarg(x_11, x_10, x_2); lean_dec(x_10); -if (x_11 == 0) +if (x_12 == 0) { -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = l_Lean_Expr_fvarId_x21(x_2); +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = l_Lean_Expr_fvarId_x21(x_2); lean_dec(x_2); -x_13 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_13, 0, x_12); -x_14 = lean_alloc_ctor(1, 2, 0); +x_14 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_4); -return x_14; -} -else -{ -lean_object* x_15; -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_2); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_14); lean_ctor_set(x_15, 1, x_4); return x_15; } -} else { lean_object* x_16; -x_16 = lean_ctor_get(x_9, 0); -lean_inc(x_16); -lean_dec(x_9); -if (lean_obj_tag(x_16) == 0) +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_2); +lean_ctor_set(x_16, 1, x_4); +return x_16; +} +} +else { -lean_object* x_17; uint8_t x_18; -lean_dec(x_16); -lean_dec(x_1); -x_17 = lean_ctor_get(x_3, 3); +lean_object* x_17; +x_17 = lean_ctor_get(x_9, 0); lean_inc(x_17); -lean_dec(x_3); -x_18 = l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(x_17, x_2); +lean_dec(x_9); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; lean_object* x_19; uint8_t x_20; lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_19 = l_Lean_Expr_fvarId_x21(x_2); -lean_dec(x_2); -x_20 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_20, 0, x_19); -x_21 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_21, 0, x_20); -lean_ctor_set(x_21, 1, x_4); -return x_21; -} -else -{ -lean_object* x_22; -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_2); -lean_ctor_set(x_22, 1, x_4); -return x_22; -} -} -else -{ -lean_object* x_23; lean_object* x_24; uint8_t x_47; -lean_dec(x_2); -x_23 = lean_ctor_get(x_16, 4); -lean_inc(x_23); -lean_dec(x_16); -x_47 = l_Lean_Expr_hasExprMVar(x_23); -if (x_47 == 0) -{ -uint8_t x_48; -x_48 = l_Lean_Expr_hasFVar(x_23); -if (x_48 == 0) -{ -lean_object* x_49; -lean_dec(x_3); lean_dec(x_1); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_23); -lean_ctor_set(x_49, 1, x_4); -return x_49; +x_18 = lean_ctor_get(x_3, 3); +lean_inc(x_18); +lean_dec(x_3); +x_19 = l_Lean_Expr_HasBeq; +lean_inc(x_2); +x_20 = l_Array_contains___rarg(x_19, x_18, x_2); +lean_dec(x_18); +if (x_20 == 0) +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = l_Lean_Expr_fvarId_x21(x_2); +lean_dec(x_2); +x_22 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_22, 0, x_21); +x_23 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_4); +return x_23; } else { -lean_object* x_50; -x_50 = lean_box(0); -x_24 = x_50; -goto block_46; +lean_object* x_24; +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_2); +lean_ctor_set(x_24, 1, x_4); +return x_24; } } else { +lean_object* x_25; lean_object* x_26; uint8_t x_49; +lean_dec(x_2); +x_25 = lean_ctor_get(x_17, 4); +lean_inc(x_25); +lean_dec(x_17); +x_49 = l_Lean_Expr_hasExprMVar(x_25); +if (x_49 == 0) +{ +uint8_t x_50; +x_50 = l_Lean_Expr_hasFVar(x_25); +if (x_50 == 0) +{ lean_object* x_51; -x_51 = lean_box(0); -x_24 = x_51; -goto block_46; -} -block_46: -{ -lean_object* x_25; lean_object* x_26; -lean_dec(x_24); -x_25 = l_Lean_Meta_CheckAssignment_findCached(x_23, x_3, x_4); -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -if (lean_obj_tag(x_26) == 0) -{ -lean_object* x_27; lean_object* x_28; -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -lean_inc(x_3); -lean_inc(x_23); -x_28 = lean_apply_3(x_1, x_23, x_3, x_27); -if (lean_obj_tag(x_28) == 0) -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_28, 1); -lean_inc(x_30); -lean_dec(x_28); -lean_inc(x_29); -x_31 = l_Lean_Meta_CheckAssignment_cache(x_23, x_29, x_3, x_30); -lean_dec(x_3); -x_32 = !lean_is_exclusive(x_31); -if (x_32 == 0) -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_31, 0); -lean_dec(x_33); -lean_ctor_set(x_31, 0, x_29); -return x_31; -} -else -{ -lean_object* x_34; lean_object* x_35; -x_34 = lean_ctor_get(x_31, 1); -lean_inc(x_34); -lean_dec(x_31); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_29); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -else -{ -uint8_t x_36; -lean_dec(x_23); -lean_dec(x_3); -x_36 = !lean_is_exclusive(x_28); -if (x_36 == 0) -{ -return x_28; -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_37 = lean_ctor_get(x_28, 0); -x_38 = lean_ctor_get(x_28, 1); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_28); -x_39 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_39, 0, x_37); -lean_ctor_set(x_39, 1, x_38); -return x_39; -} -} -} -else -{ -uint8_t x_40; -lean_dec(x_23); lean_dec(x_3); lean_dec(x_1); -x_40 = !lean_is_exclusive(x_25); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_25, 0); -lean_dec(x_41); -x_42 = lean_ctor_get(x_26, 0); -lean_inc(x_42); -lean_dec(x_26); -lean_ctor_set(x_25, 0, x_42); -return x_25; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_25, 1); -lean_inc(x_43); -lean_dec(x_25); -x_44 = lean_ctor_get(x_26, 0); -lean_inc(x_44); -lean_dec(x_26); -x_45 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_45, 0, x_44); -lean_ctor_set(x_45, 1, x_43); -return x_45; -} -} -} -} -} +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_25); +lean_ctor_set(x_51, 1, x_4); +return x_51; } else { lean_object* x_52; +x_52 = lean_box(0); +x_26 = x_52; +goto block_48; +} +} +else +{ +lean_object* x_53; +x_53 = lean_box(0); +x_26 = x_53; +goto block_48; +} +block_48: +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_26); +x_27 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_25, x_3, x_4); +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; +x_29 = lean_ctor_get(x_27, 1); +lean_inc(x_29); +lean_dec(x_27); +lean_inc(x_3); +lean_inc(x_25); +x_30 = lean_apply_3(x_1, x_25, x_3, x_29); +if (lean_obj_tag(x_30) == 0) +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +x_31 = lean_ctor_get(x_30, 0); +lean_inc(x_31); +x_32 = lean_ctor_get(x_30, 1); +lean_inc(x_32); +lean_dec(x_30); +lean_inc(x_31); +x_33 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_25, x_31, x_3, x_32); +lean_dec(x_3); +x_34 = !lean_is_exclusive(x_33); +if (x_34 == 0) +{ +lean_object* x_35; +x_35 = lean_ctor_get(x_33, 0); +lean_dec(x_35); +lean_ctor_set(x_33, 0, x_31); +return x_33; +} +else +{ +lean_object* x_36; lean_object* x_37; +x_36 = lean_ctor_get(x_33, 1); +lean_inc(x_36); +lean_dec(x_33); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_31); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +else +{ +uint8_t x_38; +lean_dec(x_25); +lean_dec(x_3); +x_38 = !lean_is_exclusive(x_30); +if (x_38 == 0) +{ +return x_30; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_30, 0); +x_40 = lean_ctor_get(x_30, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_30); +x_41 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_41, 0, x_39); +lean_ctor_set(x_41, 1, x_40); +return x_41; +} +} +} +else +{ +uint8_t x_42; +lean_dec(x_25); lean_dec(x_3); lean_dec(x_1); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_2); -lean_ctor_set(x_52, 1, x_4); -return x_52; -} -} -} -lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_checkFVar___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: +x_42 = !lean_is_exclusive(x_27); +if (x_42 == 0) { -uint8_t x_6; lean_object* x_7; -x_6 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_checkFVar___spec__2(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_4); +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_27, 0); +lean_dec(x_43); +x_44 = lean_ctor_get(x_28, 0); +lean_inc(x_44); +lean_dec(x_28); +lean_ctor_set(x_27, 0, x_44); +return x_27; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_27, 1); +lean_inc(x_45); +lean_dec(x_27); +x_46 = lean_ctor_get(x_28, 0); +lean_inc(x_46); +lean_dec(x_28); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_46); +lean_ctor_set(x_47, 1, x_45); +return x_47; +} +} +} +} +} +} +else +{ +lean_object* x_54; lean_dec(x_3); -lean_dec(x_2); lean_dec(x_1); -x_7 = lean_box(x_6); -return x_7; +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_2); +lean_ctor_set(x_54, 1, x_4); +return x_54; } } -lean_object* l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1___boxed(lean_object* x_1, lean_object* x_2) { -_start: -{ -uint8_t x_3; lean_object* x_4; -x_3 = l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(x_1, x_2); -lean_dec(x_2); -lean_dec(x_1); -x_4 = lean_box(x_3); -return x_4; -} } lean_object* l_Lean_Meta_CheckAssignment_getMCtx___rarg(lean_object* x_1) { _start: @@ -4078,7 +4556,7 @@ block_86: { lean_object* x_65; lean_object* x_66; lean_dec(x_64); -x_65 = l_Lean_Meta_CheckAssignment_findCached(x_63, x_3, x_4); +x_65 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_63, x_3, x_4); x_66 = lean_ctor_get(x_65, 0); lean_inc(x_66); if (lean_obj_tag(x_66) == 0) @@ -4099,7 +4577,7 @@ x_70 = lean_ctor_get(x_68, 1); lean_inc(x_70); lean_dec(x_68); lean_inc(x_69); -x_71 = l_Lean_Meta_CheckAssignment_cache(x_63, x_69, x_3, x_70); +x_71 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_63, x_69, x_3, x_70); lean_dec(x_3); x_72 = !lean_is_exclusive(x_71); if (x_72 == 0) @@ -4184,11 +4662,736 @@ return x_85; } } } +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_check___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_fget(x_3, x_5); +x_9 = lean_expr_eqv(x_2, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_5, x_10); +lean_dec(x_5); +x_5 = x_11; +goto _start; +} +else +{ +lean_dec(x_5); +return x_9; +} +} +} +} +uint8_t l_Array_contains___at_Lean_Meta_CheckAssignment_check___main___spec__2(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; uint8_t x_5; +x_3 = lean_array_get_size(x_1); +x_4 = lean_unsigned_to_nat(0u); +x_5 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_check___main___spec__3(x_1, x_2, x_1, x_3, x_4); +lean_dec(x_3); +return x_5; +} +} +lean_object* l_Lean_Meta_CheckAssignment_checkFVar___at_Lean_Meta_CheckAssignment_check___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; uint8_t x_6; +x_4 = lean_ctor_get(x_2, 2); +lean_inc(x_4); +x_5 = lean_ctor_get(x_4, 1); +lean_inc(x_5); +lean_dec(x_4); +x_6 = l_Lean_LocalContext_containsFVar(x_5, x_1); +lean_dec(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; +x_7 = lean_ctor_get(x_2, 0); +lean_inc(x_7); +x_8 = l_Lean_LocalContext_findFVar(x_7, x_1); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_2, 3); +lean_inc(x_9); +lean_dec(x_2); +x_10 = l_Array_contains___at_Lean_Meta_CheckAssignment_check___main___spec__2(x_9, x_1); +lean_dec(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = l_Lean_Expr_fvarId_x21(x_1); +lean_dec(x_1); +x_12 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_12, 0, x_11); +x_13 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_3); +return x_13; +} +else +{ +lean_object* x_14; +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_1); +lean_ctor_set(x_14, 1, x_3); +return x_14; +} +} +else +{ +lean_object* x_15; +x_15 = lean_ctor_get(x_8, 0); +lean_inc(x_15); +lean_dec(x_8); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; uint8_t x_17; +lean_dec(x_15); +x_16 = lean_ctor_get(x_2, 3); +lean_inc(x_16); +lean_dec(x_2); +x_17 = l_Array_contains___at_Lean_Meta_CheckAssignment_check___main___spec__2(x_16, x_1); +lean_dec(x_16); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = l_Lean_Expr_fvarId_x21(x_1); +lean_dec(x_1); +x_19 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_19, 0, x_18); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_3); +return x_20; +} +else +{ +lean_object* x_21; +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_1); +lean_ctor_set(x_21, 1, x_3); +return x_21; +} +} +else +{ +lean_object* x_22; lean_object* x_23; uint8_t x_46; +lean_dec(x_1); +x_22 = lean_ctor_get(x_15, 4); +lean_inc(x_22); +lean_dec(x_15); +x_46 = l_Lean_Expr_hasExprMVar(x_22); +if (x_46 == 0) +{ +uint8_t x_47; +x_47 = l_Lean_Expr_hasFVar(x_22); +if (x_47 == 0) +{ +lean_object* x_48; +lean_dec(x_2); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_22); +lean_ctor_set(x_48, 1, x_3); +return x_48; +} +else +{ +lean_object* x_49; +x_49 = lean_box(0); +x_23 = x_49; +goto block_45; +} +} +else +{ +lean_object* x_50; +x_50 = lean_box(0); +x_23 = x_50; +goto block_45; +} +block_45: +{ +lean_object* x_24; lean_object* x_25; +lean_dec(x_23); +x_24 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_22, x_2, x_3); +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +if (lean_obj_tag(x_25) == 0) +{ +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +lean_inc(x_2); +lean_inc(x_22); +x_27 = l_Lean_Meta_CheckAssignment_check___main(x_22, x_2, x_26); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +x_29 = lean_ctor_get(x_27, 1); +lean_inc(x_29); +lean_dec(x_27); +lean_inc(x_28); +x_30 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_22, x_28, x_2, x_29); +lean_dec(x_2); +x_31 = !lean_is_exclusive(x_30); +if (x_31 == 0) +{ +lean_object* x_32; +x_32 = lean_ctor_get(x_30, 0); +lean_dec(x_32); +lean_ctor_set(x_30, 0, x_28); +return x_30; +} +else +{ +lean_object* x_33; lean_object* x_34; +x_33 = lean_ctor_get(x_30, 1); +lean_inc(x_33); +lean_dec(x_30); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_28); +lean_ctor_set(x_34, 1, x_33); +return x_34; +} +} +else +{ +uint8_t x_35; +lean_dec(x_22); +lean_dec(x_2); +x_35 = !lean_is_exclusive(x_27); +if (x_35 == 0) +{ +return x_27; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_27, 0); +x_37 = lean_ctor_get(x_27, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_27); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +} +else +{ +uint8_t x_39; +lean_dec(x_22); +lean_dec(x_2); +x_39 = !lean_is_exclusive(x_24); +if (x_39 == 0) +{ +lean_object* x_40; lean_object* x_41; +x_40 = lean_ctor_get(x_24, 0); +lean_dec(x_40); +x_41 = lean_ctor_get(x_25, 0); +lean_inc(x_41); +lean_dec(x_25); +lean_ctor_set(x_24, 0, x_41); +return x_24; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_24, 1); +lean_inc(x_42); +lean_dec(x_24); +x_43 = lean_ctor_get(x_25, 0); +lean_inc(x_43); +lean_dec(x_25); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_42); +return x_44; +} +} +} +} +} +} +else +{ +lean_object* x_51; +lean_dec(x_2); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_1); +lean_ctor_set(x_51, 1, x_3); +return x_51; +} +} +} +lean_object* l_Lean_Meta_CheckAssignment_checkMVar___at_Lean_Meta_CheckAssignment_check___main___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; +x_4 = l_Lean_Expr_mvarId_x21(x_1); +x_5 = lean_ctor_get(x_3, 0); +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_5); +x_6 = lean_metavar_ctx_get_expr_assignment(x_5, x_4); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_ctor_get(x_2, 1); +lean_inc(x_7); +x_8 = lean_name_eq(x_4, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; +lean_inc(x_4); +lean_inc(x_5); +x_9 = lean_metavar_ctx_find_decl(x_5, x_4); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_10 = lean_alloc_ctor(5, 1, 0); +lean_ctor_set(x_10, 0, x_4); +x_11 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_3); +return x_11; +} +else +{ +uint8_t x_12; +x_12 = lean_ctor_get_uint8(x_2, sizeof(void*)*4 + 1); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; +x_13 = lean_ctor_get(x_9, 0); +lean_inc(x_13); +lean_dec(x_9); +x_14 = lean_ctor_get(x_13, 1); +lean_inc(x_14); +x_15 = lean_ctor_get(x_2, 2); +lean_inc(x_15); +x_16 = lean_ctor_get(x_15, 1); +lean_inc(x_16); +lean_dec(x_15); +lean_inc(x_16); +lean_inc(x_14); +x_17 = l_Lean_LocalContext_isSubPrefixOf(x_14, x_16); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; uint8_t x_20; +x_18 = lean_ctor_get(x_13, 3); +lean_inc(x_18); +x_19 = lean_ctor_get(x_5, 0); +lean_inc(x_19); +x_20 = lean_nat_dec_eq(x_18, x_19); +lean_dec(x_19); +lean_dec(x_18); +if (x_20 == 0) +{ +lean_object* x_21; lean_object* x_22; +lean_dec(x_16); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_21 = lean_alloc_ctor(3, 1, 0); +lean_ctor_set(x_21, 0, x_4); +x_22 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_3); +return x_22; +} +else +{ +uint8_t x_23; +x_23 = lean_ctor_get_uint8(x_13, sizeof(void*)*4); +if (x_23 == 0) +{ +uint8_t x_24; +x_24 = lean_ctor_get_uint8(x_2, sizeof(void*)*4); +if (x_24 == 0) +{ +lean_object* x_25; +lean_dec(x_16); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_25 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_25, 0, x_1); +lean_ctor_set(x_25, 1, x_3); +return x_25; +} +else +{ +uint8_t x_26; +lean_inc(x_16); +x_26 = l_Lean_LocalContext_isSubPrefixOf(x_16, x_14); +if (x_26 == 0) +{ +lean_object* x_27; +lean_dec(x_16); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_1); +lean_ctor_set(x_27, 1, x_3); +return x_27; +} +else +{ +lean_object* x_28; lean_object* x_29; uint8_t x_30; +lean_dec(x_1); +x_28 = lean_ctor_get(x_13, 2); +lean_inc(x_28); +lean_dec(x_13); +lean_inc(x_28); +lean_inc(x_16); +x_29 = l_Lean_MetavarContext_isWellFormed___main(x_5, x_16, x_28); +x_30 = lean_unbox(x_29); +lean_dec(x_29); +if (x_30 == 0) +{ +lean_object* x_31; lean_object* x_32; +lean_dec(x_28); +lean_dec(x_16); +lean_dec(x_2); +x_31 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_31, 0, x_4); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_31); +lean_ctor_set(x_32, 1, x_3); +return x_32; +} +else +{ +lean_object* x_33; uint8_t x_34; +x_33 = l_Lean_Meta_CheckAssignment_mkAuxMVar(x_16, x_28, x_2, x_3); +lean_dec(x_2); +x_34 = !lean_is_exclusive(x_33); +if (x_34 == 0) +{ +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_33, 1); +x_36 = !lean_is_exclusive(x_35); +if (x_36 == 0) +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_37 = lean_ctor_get(x_33, 0); +x_38 = lean_ctor_get(x_35, 0); +lean_inc(x_37); +x_39 = lean_metavar_ctx_assign_expr(x_38, x_4, x_37); +lean_ctor_set(x_35, 0, x_39); +return x_33; +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_40 = lean_ctor_get(x_33, 0); +x_41 = lean_ctor_get(x_35, 0); +x_42 = lean_ctor_get(x_35, 1); +x_43 = lean_ctor_get(x_35, 2); +lean_inc(x_43); +lean_inc(x_42); +lean_inc(x_41); +lean_dec(x_35); +lean_inc(x_40); +x_44 = lean_metavar_ctx_assign_expr(x_41, x_4, x_40); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_44); +lean_ctor_set(x_45, 1, x_42); +lean_ctor_set(x_45, 2, x_43); +lean_ctor_set(x_33, 1, x_45); +return x_33; +} +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_46 = lean_ctor_get(x_33, 1); +x_47 = lean_ctor_get(x_33, 0); +lean_inc(x_46); +lean_inc(x_47); +lean_dec(x_33); +x_48 = lean_ctor_get(x_46, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_46, 1); +lean_inc(x_49); +x_50 = lean_ctor_get(x_46, 2); +lean_inc(x_50); +if (lean_is_exclusive(x_46)) { + lean_ctor_release(x_46, 0); + lean_ctor_release(x_46, 1); + lean_ctor_release(x_46, 2); + x_51 = x_46; +} else { + lean_dec_ref(x_46); + x_51 = lean_box(0); +} +lean_inc(x_47); +x_52 = lean_metavar_ctx_assign_expr(x_48, x_4, x_47); +if (lean_is_scalar(x_51)) { + x_53 = lean_alloc_ctor(0, 3, 0); +} else { + x_53 = x_51; +} +lean_ctor_set(x_53, 0, x_52); +lean_ctor_set(x_53, 1, x_49); +lean_ctor_set(x_53, 2, x_50); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_47); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} +} +} +else +{ +lean_object* x_55; lean_object* x_56; +lean_dec(x_16); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_2); +lean_dec(x_1); +x_55 = lean_alloc_ctor(3, 1, 0); +lean_ctor_set(x_55, 0, x_4); +x_56 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_56, 0, x_55); +lean_ctor_set(x_56, 1, x_3); +return x_56; +} +} +} +else +{ +lean_object* x_57; +lean_dec(x_16); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_1); +lean_ctor_set(x_57, 1, x_3); +return x_57; +} +} +else +{ +lean_object* x_58; lean_object* x_59; +lean_dec(x_9); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_58 = lean_box(1); +x_59 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_59, 0, x_58); +lean_ctor_set(x_59, 1, x_3); +return x_59; +} +} +} +else +{ +lean_object* x_60; lean_object* x_61; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_60 = lean_box(0); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_60); +lean_ctor_set(x_61, 1, x_3); +return x_61; +} +} +else +{ +lean_object* x_62; lean_object* x_63; uint8_t x_86; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_62 = lean_ctor_get(x_6, 0); +lean_inc(x_62); +lean_dec(x_6); +x_86 = l_Lean_Expr_hasExprMVar(x_62); +if (x_86 == 0) +{ +uint8_t x_87; +x_87 = l_Lean_Expr_hasFVar(x_62); +if (x_87 == 0) +{ +lean_object* x_88; +lean_dec(x_2); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_62); +lean_ctor_set(x_88, 1, x_3); +return x_88; +} +else +{ +lean_object* x_89; +x_89 = lean_box(0); +x_63 = x_89; +goto block_85; +} +} +else +{ +lean_object* x_90; +x_90 = lean_box(0); +x_63 = x_90; +goto block_85; +} +block_85: +{ +lean_object* x_64; lean_object* x_65; +lean_dec(x_63); +x_64 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_62, x_2, x_3); +x_65 = lean_ctor_get(x_64, 0); +lean_inc(x_65); +if (lean_obj_tag(x_65) == 0) +{ +lean_object* x_66; lean_object* x_67; +x_66 = lean_ctor_get(x_64, 1); +lean_inc(x_66); +lean_dec(x_64); +lean_inc(x_2); +lean_inc(x_62); +x_67 = l_Lean_Meta_CheckAssignment_check___main(x_62, x_2, x_66); +if (lean_obj_tag(x_67) == 0) +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; uint8_t x_71; +x_68 = lean_ctor_get(x_67, 0); +lean_inc(x_68); +x_69 = lean_ctor_get(x_67, 1); +lean_inc(x_69); +lean_dec(x_67); +lean_inc(x_68); +x_70 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_62, x_68, x_2, x_69); +lean_dec(x_2); +x_71 = !lean_is_exclusive(x_70); +if (x_71 == 0) +{ +lean_object* x_72; +x_72 = lean_ctor_get(x_70, 0); +lean_dec(x_72); +lean_ctor_set(x_70, 0, x_68); +return x_70; +} +else +{ +lean_object* x_73; lean_object* x_74; +x_73 = lean_ctor_get(x_70, 1); +lean_inc(x_73); +lean_dec(x_70); +x_74 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_74, 0, x_68); +lean_ctor_set(x_74, 1, x_73); +return x_74; +} +} +else +{ +uint8_t x_75; +lean_dec(x_62); +lean_dec(x_2); +x_75 = !lean_is_exclusive(x_67); +if (x_75 == 0) +{ +return x_67; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_67, 0); +x_77 = lean_ctor_get(x_67, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_67); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +else +{ +uint8_t x_79; +lean_dec(x_62); +lean_dec(x_2); +x_79 = !lean_is_exclusive(x_64); +if (x_79 == 0) +{ +lean_object* x_80; lean_object* x_81; +x_80 = lean_ctor_get(x_64, 0); +lean_dec(x_80); +x_81 = lean_ctor_get(x_65, 0); +lean_inc(x_81); +lean_dec(x_65); +lean_ctor_set(x_64, 0, x_81); +return x_64; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_64, 1); +lean_inc(x_82); +lean_dec(x_64); +x_83 = lean_ctor_get(x_65, 0); +lean_inc(x_83); +lean_dec(x_65); +x_84 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_82); +return x_84; +} +} +} +} +} +} lean_object* _init_l_Lean_Meta_CheckAssignment_check___main___closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; +x_1 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; x_2 = l_Lean_Expr_Inhabited; x_3 = l_monadInhabited___rarg(x_1, x_2); return x_3; @@ -4197,2688 +5400,1686 @@ return x_3; lean_object* l_Lean_Meta_CheckAssignment_check___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_4; lean_object* x_5; lean_object* x_12; lean_object* x_13; lean_object* x_21; lean_object* x_22; +lean_object* x_4; lean_object* x_5; lean_object* x_13; lean_object* x_14; switch (lean_obj_tag(x_1)) { case 1: { -lean_object* x_30; uint8_t x_116; -x_116 = l_Lean_Expr_hasExprMVar(x_1); -if (x_116 == 0) +lean_object* x_22; uint8_t x_45; +x_45 = l_Lean_Expr_hasExprMVar(x_1); +if (x_45 == 0) { -uint8_t x_117; -x_117 = l_Lean_Expr_hasFVar(x_1); -if (x_117 == 0) +uint8_t x_46; +x_46 = l_Lean_Expr_hasFVar(x_1); +if (x_46 == 0) { -lean_object* x_118; +lean_object* x_47; lean_dec(x_2); -x_118 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_118, 0, x_1); -lean_ctor_set(x_118, 1, x_3); -return x_118; +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_1); +lean_ctor_set(x_47, 1, x_3); +return x_47; } else { -lean_object* x_119; -x_119 = lean_box(0); -x_30 = x_119; -goto block_115; +lean_object* x_48; +x_48 = lean_box(0); +x_22 = x_48; +goto block_44; } } else { -lean_object* x_120; -x_120 = lean_box(0); -x_30 = x_120; -goto block_115; +lean_object* x_49; +x_49 = lean_box(0); +x_22 = x_49; +goto block_44; } -block_115: +block_44: { -lean_object* x_31; lean_object* x_32; -lean_dec(x_30); -x_31 = l_Lean_Meta_CheckAssignment_findCached(x_1, x_2, x_3); -x_32 = lean_ctor_get(x_31, 0); +lean_object* x_23; lean_object* x_24; +lean_dec(x_22); +x_23 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_1, x_2, x_3); +x_24 = lean_ctor_get(x_23, 0); +lean_inc(x_24); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_23, 1); +lean_inc(x_25); +lean_dec(x_23); +lean_inc(x_2); +lean_inc(x_1); +x_26 = l_Lean_Meta_CheckAssignment_checkFVar___at_Lean_Meta_CheckAssignment_check___main___spec__1(x_1, x_2, x_25); +if (lean_obj_tag(x_26) == 0) +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; uint8_t x_30; +x_27 = lean_ctor_get(x_26, 0); +lean_inc(x_27); +x_28 = lean_ctor_get(x_26, 1); +lean_inc(x_28); +lean_dec(x_26); +lean_inc(x_27); +x_29 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_1, x_27, x_2, x_28); +lean_dec(x_2); +x_30 = !lean_is_exclusive(x_29); +if (x_30 == 0) +{ +lean_object* x_31; +x_31 = lean_ctor_get(x_29, 0); +lean_dec(x_31); +lean_ctor_set(x_29, 0, x_27); +return x_29; +} +else +{ +lean_object* x_32; lean_object* x_33; +x_32 = lean_ctor_get(x_29, 1); lean_inc(x_32); -if (lean_obj_tag(x_32) == 0) +lean_dec(x_29); +x_33 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_33, 0, x_27); +lean_ctor_set(x_33, 1, x_32); +return x_33; +} +} +else { -uint8_t x_33; -x_33 = !lean_is_exclusive(x_31); -if (x_33 == 0) +uint8_t x_34; +lean_dec(x_2); +lean_dec(x_1); +x_34 = !lean_is_exclusive(x_26); +if (x_34 == 0) { -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; -x_34 = lean_ctor_get(x_31, 1); -x_35 = lean_ctor_get(x_31, 0); -lean_dec(x_35); -x_36 = lean_ctor_get(x_2, 2); +return x_26; +} +else +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_26, 0); +x_36 = lean_ctor_get(x_26, 1); lean_inc(x_36); -x_37 = lean_ctor_get(x_36, 1); -lean_inc(x_37); -lean_dec(x_36); -x_38 = l_Lean_LocalContext_containsFVar(x_37, x_1); -lean_dec(x_37); +lean_inc(x_35); +lean_dec(x_26); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_35); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +} +else +{ +uint8_t x_38; +lean_dec(x_2); +lean_dec(x_1); +x_38 = !lean_is_exclusive(x_23); if (x_38 == 0) { lean_object* x_39; lean_object* x_40; -x_39 = lean_ctor_get(x_2, 0); -lean_inc(x_39); -x_40 = l_Lean_LocalContext_findFVar(x_39, x_1); -if (lean_obj_tag(x_40) == 0) +x_39 = lean_ctor_get(x_23, 0); +lean_dec(x_39); +x_40 = lean_ctor_get(x_24, 0); +lean_inc(x_40); +lean_dec(x_24); +lean_ctor_set(x_23, 0, x_40); +return x_23; +} +else { -lean_object* x_41; uint8_t x_42; -x_41 = lean_ctor_get(x_2, 3); +lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_41 = lean_ctor_get(x_23, 1); lean_inc(x_41); -x_42 = l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(x_41, x_1); -lean_dec(x_41); -if (x_42 == 0) -{ -lean_object* x_43; lean_object* x_44; -lean_dec(x_2); -x_43 = l_Lean_Expr_fvarId_x21(x_1); -lean_dec(x_1); -x_44 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_44, 0, x_43); -lean_ctor_set_tag(x_31, 1); -lean_ctor_set(x_31, 0, x_44); -return x_31; -} -else -{ -lean_free_object(x_31); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_34; -goto block_11; -} -} -else -{ -lean_object* x_45; -x_45 = lean_ctor_get(x_40, 0); -lean_inc(x_45); -lean_dec(x_40); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; uint8_t x_47; -lean_dec(x_45); -x_46 = lean_ctor_get(x_2, 3); -lean_inc(x_46); -x_47 = l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(x_46, x_1); -lean_dec(x_46); -if (x_47 == 0) -{ -lean_object* x_48; lean_object* x_49; -lean_dec(x_2); -x_48 = l_Lean_Expr_fvarId_x21(x_1); -lean_dec(x_1); -x_49 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set_tag(x_31, 1); -lean_ctor_set(x_31, 0, x_49); -return x_31; -} -else -{ -lean_free_object(x_31); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_34; -goto block_11; -} -} -else -{ -lean_object* x_50; lean_object* x_51; uint8_t x_67; -lean_free_object(x_31); -x_50 = lean_ctor_get(x_45, 4); -lean_inc(x_50); -lean_dec(x_45); -x_67 = l_Lean_Expr_hasExprMVar(x_50); -if (x_67 == 0) -{ -uint8_t x_68; -x_68 = l_Lean_Expr_hasFVar(x_50); -if (x_68 == 0) -{ -x_4 = x_50; -x_5 = x_34; -goto block_11; -} -else -{ -lean_object* x_69; -x_69 = lean_box(0); -x_51 = x_69; -goto block_66; -} -} -else -{ -lean_object* x_70; -x_70 = lean_box(0); -x_51 = x_70; -goto block_66; -} -block_66: -{ -lean_object* x_52; lean_object* x_53; -lean_dec(x_51); -x_52 = l_Lean_Meta_CheckAssignment_findCached(x_50, x_2, x_34); -x_53 = lean_ctor_get(x_52, 0); -lean_inc(x_53); -if (lean_obj_tag(x_53) == 0) -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_52, 1); -lean_inc(x_54); -lean_dec(x_52); -lean_inc(x_2); -lean_inc(x_50); -x_55 = l_Lean_Meta_CheckAssignment_check___main(x_50, x_2, x_54); -if (lean_obj_tag(x_55) == 0) -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_56 = lean_ctor_get(x_55, 0); -lean_inc(x_56); -x_57 = lean_ctor_get(x_55, 1); -lean_inc(x_57); -lean_dec(x_55); -lean_inc(x_56); -x_58 = l_Lean_Meta_CheckAssignment_cache(x_50, x_56, x_2, x_57); -x_59 = lean_ctor_get(x_58, 1); -lean_inc(x_59); -lean_dec(x_58); -x_4 = x_56; -x_5 = x_59; -goto block_11; -} -else -{ -uint8_t x_60; -lean_dec(x_50); -lean_dec(x_2); -lean_dec(x_1); -x_60 = !lean_is_exclusive(x_55); -if (x_60 == 0) -{ -return x_55; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_55, 0); -x_62 = lean_ctor_get(x_55, 1); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_55); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_61); -lean_ctor_set(x_63, 1, x_62); -return x_63; -} -} -} -else -{ -lean_object* x_64; lean_object* x_65; -lean_dec(x_50); -x_64 = lean_ctor_get(x_52, 1); -lean_inc(x_64); -lean_dec(x_52); -x_65 = lean_ctor_get(x_53, 0); -lean_inc(x_65); -lean_dec(x_53); -x_4 = x_65; -x_5 = x_64; -goto block_11; -} -} -} -} -} -else -{ -lean_free_object(x_31); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_34; -goto block_11; -} -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; uint8_t x_74; -x_71 = lean_ctor_get(x_31, 1); -lean_inc(x_71); -lean_dec(x_31); -x_72 = lean_ctor_get(x_2, 2); -lean_inc(x_72); -x_73 = lean_ctor_get(x_72, 1); -lean_inc(x_73); -lean_dec(x_72); -x_74 = l_Lean_LocalContext_containsFVar(x_73, x_1); -lean_dec(x_73); -if (x_74 == 0) -{ -lean_object* x_75; lean_object* x_76; -x_75 = lean_ctor_get(x_2, 0); -lean_inc(x_75); -x_76 = l_Lean_LocalContext_findFVar(x_75, x_1); -if (lean_obj_tag(x_76) == 0) -{ -lean_object* x_77; uint8_t x_78; -x_77 = lean_ctor_get(x_2, 3); -lean_inc(x_77); -x_78 = l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(x_77, x_1); -lean_dec(x_77); -if (x_78 == 0) -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -lean_dec(x_2); -x_79 = l_Lean_Expr_fvarId_x21(x_1); -lean_dec(x_1); -x_80 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_80, 0, x_79); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_71); -return x_81; -} -else -{ -lean_inc(x_1); -x_4 = x_1; -x_5 = x_71; -goto block_11; -} -} -else -{ -lean_object* x_82; -x_82 = lean_ctor_get(x_76, 0); -lean_inc(x_82); -lean_dec(x_76); -if (lean_obj_tag(x_82) == 0) -{ -lean_object* x_83; uint8_t x_84; -lean_dec(x_82); -x_83 = lean_ctor_get(x_2, 3); -lean_inc(x_83); -x_84 = l_Array_contains___at_Lean_Meta_CheckAssignment_checkFVar___spec__1(x_83, x_1); -lean_dec(x_83); -if (x_84 == 0) -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; -lean_dec(x_2); -x_85 = l_Lean_Expr_fvarId_x21(x_1); -lean_dec(x_1); -x_86 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_86, 0, x_85); -x_87 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_87, 0, x_86); -lean_ctor_set(x_87, 1, x_71); -return x_87; -} -else -{ -lean_inc(x_1); -x_4 = x_1; -x_5 = x_71; -goto block_11; -} -} -else -{ -lean_object* x_88; lean_object* x_89; uint8_t x_105; -x_88 = lean_ctor_get(x_82, 4); -lean_inc(x_88); -lean_dec(x_82); -x_105 = l_Lean_Expr_hasExprMVar(x_88); -if (x_105 == 0) -{ -uint8_t x_106; -x_106 = l_Lean_Expr_hasFVar(x_88); -if (x_106 == 0) -{ -x_4 = x_88; -x_5 = x_71; -goto block_11; -} -else -{ -lean_object* x_107; -x_107 = lean_box(0); -x_89 = x_107; -goto block_104; -} -} -else -{ -lean_object* x_108; -x_108 = lean_box(0); -x_89 = x_108; -goto block_104; -} -block_104: -{ -lean_object* x_90; lean_object* x_91; -lean_dec(x_89); -x_90 = l_Lean_Meta_CheckAssignment_findCached(x_88, x_2, x_71); -x_91 = lean_ctor_get(x_90, 0); -lean_inc(x_91); -if (lean_obj_tag(x_91) == 0) -{ -lean_object* x_92; lean_object* x_93; -x_92 = lean_ctor_get(x_90, 1); -lean_inc(x_92); -lean_dec(x_90); -lean_inc(x_2); -lean_inc(x_88); -x_93 = l_Lean_Meta_CheckAssignment_check___main(x_88, x_2, x_92); -if (lean_obj_tag(x_93) == 0) -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_94 = lean_ctor_get(x_93, 0); -lean_inc(x_94); -x_95 = lean_ctor_get(x_93, 1); -lean_inc(x_95); -lean_dec(x_93); -lean_inc(x_94); -x_96 = l_Lean_Meta_CheckAssignment_cache(x_88, x_94, x_2, x_95); -x_97 = lean_ctor_get(x_96, 1); -lean_inc(x_97); -lean_dec(x_96); -x_4 = x_94; -x_5 = x_97; -goto block_11; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; -lean_dec(x_88); -lean_dec(x_2); -lean_dec(x_1); -x_98 = lean_ctor_get(x_93, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_93, 1); -lean_inc(x_99); -if (lean_is_exclusive(x_93)) { - lean_ctor_release(x_93, 0); - lean_ctor_release(x_93, 1); - x_100 = x_93; -} else { - lean_dec_ref(x_93); - x_100 = lean_box(0); -} -if (lean_is_scalar(x_100)) { - x_101 = lean_alloc_ctor(1, 2, 0); -} else { - x_101 = x_100; -} -lean_ctor_set(x_101, 0, x_98); -lean_ctor_set(x_101, 1, x_99); -return x_101; -} -} -else -{ -lean_object* x_102; lean_object* x_103; -lean_dec(x_88); -x_102 = lean_ctor_get(x_90, 1); -lean_inc(x_102); -lean_dec(x_90); -x_103 = lean_ctor_get(x_91, 0); -lean_inc(x_103); -lean_dec(x_91); -x_4 = x_103; -x_5 = x_102; -goto block_11; -} -} -} -} -} -else -{ -lean_inc(x_1); -x_4 = x_1; -x_5 = x_71; -goto block_11; -} -} -} -else -{ -uint8_t x_109; -lean_dec(x_2); -lean_dec(x_1); -x_109 = !lean_is_exclusive(x_31); -if (x_109 == 0) -{ -lean_object* x_110; lean_object* x_111; -x_110 = lean_ctor_get(x_31, 0); -lean_dec(x_110); -x_111 = lean_ctor_get(x_32, 0); -lean_inc(x_111); -lean_dec(x_32); -lean_ctor_set(x_31, 0, x_111); -return x_31; -} -else -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -x_112 = lean_ctor_get(x_31, 1); -lean_inc(x_112); -lean_dec(x_31); -x_113 = lean_ctor_get(x_32, 0); -lean_inc(x_113); -lean_dec(x_32); -x_114 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_112); -return x_114; +lean_dec(x_23); +x_42 = lean_ctor_get(x_24, 0); +lean_inc(x_42); +lean_dec(x_24); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_42); +lean_ctor_set(x_43, 1, x_41); +return x_43; } } } } case 2: { -lean_object* x_121; uint8_t x_257; -x_257 = l_Lean_Expr_hasExprMVar(x_1); -if (x_257 == 0) +lean_object* x_50; uint8_t x_73; +x_73 = l_Lean_Expr_hasExprMVar(x_1); +if (x_73 == 0) { -uint8_t x_258; -x_258 = l_Lean_Expr_hasFVar(x_1); -if (x_258 == 0) +uint8_t x_74; +x_74 = l_Lean_Expr_hasFVar(x_1); +if (x_74 == 0) { -lean_object* x_259; +lean_object* x_75; lean_dec(x_2); -x_259 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_259, 0, x_1); -lean_ctor_set(x_259, 1, x_3); -return x_259; +x_75 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_75, 0, x_1); +lean_ctor_set(x_75, 1, x_3); +return x_75; } else { -lean_object* x_260; -x_260 = lean_box(0); -x_121 = x_260; -goto block_256; +lean_object* x_76; +x_76 = lean_box(0); +x_50 = x_76; +goto block_72; } } else { -lean_object* x_261; -x_261 = lean_box(0); -x_121 = x_261; -goto block_256; +lean_object* x_77; +x_77 = lean_box(0); +x_50 = x_77; +goto block_72; } -block_256: +block_72: { -lean_object* x_122; lean_object* x_123; -lean_dec(x_121); -x_122 = l_Lean_Meta_CheckAssignment_findCached(x_1, x_2, x_3); -x_123 = lean_ctor_get(x_122, 0); -lean_inc(x_123); -if (lean_obj_tag(x_123) == 0) +lean_object* x_51; lean_object* x_52; +lean_dec(x_50); +x_51 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_1, x_2, x_3); +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +if (lean_obj_tag(x_52) == 0) { -uint8_t x_124; -x_124 = !lean_is_exclusive(x_122); -if (x_124 == 0) -{ -lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; -x_125 = lean_ctor_get(x_122, 1); -x_126 = lean_ctor_get(x_122, 0); -lean_dec(x_126); -x_127 = l_Lean_Expr_mvarId_x21(x_1); -x_128 = lean_ctor_get(x_125, 0); -lean_inc(x_128); -lean_inc(x_127); -lean_inc(x_128); -x_129 = lean_metavar_ctx_get_expr_assignment(x_128, x_127); -if (lean_obj_tag(x_129) == 0) -{ -lean_object* x_130; uint8_t x_131; -x_130 = lean_ctor_get(x_2, 1); -lean_inc(x_130); -x_131 = lean_name_eq(x_127, x_130); -lean_dec(x_130); -if (x_131 == 0) -{ -lean_object* x_132; -lean_inc(x_127); -lean_inc(x_128); -x_132 = lean_metavar_ctx_find_decl(x_128, x_127); -if (lean_obj_tag(x_132) == 0) -{ -lean_object* x_133; -lean_dec(x_128); -lean_dec(x_2); -lean_dec(x_1); -x_133 = lean_alloc_ctor(5, 1, 0); -lean_ctor_set(x_133, 0, x_127); -lean_ctor_set_tag(x_122, 1); -lean_ctor_set(x_122, 0, x_133); -return x_122; -} -else -{ -uint8_t x_134; -x_134 = lean_ctor_get_uint8(x_2, sizeof(void*)*4 + 1); -if (x_134 == 0) -{ -lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; uint8_t x_139; -x_135 = lean_ctor_get(x_132, 0); -lean_inc(x_135); -lean_dec(x_132); -x_136 = lean_ctor_get(x_135, 1); -lean_inc(x_136); -x_137 = lean_ctor_get(x_2, 2); -lean_inc(x_137); -x_138 = lean_ctor_get(x_137, 1); -lean_inc(x_138); -lean_dec(x_137); -lean_inc(x_138); -lean_inc(x_136); -x_139 = l_Lean_LocalContext_isSubPrefixOf(x_136, x_138); -if (x_139 == 0) -{ -lean_object* x_140; lean_object* x_141; uint8_t x_142; -x_140 = lean_ctor_get(x_135, 3); -lean_inc(x_140); -x_141 = lean_ctor_get(x_128, 0); -lean_inc(x_141); -x_142 = lean_nat_dec_eq(x_140, x_141); -lean_dec(x_141); -lean_dec(x_140); -if (x_142 == 0) -{ -lean_object* x_143; -lean_dec(x_138); -lean_dec(x_136); -lean_dec(x_135); -lean_dec(x_128); -lean_dec(x_2); -lean_dec(x_1); -x_143 = lean_alloc_ctor(3, 1, 0); -lean_ctor_set(x_143, 0, x_127); -lean_ctor_set_tag(x_122, 1); -lean_ctor_set(x_122, 0, x_143); -return x_122; -} -else -{ -uint8_t x_144; -x_144 = lean_ctor_get_uint8(x_135, sizeof(void*)*4); -if (x_144 == 0) -{ -uint8_t x_145; -x_145 = lean_ctor_get_uint8(x_2, sizeof(void*)*4); -if (x_145 == 0) -{ -lean_dec(x_138); -lean_dec(x_136); -lean_dec(x_135); -lean_dec(x_128); -lean_dec(x_127); -lean_free_object(x_122); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_125; -goto block_11; -} -else -{ -uint8_t x_146; -lean_inc(x_138); -x_146 = l_Lean_LocalContext_isSubPrefixOf(x_138, x_136); -if (x_146 == 0) -{ -lean_dec(x_138); -lean_dec(x_135); -lean_dec(x_128); -lean_dec(x_127); -lean_free_object(x_122); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_125; -goto block_11; -} -else -{ -lean_object* x_147; lean_object* x_148; uint8_t x_149; -x_147 = lean_ctor_get(x_135, 2); -lean_inc(x_147); -lean_dec(x_135); -lean_inc(x_147); -lean_inc(x_138); -x_148 = l_Lean_MetavarContext_isWellFormed___main(x_128, x_138, x_147); -x_149 = lean_unbox(x_148); -lean_dec(x_148); -if (x_149 == 0) -{ -lean_object* x_150; -lean_dec(x_147); -lean_dec(x_138); -lean_dec(x_2); -lean_dec(x_1); -x_150 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_150, 0, x_127); -lean_ctor_set_tag(x_122, 1); -lean_ctor_set(x_122, 0, x_150); -return x_122; -} -else -{ -lean_object* x_151; lean_object* x_152; lean_object* x_153; uint8_t x_154; -lean_free_object(x_122); -x_151 = l_Lean_Meta_CheckAssignment_mkAuxMVar(x_138, x_147, x_2, x_125); -x_152 = lean_ctor_get(x_151, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_151, 0); -lean_inc(x_153); -lean_dec(x_151); -x_154 = !lean_is_exclusive(x_152); -if (x_154 == 0) -{ -lean_object* x_155; lean_object* x_156; -x_155 = lean_ctor_get(x_152, 0); -lean_inc(x_153); -x_156 = lean_metavar_ctx_assign_expr(x_155, x_127, x_153); -lean_ctor_set(x_152, 0, x_156); -x_4 = x_153; -x_5 = x_152; -goto block_11; -} -else -{ -lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; -x_157 = lean_ctor_get(x_152, 0); -x_158 = lean_ctor_get(x_152, 1); -x_159 = lean_ctor_get(x_152, 2); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); -lean_dec(x_152); -lean_inc(x_153); -x_160 = lean_metavar_ctx_assign_expr(x_157, x_127, x_153); -x_161 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_161, 0, x_160); -lean_ctor_set(x_161, 1, x_158); -lean_ctor_set(x_161, 2, x_159); -x_4 = x_153; -x_5 = x_161; -goto block_11; -} -} -} -} -} -else -{ -lean_object* x_162; -lean_dec(x_138); -lean_dec(x_136); -lean_dec(x_135); -lean_dec(x_128); -lean_dec(x_2); -lean_dec(x_1); -x_162 = lean_alloc_ctor(3, 1, 0); -lean_ctor_set(x_162, 0, x_127); -lean_ctor_set_tag(x_122, 1); -lean_ctor_set(x_122, 0, x_162); -return x_122; -} -} -} -else -{ -lean_dec(x_138); -lean_dec(x_136); -lean_dec(x_135); -lean_dec(x_128); -lean_dec(x_127); -lean_free_object(x_122); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_125; -goto block_11; -} -} -else -{ -lean_object* x_163; -lean_dec(x_132); -lean_dec(x_128); -lean_dec(x_127); -lean_dec(x_2); -lean_dec(x_1); -x_163 = lean_box(1); -lean_ctor_set_tag(x_122, 1); -lean_ctor_set(x_122, 0, x_163); -return x_122; -} -} -} -else -{ -lean_object* x_164; -lean_dec(x_128); -lean_dec(x_127); -lean_dec(x_2); -lean_dec(x_1); -x_164 = lean_box(0); -lean_ctor_set_tag(x_122, 1); -lean_ctor_set(x_122, 0, x_164); -return x_122; -} -} -else -{ -lean_object* x_165; lean_object* x_166; uint8_t x_182; -lean_dec(x_128); -lean_dec(x_127); -lean_free_object(x_122); -x_165 = lean_ctor_get(x_129, 0); -lean_inc(x_165); -lean_dec(x_129); -x_182 = l_Lean_Expr_hasExprMVar(x_165); -if (x_182 == 0) -{ -uint8_t x_183; -x_183 = l_Lean_Expr_hasFVar(x_165); -if (x_183 == 0) -{ -x_4 = x_165; -x_5 = x_125; -goto block_11; -} -else -{ -lean_object* x_184; -x_184 = lean_box(0); -x_166 = x_184; -goto block_181; -} -} -else -{ -lean_object* x_185; -x_185 = lean_box(0); -x_166 = x_185; -goto block_181; -} -block_181: -{ -lean_object* x_167; lean_object* x_168; -lean_dec(x_166); -x_167 = l_Lean_Meta_CheckAssignment_findCached(x_165, x_2, x_125); -x_168 = lean_ctor_get(x_167, 0); -lean_inc(x_168); -if (lean_obj_tag(x_168) == 0) -{ -lean_object* x_169; lean_object* x_170; -x_169 = lean_ctor_get(x_167, 1); -lean_inc(x_169); -lean_dec(x_167); +lean_object* x_53; lean_object* x_54; +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +lean_dec(x_51); lean_inc(x_2); -lean_inc(x_165); -x_170 = l_Lean_Meta_CheckAssignment_check___main(x_165, x_2, x_169); -if (lean_obj_tag(x_170) == 0) -{ -lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; -x_171 = lean_ctor_get(x_170, 0); -lean_inc(x_171); -x_172 = lean_ctor_get(x_170, 1); -lean_inc(x_172); -lean_dec(x_170); -lean_inc(x_171); -x_173 = l_Lean_Meta_CheckAssignment_cache(x_165, x_171, x_2, x_172); -x_174 = lean_ctor_get(x_173, 1); -lean_inc(x_174); -lean_dec(x_173); -x_4 = x_171; -x_5 = x_174; -goto block_11; -} -else -{ -uint8_t x_175; -lean_dec(x_165); -lean_dec(x_2); -lean_dec(x_1); -x_175 = !lean_is_exclusive(x_170); -if (x_175 == 0) -{ -return x_170; -} -else -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; -x_176 = lean_ctor_get(x_170, 0); -x_177 = lean_ctor_get(x_170, 1); -lean_inc(x_177); -lean_inc(x_176); -lean_dec(x_170); -x_178 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_178, 0, x_176); -lean_ctor_set(x_178, 1, x_177); -return x_178; -} -} -} -else -{ -lean_object* x_179; lean_object* x_180; -lean_dec(x_165); -x_179 = lean_ctor_get(x_167, 1); -lean_inc(x_179); -lean_dec(x_167); -x_180 = lean_ctor_get(x_168, 0); -lean_inc(x_180); -lean_dec(x_168); -x_4 = x_180; -x_5 = x_179; -goto block_11; -} -} -} -} -else -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; -x_186 = lean_ctor_get(x_122, 1); -lean_inc(x_186); -lean_dec(x_122); -x_187 = l_Lean_Expr_mvarId_x21(x_1); -x_188 = lean_ctor_get(x_186, 0); -lean_inc(x_188); -lean_inc(x_187); -lean_inc(x_188); -x_189 = lean_metavar_ctx_get_expr_assignment(x_188, x_187); -if (lean_obj_tag(x_189) == 0) -{ -lean_object* x_190; uint8_t x_191; -x_190 = lean_ctor_get(x_2, 1); -lean_inc(x_190); -x_191 = lean_name_eq(x_187, x_190); -lean_dec(x_190); -if (x_191 == 0) -{ -lean_object* x_192; -lean_inc(x_187); -lean_inc(x_188); -x_192 = lean_metavar_ctx_find_decl(x_188, x_187); -if (lean_obj_tag(x_192) == 0) -{ -lean_object* x_193; lean_object* x_194; -lean_dec(x_188); -lean_dec(x_2); -lean_dec(x_1); -x_193 = lean_alloc_ctor(5, 1, 0); -lean_ctor_set(x_193, 0, x_187); -x_194 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_194, 0, x_193); -lean_ctor_set(x_194, 1, x_186); -return x_194; -} -else -{ -uint8_t x_195; -x_195 = lean_ctor_get_uint8(x_2, sizeof(void*)*4 + 1); -if (x_195 == 0) -{ -lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; uint8_t x_200; -x_196 = lean_ctor_get(x_192, 0); -lean_inc(x_196); -lean_dec(x_192); -x_197 = lean_ctor_get(x_196, 1); -lean_inc(x_197); -x_198 = lean_ctor_get(x_2, 2); -lean_inc(x_198); -x_199 = lean_ctor_get(x_198, 1); -lean_inc(x_199); -lean_dec(x_198); -lean_inc(x_199); -lean_inc(x_197); -x_200 = l_Lean_LocalContext_isSubPrefixOf(x_197, x_199); -if (x_200 == 0) -{ -lean_object* x_201; lean_object* x_202; uint8_t x_203; -x_201 = lean_ctor_get(x_196, 3); -lean_inc(x_201); -x_202 = lean_ctor_get(x_188, 0); -lean_inc(x_202); -x_203 = lean_nat_dec_eq(x_201, x_202); -lean_dec(x_202); -lean_dec(x_201); -if (x_203 == 0) -{ -lean_object* x_204; lean_object* x_205; -lean_dec(x_199); -lean_dec(x_197); -lean_dec(x_196); -lean_dec(x_188); -lean_dec(x_2); -lean_dec(x_1); -x_204 = lean_alloc_ctor(3, 1, 0); -lean_ctor_set(x_204, 0, x_187); -x_205 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_205, 0, x_204); -lean_ctor_set(x_205, 1, x_186); -return x_205; -} -else -{ -uint8_t x_206; -x_206 = lean_ctor_get_uint8(x_196, sizeof(void*)*4); -if (x_206 == 0) -{ -uint8_t x_207; -x_207 = lean_ctor_get_uint8(x_2, sizeof(void*)*4); -if (x_207 == 0) -{ -lean_dec(x_199); -lean_dec(x_197); -lean_dec(x_196); -lean_dec(x_188); -lean_dec(x_187); lean_inc(x_1); -x_4 = x_1; -x_5 = x_186; -goto block_11; +x_54 = l_Lean_Meta_CheckAssignment_checkMVar___at_Lean_Meta_CheckAssignment_check___main___spec__4(x_1, x_2, x_53); +if (lean_obj_tag(x_54) == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; +x_55 = lean_ctor_get(x_54, 0); +lean_inc(x_55); +x_56 = lean_ctor_get(x_54, 1); +lean_inc(x_56); +lean_dec(x_54); +lean_inc(x_55); +x_57 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_1, x_55, x_2, x_56); +lean_dec(x_2); +x_58 = !lean_is_exclusive(x_57); +if (x_58 == 0) +{ +lean_object* x_59; +x_59 = lean_ctor_get(x_57, 0); +lean_dec(x_59); +lean_ctor_set(x_57, 0, x_55); +return x_57; } else { -uint8_t x_208; -lean_inc(x_199); -x_208 = l_Lean_LocalContext_isSubPrefixOf(x_199, x_197); -if (x_208 == 0) -{ -lean_dec(x_199); -lean_dec(x_196); -lean_dec(x_188); -lean_dec(x_187); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_186; -goto block_11; +lean_object* x_60; lean_object* x_61; +x_60 = lean_ctor_get(x_57, 1); +lean_inc(x_60); +lean_dec(x_57); +x_61 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_61, 0, x_55); +lean_ctor_set(x_61, 1, x_60); +return x_61; +} } else { -lean_object* x_209; lean_object* x_210; uint8_t x_211; -x_209 = lean_ctor_get(x_196, 2); -lean_inc(x_209); -lean_dec(x_196); -lean_inc(x_209); -lean_inc(x_199); -x_210 = l_Lean_MetavarContext_isWellFormed___main(x_188, x_199, x_209); -x_211 = lean_unbox(x_210); -lean_dec(x_210); -if (x_211 == 0) -{ -lean_object* x_212; lean_object* x_213; -lean_dec(x_209); -lean_dec(x_199); +uint8_t x_62; lean_dec(x_2); lean_dec(x_1); -x_212 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_212, 0, x_187); -x_213 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_213, 0, x_212); -lean_ctor_set(x_213, 1, x_186); -return x_213; +x_62 = !lean_is_exclusive(x_54); +if (x_62 == 0) +{ +return x_54; } else { -lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; -x_214 = l_Lean_Meta_CheckAssignment_mkAuxMVar(x_199, x_209, x_2, x_186); -x_215 = lean_ctor_get(x_214, 1); -lean_inc(x_215); -x_216 = lean_ctor_get(x_214, 0); -lean_inc(x_216); -lean_dec(x_214); -x_217 = lean_ctor_get(x_215, 0); -lean_inc(x_217); -x_218 = lean_ctor_get(x_215, 1); -lean_inc(x_218); -x_219 = lean_ctor_get(x_215, 2); -lean_inc(x_219); -if (lean_is_exclusive(x_215)) { - lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - lean_ctor_release(x_215, 2); - x_220 = x_215; -} else { - lean_dec_ref(x_215); - x_220 = lean_box(0); -} -lean_inc(x_216); -x_221 = lean_metavar_ctx_assign_expr(x_217, x_187, x_216); -if (lean_is_scalar(x_220)) { - x_222 = lean_alloc_ctor(0, 3, 0); -} else { - x_222 = x_220; -} -lean_ctor_set(x_222, 0, x_221); -lean_ctor_set(x_222, 1, x_218); -lean_ctor_set(x_222, 2, x_219); -x_4 = x_216; -x_5 = x_222; -goto block_11; -} +lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_63 = lean_ctor_get(x_54, 0); +x_64 = lean_ctor_get(x_54, 1); +lean_inc(x_64); +lean_inc(x_63); +lean_dec(x_54); +x_65 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_65, 0, x_63); +lean_ctor_set(x_65, 1, x_64); +return x_65; } } } else { -lean_object* x_223; lean_object* x_224; -lean_dec(x_199); -lean_dec(x_197); -lean_dec(x_196); -lean_dec(x_188); +uint8_t x_66; lean_dec(x_2); lean_dec(x_1); -x_223 = lean_alloc_ctor(3, 1, 0); -lean_ctor_set(x_223, 0, x_187); -x_224 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_224, 0, x_223); -lean_ctor_set(x_224, 1, x_186); -return x_224; -} -} +x_66 = !lean_is_exclusive(x_51); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; +x_67 = lean_ctor_get(x_51, 0); +lean_dec(x_67); +x_68 = lean_ctor_get(x_52, 0); +lean_inc(x_68); +lean_dec(x_52); +lean_ctor_set(x_51, 0, x_68); +return x_51; } else { -lean_dec(x_199); -lean_dec(x_197); -lean_dec(x_196); -lean_dec(x_188); -lean_dec(x_187); -lean_inc(x_1); -x_4 = x_1; -x_5 = x_186; -goto block_11; -} -} -else -{ -lean_object* x_225; lean_object* x_226; -lean_dec(x_192); -lean_dec(x_188); -lean_dec(x_187); -lean_dec(x_2); -lean_dec(x_1); -x_225 = lean_box(1); -x_226 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_226, 0, x_225); -lean_ctor_set(x_226, 1, x_186); -return x_226; -} -} -} -else -{ -lean_object* x_227; lean_object* x_228; -lean_dec(x_188); -lean_dec(x_187); -lean_dec(x_2); -lean_dec(x_1); -x_227 = lean_box(0); -x_228 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_228, 0, x_227); -lean_ctor_set(x_228, 1, x_186); -return x_228; -} -} -else -{ -lean_object* x_229; lean_object* x_230; uint8_t x_246; -lean_dec(x_188); -lean_dec(x_187); -x_229 = lean_ctor_get(x_189, 0); -lean_inc(x_229); -lean_dec(x_189); -x_246 = l_Lean_Expr_hasExprMVar(x_229); -if (x_246 == 0) -{ -uint8_t x_247; -x_247 = l_Lean_Expr_hasFVar(x_229); -if (x_247 == 0) -{ -x_4 = x_229; -x_5 = x_186; -goto block_11; -} -else -{ -lean_object* x_248; -x_248 = lean_box(0); -x_230 = x_248; -goto block_245; -} -} -else -{ -lean_object* x_249; -x_249 = lean_box(0); -x_230 = x_249; -goto block_245; -} -block_245: -{ -lean_object* x_231; lean_object* x_232; -lean_dec(x_230); -x_231 = l_Lean_Meta_CheckAssignment_findCached(x_229, x_2, x_186); -x_232 = lean_ctor_get(x_231, 0); -lean_inc(x_232); -if (lean_obj_tag(x_232) == 0) -{ -lean_object* x_233; lean_object* x_234; -x_233 = lean_ctor_get(x_231, 1); -lean_inc(x_233); -lean_dec(x_231); -lean_inc(x_2); -lean_inc(x_229); -x_234 = l_Lean_Meta_CheckAssignment_check___main(x_229, x_2, x_233); -if (lean_obj_tag(x_234) == 0) -{ -lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; -x_235 = lean_ctor_get(x_234, 0); -lean_inc(x_235); -x_236 = lean_ctor_get(x_234, 1); -lean_inc(x_236); -lean_dec(x_234); -lean_inc(x_235); -x_237 = l_Lean_Meta_CheckAssignment_cache(x_229, x_235, x_2, x_236); -x_238 = lean_ctor_get(x_237, 1); -lean_inc(x_238); -lean_dec(x_237); -x_4 = x_235; -x_5 = x_238; -goto block_11; -} -else -{ -lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; -lean_dec(x_229); -lean_dec(x_2); -lean_dec(x_1); -x_239 = lean_ctor_get(x_234, 0); -lean_inc(x_239); -x_240 = lean_ctor_get(x_234, 1); -lean_inc(x_240); -if (lean_is_exclusive(x_234)) { - lean_ctor_release(x_234, 0); - lean_ctor_release(x_234, 1); - x_241 = x_234; -} else { - lean_dec_ref(x_234); - x_241 = lean_box(0); -} -if (lean_is_scalar(x_241)) { - x_242 = lean_alloc_ctor(1, 2, 0); -} else { - x_242 = x_241; -} -lean_ctor_set(x_242, 0, x_239); -lean_ctor_set(x_242, 1, x_240); -return x_242; -} -} -else -{ -lean_object* x_243; lean_object* x_244; -lean_dec(x_229); -x_243 = lean_ctor_get(x_231, 1); -lean_inc(x_243); -lean_dec(x_231); -x_244 = lean_ctor_get(x_232, 0); -lean_inc(x_244); -lean_dec(x_232); -x_4 = x_244; -x_5 = x_243; -goto block_11; -} -} -} -} -} -else -{ -uint8_t x_250; -lean_dec(x_2); -lean_dec(x_1); -x_250 = !lean_is_exclusive(x_122); -if (x_250 == 0) -{ -lean_object* x_251; lean_object* x_252; -x_251 = lean_ctor_get(x_122, 0); -lean_dec(x_251); -x_252 = lean_ctor_get(x_123, 0); -lean_inc(x_252); -lean_dec(x_123); -lean_ctor_set(x_122, 0, x_252); -return x_122; -} -else -{ -lean_object* x_253; lean_object* x_254; lean_object* x_255; -x_253 = lean_ctor_get(x_122, 1); -lean_inc(x_253); -lean_dec(x_122); -x_254 = lean_ctor_get(x_123, 0); -lean_inc(x_254); -lean_dec(x_123); -x_255 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_255, 0, x_254); -lean_ctor_set(x_255, 1, x_253); -return x_255; +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_51, 1); +lean_inc(x_69); +lean_dec(x_51); +x_70 = lean_ctor_get(x_52, 0); +lean_inc(x_70); +lean_dec(x_52); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_70); +lean_ctor_set(x_71, 1, x_69); +return x_71; } } } } case 5: { -lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_296; uint8_t x_312; -x_262 = lean_ctor_get(x_1, 0); -lean_inc(x_262); -x_263 = lean_ctor_get(x_1, 1); -lean_inc(x_263); -x_312 = l_Lean_Expr_hasExprMVar(x_262); -if (x_312 == 0) +lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_112; uint8_t x_128; +x_78 = lean_ctor_get(x_1, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_1, 1); +lean_inc(x_79); +x_128 = l_Lean_Expr_hasExprMVar(x_78); +if (x_128 == 0) { -uint8_t x_313; -x_313 = l_Lean_Expr_hasFVar(x_262); -if (x_313 == 0) +uint8_t x_129; +x_129 = l_Lean_Expr_hasFVar(x_78); +if (x_129 == 0) { -x_264 = x_262; -x_265 = x_3; -goto block_295; +x_80 = x_78; +x_81 = x_3; +goto block_111; } else { -lean_object* x_314; -x_314 = lean_box(0); -x_296 = x_314; -goto block_311; +lean_object* x_130; +x_130 = lean_box(0); +x_112 = x_130; +goto block_127; } } else { -lean_object* x_315; -x_315 = lean_box(0); -x_296 = x_315; -goto block_311; +lean_object* x_131; +x_131 = lean_box(0); +x_112 = x_131; +goto block_127; } -block_295: +block_111: { -lean_object* x_266; lean_object* x_267; lean_object* x_275; uint8_t x_291; -x_291 = l_Lean_Expr_hasExprMVar(x_263); -if (x_291 == 0) +lean_object* x_82; lean_object* x_83; lean_object* x_91; uint8_t x_107; +x_107 = l_Lean_Expr_hasExprMVar(x_79); +if (x_107 == 0) { -uint8_t x_292; -x_292 = l_Lean_Expr_hasFVar(x_263); -if (x_292 == 0) +uint8_t x_108; +x_108 = l_Lean_Expr_hasFVar(x_79); +if (x_108 == 0) { lean_dec(x_2); -x_266 = x_263; -x_267 = x_265; -goto block_274; +x_82 = x_79; +x_83 = x_81; +goto block_90; } else { -lean_object* x_293; -x_293 = lean_box(0); -x_275 = x_293; -goto block_290; +lean_object* x_109; +x_109 = lean_box(0); +x_91 = x_109; +goto block_106; } } else { -lean_object* x_294; -x_294 = lean_box(0); -x_275 = x_294; -goto block_290; +lean_object* x_110; +x_110 = lean_box(0); +x_91 = x_110; +goto block_106; } -block_274: +block_90: { if (lean_obj_tag(x_1) == 5) { -lean_object* x_268; lean_object* x_269; -x_268 = lean_expr_update_app(x_1, x_264, x_266); -x_269 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_269, 0, x_268); -lean_ctor_set(x_269, 1, x_267); -return x_269; +lean_object* x_84; lean_object* x_85; +x_84 = lean_expr_update_app(x_1, x_80, x_82); +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_84); +lean_ctor_set(x_85, 1, x_83); +return x_85; } else { -lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; -lean_dec(x_266); -lean_dec(x_264); +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; +lean_dec(x_82); +lean_dec(x_80); lean_dec(x_1); -x_270 = l_Lean_Expr_Inhabited; -x_271 = l_Lean_Expr_updateApp_x21___closed__1; -x_272 = lean_panic_fn(x_271); -x_273 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_273, 0, x_272); -lean_ctor_set(x_273, 1, x_267); -return x_273; +x_86 = l_Lean_Expr_Inhabited; +x_87 = l_Lean_Expr_updateApp_x21___closed__1; +x_88 = lean_panic_fn(x_87); +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_88); +lean_ctor_set(x_89, 1, x_83); +return x_89; } } -block_290: +block_106: { -lean_object* x_276; lean_object* x_277; -lean_dec(x_275); -x_276 = l_Lean_Meta_CheckAssignment_findCached(x_263, x_2, x_265); -x_277 = lean_ctor_get(x_276, 0); -lean_inc(x_277); -if (lean_obj_tag(x_277) == 0) +lean_object* x_92; lean_object* x_93; +lean_dec(x_91); +x_92 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_79, x_2, x_81); +x_93 = lean_ctor_get(x_92, 0); +lean_inc(x_93); +if (lean_obj_tag(x_93) == 0) { -lean_object* x_278; lean_object* x_279; -x_278 = lean_ctor_get(x_276, 1); -lean_inc(x_278); -lean_dec(x_276); +lean_object* x_94; lean_object* x_95; +x_94 = lean_ctor_get(x_92, 1); +lean_inc(x_94); +lean_dec(x_92); lean_inc(x_2); -lean_inc(x_263); -x_279 = l_Lean_Meta_CheckAssignment_check___main(x_263, x_2, x_278); -if (lean_obj_tag(x_279) == 0) +lean_inc(x_79); +x_95 = l_Lean_Meta_CheckAssignment_check___main(x_79, x_2, x_94); +if (lean_obj_tag(x_95) == 0) { -lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; -x_280 = lean_ctor_get(x_279, 0); -lean_inc(x_280); -x_281 = lean_ctor_get(x_279, 1); -lean_inc(x_281); -lean_dec(x_279); -lean_inc(x_280); -x_282 = l_Lean_Meta_CheckAssignment_cache(x_263, x_280, x_2, x_281); +lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_96 = lean_ctor_get(x_95, 0); +lean_inc(x_96); +x_97 = lean_ctor_get(x_95, 1); +lean_inc(x_97); +lean_dec(x_95); +lean_inc(x_96); +x_98 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_79, x_96, x_2, x_97); lean_dec(x_2); -x_283 = lean_ctor_get(x_282, 1); -lean_inc(x_283); -lean_dec(x_282); -x_266 = x_280; -x_267 = x_283; -goto block_274; +x_99 = lean_ctor_get(x_98, 1); +lean_inc(x_99); +lean_dec(x_98); +x_82 = x_96; +x_83 = x_99; +goto block_90; } else { -uint8_t x_284; -lean_dec(x_264); -lean_dec(x_263); +uint8_t x_100; +lean_dec(x_80); +lean_dec(x_79); lean_dec(x_2); lean_dec(x_1); -x_284 = !lean_is_exclusive(x_279); -if (x_284 == 0) +x_100 = !lean_is_exclusive(x_95); +if (x_100 == 0) { -return x_279; +return x_95; } else { -lean_object* x_285; lean_object* x_286; lean_object* x_287; -x_285 = lean_ctor_get(x_279, 0); -x_286 = lean_ctor_get(x_279, 1); -lean_inc(x_286); -lean_inc(x_285); -lean_dec(x_279); -x_287 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_287, 0, x_285); -lean_ctor_set(x_287, 1, x_286); -return x_287; +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_95, 0); +x_102 = lean_ctor_get(x_95, 1); +lean_inc(x_102); +lean_inc(x_101); +lean_dec(x_95); +x_103 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_103, 0, x_101); +lean_ctor_set(x_103, 1, x_102); +return x_103; } } } else { -lean_object* x_288; lean_object* x_289; -lean_dec(x_263); +lean_object* x_104; lean_object* x_105; +lean_dec(x_79); lean_dec(x_2); -x_288 = lean_ctor_get(x_276, 1); -lean_inc(x_288); -lean_dec(x_276); -x_289 = lean_ctor_get(x_277, 0); -lean_inc(x_289); -lean_dec(x_277); -x_266 = x_289; -x_267 = x_288; -goto block_274; +x_104 = lean_ctor_get(x_92, 1); +lean_inc(x_104); +lean_dec(x_92); +x_105 = lean_ctor_get(x_93, 0); +lean_inc(x_105); +lean_dec(x_93); +x_82 = x_105; +x_83 = x_104; +goto block_90; } } } -block_311: +block_127: { -lean_object* x_297; lean_object* x_298; -lean_dec(x_296); -x_297 = l_Lean_Meta_CheckAssignment_findCached(x_262, x_2, x_3); -x_298 = lean_ctor_get(x_297, 0); -lean_inc(x_298); -if (lean_obj_tag(x_298) == 0) +lean_object* x_113; lean_object* x_114; +lean_dec(x_112); +x_113 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_78, x_2, x_3); +x_114 = lean_ctor_get(x_113, 0); +lean_inc(x_114); +if (lean_obj_tag(x_114) == 0) { -lean_object* x_299; lean_object* x_300; -x_299 = lean_ctor_get(x_297, 1); -lean_inc(x_299); -lean_dec(x_297); +lean_object* x_115; lean_object* x_116; +x_115 = lean_ctor_get(x_113, 1); +lean_inc(x_115); +lean_dec(x_113); lean_inc(x_2); -lean_inc(x_262); -x_300 = l_Lean_Meta_CheckAssignment_check___main(x_262, x_2, x_299); -if (lean_obj_tag(x_300) == 0) +lean_inc(x_78); +x_116 = l_Lean_Meta_CheckAssignment_check___main(x_78, x_2, x_115); +if (lean_obj_tag(x_116) == 0) { -lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; -x_301 = lean_ctor_get(x_300, 0); -lean_inc(x_301); -x_302 = lean_ctor_get(x_300, 1); -lean_inc(x_302); -lean_dec(x_300); -lean_inc(x_301); -x_303 = l_Lean_Meta_CheckAssignment_cache(x_262, x_301, x_2, x_302); -x_304 = lean_ctor_get(x_303, 1); -lean_inc(x_304); -lean_dec(x_303); -x_264 = x_301; -x_265 = x_304; -goto block_295; +lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_117 = lean_ctor_get(x_116, 0); +lean_inc(x_117); +x_118 = lean_ctor_get(x_116, 1); +lean_inc(x_118); +lean_dec(x_116); +lean_inc(x_117); +x_119 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_78, x_117, x_2, x_118); +x_120 = lean_ctor_get(x_119, 1); +lean_inc(x_120); +lean_dec(x_119); +x_80 = x_117; +x_81 = x_120; +goto block_111; } else { -uint8_t x_305; -lean_dec(x_263); -lean_dec(x_262); +uint8_t x_121; +lean_dec(x_79); +lean_dec(x_78); lean_dec(x_2); lean_dec(x_1); -x_305 = !lean_is_exclusive(x_300); -if (x_305 == 0) +x_121 = !lean_is_exclusive(x_116); +if (x_121 == 0) { -return x_300; +return x_116; } else { -lean_object* x_306; lean_object* x_307; lean_object* x_308; -x_306 = lean_ctor_get(x_300, 0); -x_307 = lean_ctor_get(x_300, 1); -lean_inc(x_307); -lean_inc(x_306); -lean_dec(x_300); -x_308 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_308, 0, x_306); -lean_ctor_set(x_308, 1, x_307); -return x_308; +lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_122 = lean_ctor_get(x_116, 0); +x_123 = lean_ctor_get(x_116, 1); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_116); +x_124 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_124, 0, x_122); +lean_ctor_set(x_124, 1, x_123); +return x_124; } } } else { -lean_object* x_309; lean_object* x_310; -lean_dec(x_262); -x_309 = lean_ctor_get(x_297, 1); -lean_inc(x_309); -lean_dec(x_297); -x_310 = lean_ctor_get(x_298, 0); -lean_inc(x_310); -lean_dec(x_298); -x_264 = x_310; -x_265 = x_309; -goto block_295; +lean_object* x_125; lean_object* x_126; +lean_dec(x_78); +x_125 = lean_ctor_get(x_113, 1); +lean_inc(x_125); +lean_dec(x_113); +x_126 = lean_ctor_get(x_114, 0); +lean_inc(x_126); +lean_dec(x_114); +x_80 = x_126; +x_81 = x_125; +goto block_111; } } } case 6: { -lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_352; uint8_t x_368; -x_316 = lean_ctor_get(x_1, 1); -lean_inc(x_316); -x_317 = lean_ctor_get(x_1, 2); -lean_inc(x_317); -x_368 = l_Lean_Expr_hasExprMVar(x_316); -if (x_368 == 0) +lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_168; uint8_t x_184; +x_132 = lean_ctor_get(x_1, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_1, 2); +lean_inc(x_133); +x_184 = l_Lean_Expr_hasExprMVar(x_132); +if (x_184 == 0) { -uint8_t x_369; -x_369 = l_Lean_Expr_hasFVar(x_316); -if (x_369 == 0) +uint8_t x_185; +x_185 = l_Lean_Expr_hasFVar(x_132); +if (x_185 == 0) { -x_318 = x_316; -x_319 = x_3; -goto block_351; +x_134 = x_132; +x_135 = x_3; +goto block_167; } else { -lean_object* x_370; -x_370 = lean_box(0); -x_352 = x_370; -goto block_367; +lean_object* x_186; +x_186 = lean_box(0); +x_168 = x_186; +goto block_183; } } else { -lean_object* x_371; -x_371 = lean_box(0); -x_352 = x_371; -goto block_367; +lean_object* x_187; +x_187 = lean_box(0); +x_168 = x_187; +goto block_183; } -block_351: +block_167: { -lean_object* x_320; lean_object* x_321; lean_object* x_331; uint8_t x_347; -x_347 = l_Lean_Expr_hasExprMVar(x_317); -if (x_347 == 0) +lean_object* x_136; lean_object* x_137; lean_object* x_147; uint8_t x_163; +x_163 = l_Lean_Expr_hasExprMVar(x_133); +if (x_163 == 0) { -uint8_t x_348; -x_348 = l_Lean_Expr_hasFVar(x_317); -if (x_348 == 0) +uint8_t x_164; +x_164 = l_Lean_Expr_hasFVar(x_133); +if (x_164 == 0) { lean_dec(x_2); -x_320 = x_317; -x_321 = x_319; -goto block_330; +x_136 = x_133; +x_137 = x_135; +goto block_146; } else { -lean_object* x_349; -x_349 = lean_box(0); -x_331 = x_349; -goto block_346; +lean_object* x_165; +x_165 = lean_box(0); +x_147 = x_165; +goto block_162; } } else { -lean_object* x_350; -x_350 = lean_box(0); -x_331 = x_350; -goto block_346; +lean_object* x_166; +x_166 = lean_box(0); +x_147 = x_166; +goto block_162; } -block_330: +block_146: { if (lean_obj_tag(x_1) == 6) { -uint64_t x_322; uint8_t x_323; lean_object* x_324; lean_object* x_325; -x_322 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); -x_323 = (uint8_t)((x_322 << 24) >> 61); -x_324 = lean_expr_update_lambda(x_1, x_323, x_318, x_320); -x_325 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_325, 0, x_324); -lean_ctor_set(x_325, 1, x_321); -return x_325; +uint64_t x_138; uint8_t x_139; lean_object* x_140; lean_object* x_141; +x_138 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_139 = (uint8_t)((x_138 << 24) >> 61); +x_140 = lean_expr_update_lambda(x_1, x_139, x_134, x_136); +x_141 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_141, 0, x_140); +lean_ctor_set(x_141, 1, x_137); +return x_141; } else { -lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; -lean_dec(x_320); -lean_dec(x_318); +lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; +lean_dec(x_136); +lean_dec(x_134); lean_dec(x_1); -x_326 = l_Lean_Expr_Inhabited; -x_327 = l_Lean_Expr_updateLambdaE_x21___closed__1; -x_328 = lean_panic_fn(x_327); -x_329 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_329, 0, x_328); -lean_ctor_set(x_329, 1, x_321); -return x_329; +x_142 = l_Lean_Expr_Inhabited; +x_143 = l_Lean_Expr_updateLambdaE_x21___closed__1; +x_144 = lean_panic_fn(x_143); +x_145 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_145, 0, x_144); +lean_ctor_set(x_145, 1, x_137); +return x_145; } } -block_346: +block_162: { -lean_object* x_332; lean_object* x_333; -lean_dec(x_331); -x_332 = l_Lean_Meta_CheckAssignment_findCached(x_317, x_2, x_319); -x_333 = lean_ctor_get(x_332, 0); -lean_inc(x_333); -if (lean_obj_tag(x_333) == 0) +lean_object* x_148; lean_object* x_149; +lean_dec(x_147); +x_148 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_133, x_2, x_135); +x_149 = lean_ctor_get(x_148, 0); +lean_inc(x_149); +if (lean_obj_tag(x_149) == 0) { -lean_object* x_334; lean_object* x_335; -x_334 = lean_ctor_get(x_332, 1); -lean_inc(x_334); -lean_dec(x_332); +lean_object* x_150; lean_object* x_151; +x_150 = lean_ctor_get(x_148, 1); +lean_inc(x_150); +lean_dec(x_148); lean_inc(x_2); -lean_inc(x_317); -x_335 = l_Lean_Meta_CheckAssignment_check___main(x_317, x_2, x_334); -if (lean_obj_tag(x_335) == 0) +lean_inc(x_133); +x_151 = l_Lean_Meta_CheckAssignment_check___main(x_133, x_2, x_150); +if (lean_obj_tag(x_151) == 0) { -lean_object* x_336; lean_object* x_337; lean_object* x_338; lean_object* x_339; -x_336 = lean_ctor_get(x_335, 0); -lean_inc(x_336); -x_337 = lean_ctor_get(x_335, 1); -lean_inc(x_337); -lean_dec(x_335); -lean_inc(x_336); -x_338 = l_Lean_Meta_CheckAssignment_cache(x_317, x_336, x_2, x_337); +lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; +x_152 = lean_ctor_get(x_151, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_151, 1); +lean_inc(x_153); +lean_dec(x_151); +lean_inc(x_152); +x_154 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_133, x_152, x_2, x_153); lean_dec(x_2); -x_339 = lean_ctor_get(x_338, 1); -lean_inc(x_339); -lean_dec(x_338); -x_320 = x_336; -x_321 = x_339; -goto block_330; +x_155 = lean_ctor_get(x_154, 1); +lean_inc(x_155); +lean_dec(x_154); +x_136 = x_152; +x_137 = x_155; +goto block_146; } else { -uint8_t x_340; -lean_dec(x_318); -lean_dec(x_317); +uint8_t x_156; +lean_dec(x_134); +lean_dec(x_133); lean_dec(x_2); lean_dec(x_1); -x_340 = !lean_is_exclusive(x_335); -if (x_340 == 0) +x_156 = !lean_is_exclusive(x_151); +if (x_156 == 0) { -return x_335; +return x_151; } else { -lean_object* x_341; lean_object* x_342; lean_object* x_343; -x_341 = lean_ctor_get(x_335, 0); -x_342 = lean_ctor_get(x_335, 1); -lean_inc(x_342); -lean_inc(x_341); -lean_dec(x_335); -x_343 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_343, 0, x_341); -lean_ctor_set(x_343, 1, x_342); -return x_343; +lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_157 = lean_ctor_get(x_151, 0); +x_158 = lean_ctor_get(x_151, 1); +lean_inc(x_158); +lean_inc(x_157); +lean_dec(x_151); +x_159 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_159, 0, x_157); +lean_ctor_set(x_159, 1, x_158); +return x_159; } } } else { -lean_object* x_344; lean_object* x_345; -lean_dec(x_317); +lean_object* x_160; lean_object* x_161; +lean_dec(x_133); lean_dec(x_2); -x_344 = lean_ctor_get(x_332, 1); -lean_inc(x_344); -lean_dec(x_332); -x_345 = lean_ctor_get(x_333, 0); -lean_inc(x_345); -lean_dec(x_333); -x_320 = x_345; -x_321 = x_344; -goto block_330; +x_160 = lean_ctor_get(x_148, 1); +lean_inc(x_160); +lean_dec(x_148); +x_161 = lean_ctor_get(x_149, 0); +lean_inc(x_161); +lean_dec(x_149); +x_136 = x_161; +x_137 = x_160; +goto block_146; } } } -block_367: +block_183: { -lean_object* x_353; lean_object* x_354; -lean_dec(x_352); -x_353 = l_Lean_Meta_CheckAssignment_findCached(x_316, x_2, x_3); -x_354 = lean_ctor_get(x_353, 0); -lean_inc(x_354); -if (lean_obj_tag(x_354) == 0) +lean_object* x_169; lean_object* x_170; +lean_dec(x_168); +x_169 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_132, x_2, x_3); +x_170 = lean_ctor_get(x_169, 0); +lean_inc(x_170); +if (lean_obj_tag(x_170) == 0) { -lean_object* x_355; lean_object* x_356; -x_355 = lean_ctor_get(x_353, 1); -lean_inc(x_355); -lean_dec(x_353); +lean_object* x_171; lean_object* x_172; +x_171 = lean_ctor_get(x_169, 1); +lean_inc(x_171); +lean_dec(x_169); lean_inc(x_2); -lean_inc(x_316); -x_356 = l_Lean_Meta_CheckAssignment_check___main(x_316, x_2, x_355); -if (lean_obj_tag(x_356) == 0) +lean_inc(x_132); +x_172 = l_Lean_Meta_CheckAssignment_check___main(x_132, x_2, x_171); +if (lean_obj_tag(x_172) == 0) { -lean_object* x_357; lean_object* x_358; lean_object* x_359; lean_object* x_360; -x_357 = lean_ctor_get(x_356, 0); -lean_inc(x_357); -x_358 = lean_ctor_get(x_356, 1); -lean_inc(x_358); -lean_dec(x_356); -lean_inc(x_357); -x_359 = l_Lean_Meta_CheckAssignment_cache(x_316, x_357, x_2, x_358); -x_360 = lean_ctor_get(x_359, 1); -lean_inc(x_360); -lean_dec(x_359); -x_318 = x_357; -x_319 = x_360; -goto block_351; +lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; +x_173 = lean_ctor_get(x_172, 0); +lean_inc(x_173); +x_174 = lean_ctor_get(x_172, 1); +lean_inc(x_174); +lean_dec(x_172); +lean_inc(x_173); +x_175 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_132, x_173, x_2, x_174); +x_176 = lean_ctor_get(x_175, 1); +lean_inc(x_176); +lean_dec(x_175); +x_134 = x_173; +x_135 = x_176; +goto block_167; } else { -uint8_t x_361; -lean_dec(x_317); -lean_dec(x_316); +uint8_t x_177; +lean_dec(x_133); +lean_dec(x_132); lean_dec(x_2); lean_dec(x_1); -x_361 = !lean_is_exclusive(x_356); -if (x_361 == 0) +x_177 = !lean_is_exclusive(x_172); +if (x_177 == 0) { -return x_356; +return x_172; } else { -lean_object* x_362; lean_object* x_363; lean_object* x_364; -x_362 = lean_ctor_get(x_356, 0); -x_363 = lean_ctor_get(x_356, 1); -lean_inc(x_363); -lean_inc(x_362); -lean_dec(x_356); -x_364 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_364, 0, x_362); -lean_ctor_set(x_364, 1, x_363); -return x_364; +lean_object* x_178; lean_object* x_179; lean_object* x_180; +x_178 = lean_ctor_get(x_172, 0); +x_179 = lean_ctor_get(x_172, 1); +lean_inc(x_179); +lean_inc(x_178); +lean_dec(x_172); +x_180 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_180, 0, x_178); +lean_ctor_set(x_180, 1, x_179); +return x_180; } } } else { -lean_object* x_365; lean_object* x_366; -lean_dec(x_316); -x_365 = lean_ctor_get(x_353, 1); -lean_inc(x_365); -lean_dec(x_353); -x_366 = lean_ctor_get(x_354, 0); -lean_inc(x_366); -lean_dec(x_354); -x_318 = x_366; -x_319 = x_365; -goto block_351; +lean_object* x_181; lean_object* x_182; +lean_dec(x_132); +x_181 = lean_ctor_get(x_169, 1); +lean_inc(x_181); +lean_dec(x_169); +x_182 = lean_ctor_get(x_170, 0); +lean_inc(x_182); +lean_dec(x_170); +x_134 = x_182; +x_135 = x_181; +goto block_167; } } } case 7: { -lean_object* x_372; lean_object* x_373; lean_object* x_374; lean_object* x_375; lean_object* x_408; uint8_t x_424; -x_372 = lean_ctor_get(x_1, 1); -lean_inc(x_372); -x_373 = lean_ctor_get(x_1, 2); -lean_inc(x_373); -x_424 = l_Lean_Expr_hasExprMVar(x_372); -if (x_424 == 0) +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_224; uint8_t x_240; +x_188 = lean_ctor_get(x_1, 1); +lean_inc(x_188); +x_189 = lean_ctor_get(x_1, 2); +lean_inc(x_189); +x_240 = l_Lean_Expr_hasExprMVar(x_188); +if (x_240 == 0) { -uint8_t x_425; -x_425 = l_Lean_Expr_hasFVar(x_372); -if (x_425 == 0) +uint8_t x_241; +x_241 = l_Lean_Expr_hasFVar(x_188); +if (x_241 == 0) { -x_374 = x_372; -x_375 = x_3; -goto block_407; +x_190 = x_188; +x_191 = x_3; +goto block_223; } else { -lean_object* x_426; -x_426 = lean_box(0); -x_408 = x_426; -goto block_423; +lean_object* x_242; +x_242 = lean_box(0); +x_224 = x_242; +goto block_239; } } else { -lean_object* x_427; -x_427 = lean_box(0); -x_408 = x_427; -goto block_423; +lean_object* x_243; +x_243 = lean_box(0); +x_224 = x_243; +goto block_239; } -block_407: +block_223: { -lean_object* x_376; lean_object* x_377; lean_object* x_387; uint8_t x_403; -x_403 = l_Lean_Expr_hasExprMVar(x_373); -if (x_403 == 0) +lean_object* x_192; lean_object* x_193; lean_object* x_203; uint8_t x_219; +x_219 = l_Lean_Expr_hasExprMVar(x_189); +if (x_219 == 0) { -uint8_t x_404; -x_404 = l_Lean_Expr_hasFVar(x_373); -if (x_404 == 0) +uint8_t x_220; +x_220 = l_Lean_Expr_hasFVar(x_189); +if (x_220 == 0) { lean_dec(x_2); -x_376 = x_373; -x_377 = x_375; -goto block_386; +x_192 = x_189; +x_193 = x_191; +goto block_202; } else { -lean_object* x_405; -x_405 = lean_box(0); -x_387 = x_405; -goto block_402; +lean_object* x_221; +x_221 = lean_box(0); +x_203 = x_221; +goto block_218; } } else { -lean_object* x_406; -x_406 = lean_box(0); -x_387 = x_406; -goto block_402; +lean_object* x_222; +x_222 = lean_box(0); +x_203 = x_222; +goto block_218; } -block_386: +block_202: { if (lean_obj_tag(x_1) == 7) { -uint64_t x_378; uint8_t x_379; lean_object* x_380; lean_object* x_381; -x_378 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); -x_379 = (uint8_t)((x_378 << 24) >> 61); -x_380 = lean_expr_update_forall(x_1, x_379, x_374, x_376); -x_381 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_381, 0, x_380); -lean_ctor_set(x_381, 1, x_377); -return x_381; +uint64_t x_194; uint8_t x_195; lean_object* x_196; lean_object* x_197; +x_194 = lean_ctor_get_uint64(x_1, sizeof(void*)*3); +x_195 = (uint8_t)((x_194 << 24) >> 61); +x_196 = lean_expr_update_forall(x_1, x_195, x_190, x_192); +x_197 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_197, 0, x_196); +lean_ctor_set(x_197, 1, x_193); +return x_197; } else { -lean_object* x_382; lean_object* x_383; lean_object* x_384; lean_object* x_385; -lean_dec(x_376); -lean_dec(x_374); +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; +lean_dec(x_192); +lean_dec(x_190); lean_dec(x_1); -x_382 = l_Lean_Expr_Inhabited; -x_383 = l_Lean_Expr_updateForallE_x21___closed__1; -x_384 = lean_panic_fn(x_383); -x_385 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_385, 0, x_384); -lean_ctor_set(x_385, 1, x_377); -return x_385; +x_198 = l_Lean_Expr_Inhabited; +x_199 = l_Lean_Expr_updateForallE_x21___closed__1; +x_200 = lean_panic_fn(x_199); +x_201 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_201, 0, x_200); +lean_ctor_set(x_201, 1, x_193); +return x_201; } } -block_402: +block_218: { -lean_object* x_388; lean_object* x_389; -lean_dec(x_387); -x_388 = l_Lean_Meta_CheckAssignment_findCached(x_373, x_2, x_375); -x_389 = lean_ctor_get(x_388, 0); -lean_inc(x_389); -if (lean_obj_tag(x_389) == 0) +lean_object* x_204; lean_object* x_205; +lean_dec(x_203); +x_204 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_189, x_2, x_191); +x_205 = lean_ctor_get(x_204, 0); +lean_inc(x_205); +if (lean_obj_tag(x_205) == 0) { -lean_object* x_390; lean_object* x_391; -x_390 = lean_ctor_get(x_388, 1); -lean_inc(x_390); -lean_dec(x_388); +lean_object* x_206; lean_object* x_207; +x_206 = lean_ctor_get(x_204, 1); +lean_inc(x_206); +lean_dec(x_204); lean_inc(x_2); -lean_inc(x_373); -x_391 = l_Lean_Meta_CheckAssignment_check___main(x_373, x_2, x_390); -if (lean_obj_tag(x_391) == 0) +lean_inc(x_189); +x_207 = l_Lean_Meta_CheckAssignment_check___main(x_189, x_2, x_206); +if (lean_obj_tag(x_207) == 0) { -lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; -x_392 = lean_ctor_get(x_391, 0); -lean_inc(x_392); -x_393 = lean_ctor_get(x_391, 1); -lean_inc(x_393); -lean_dec(x_391); -lean_inc(x_392); -x_394 = l_Lean_Meta_CheckAssignment_cache(x_373, x_392, x_2, x_393); +lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; +x_208 = lean_ctor_get(x_207, 0); +lean_inc(x_208); +x_209 = lean_ctor_get(x_207, 1); +lean_inc(x_209); +lean_dec(x_207); +lean_inc(x_208); +x_210 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_189, x_208, x_2, x_209); lean_dec(x_2); -x_395 = lean_ctor_get(x_394, 1); -lean_inc(x_395); -lean_dec(x_394); -x_376 = x_392; -x_377 = x_395; -goto block_386; +x_211 = lean_ctor_get(x_210, 1); +lean_inc(x_211); +lean_dec(x_210); +x_192 = x_208; +x_193 = x_211; +goto block_202; } else { -uint8_t x_396; -lean_dec(x_374); -lean_dec(x_373); +uint8_t x_212; +lean_dec(x_190); +lean_dec(x_189); lean_dec(x_2); lean_dec(x_1); -x_396 = !lean_is_exclusive(x_391); -if (x_396 == 0) +x_212 = !lean_is_exclusive(x_207); +if (x_212 == 0) { -return x_391; +return x_207; } else { -lean_object* x_397; lean_object* x_398; lean_object* x_399; -x_397 = lean_ctor_get(x_391, 0); -x_398 = lean_ctor_get(x_391, 1); -lean_inc(x_398); -lean_inc(x_397); -lean_dec(x_391); -x_399 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_399, 0, x_397); -lean_ctor_set(x_399, 1, x_398); -return x_399; +lean_object* x_213; lean_object* x_214; lean_object* x_215; +x_213 = lean_ctor_get(x_207, 0); +x_214 = lean_ctor_get(x_207, 1); +lean_inc(x_214); +lean_inc(x_213); +lean_dec(x_207); +x_215 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_215, 0, x_213); +lean_ctor_set(x_215, 1, x_214); +return x_215; } } } else { -lean_object* x_400; lean_object* x_401; -lean_dec(x_373); +lean_object* x_216; lean_object* x_217; +lean_dec(x_189); lean_dec(x_2); -x_400 = lean_ctor_get(x_388, 1); -lean_inc(x_400); -lean_dec(x_388); -x_401 = lean_ctor_get(x_389, 0); -lean_inc(x_401); -lean_dec(x_389); -x_376 = x_401; -x_377 = x_400; -goto block_386; +x_216 = lean_ctor_get(x_204, 1); +lean_inc(x_216); +lean_dec(x_204); +x_217 = lean_ctor_get(x_205, 0); +lean_inc(x_217); +lean_dec(x_205); +x_192 = x_217; +x_193 = x_216; +goto block_202; } } } -block_423: +block_239: { -lean_object* x_409; lean_object* x_410; -lean_dec(x_408); -x_409 = l_Lean_Meta_CheckAssignment_findCached(x_372, x_2, x_3); -x_410 = lean_ctor_get(x_409, 0); -lean_inc(x_410); -if (lean_obj_tag(x_410) == 0) +lean_object* x_225; lean_object* x_226; +lean_dec(x_224); +x_225 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_188, x_2, x_3); +x_226 = lean_ctor_get(x_225, 0); +lean_inc(x_226); +if (lean_obj_tag(x_226) == 0) { -lean_object* x_411; lean_object* x_412; -x_411 = lean_ctor_get(x_409, 1); -lean_inc(x_411); -lean_dec(x_409); +lean_object* x_227; lean_object* x_228; +x_227 = lean_ctor_get(x_225, 1); +lean_inc(x_227); +lean_dec(x_225); lean_inc(x_2); -lean_inc(x_372); -x_412 = l_Lean_Meta_CheckAssignment_check___main(x_372, x_2, x_411); -if (lean_obj_tag(x_412) == 0) +lean_inc(x_188); +x_228 = l_Lean_Meta_CheckAssignment_check___main(x_188, x_2, x_227); +if (lean_obj_tag(x_228) == 0) { -lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; -x_413 = lean_ctor_get(x_412, 0); -lean_inc(x_413); -x_414 = lean_ctor_get(x_412, 1); -lean_inc(x_414); -lean_dec(x_412); -lean_inc(x_413); -x_415 = l_Lean_Meta_CheckAssignment_cache(x_372, x_413, x_2, x_414); -x_416 = lean_ctor_get(x_415, 1); -lean_inc(x_416); -lean_dec(x_415); -x_374 = x_413; -x_375 = x_416; -goto block_407; +lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; +x_229 = lean_ctor_get(x_228, 0); +lean_inc(x_229); +x_230 = lean_ctor_get(x_228, 1); +lean_inc(x_230); +lean_dec(x_228); +lean_inc(x_229); +x_231 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_188, x_229, x_2, x_230); +x_232 = lean_ctor_get(x_231, 1); +lean_inc(x_232); +lean_dec(x_231); +x_190 = x_229; +x_191 = x_232; +goto block_223; } else { -uint8_t x_417; -lean_dec(x_373); -lean_dec(x_372); +uint8_t x_233; +lean_dec(x_189); +lean_dec(x_188); lean_dec(x_2); lean_dec(x_1); -x_417 = !lean_is_exclusive(x_412); -if (x_417 == 0) +x_233 = !lean_is_exclusive(x_228); +if (x_233 == 0) { -return x_412; +return x_228; } else { -lean_object* x_418; lean_object* x_419; lean_object* x_420; -x_418 = lean_ctor_get(x_412, 0); -x_419 = lean_ctor_get(x_412, 1); -lean_inc(x_419); -lean_inc(x_418); -lean_dec(x_412); -x_420 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_420, 0, x_418); -lean_ctor_set(x_420, 1, x_419); -return x_420; +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_228, 0); +x_235 = lean_ctor_get(x_228, 1); +lean_inc(x_235); +lean_inc(x_234); +lean_dec(x_228); +x_236 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_236, 0, x_234); +lean_ctor_set(x_236, 1, x_235); +return x_236; } } } else { -lean_object* x_421; lean_object* x_422; -lean_dec(x_372); -x_421 = lean_ctor_get(x_409, 1); -lean_inc(x_421); -lean_dec(x_409); -x_422 = lean_ctor_get(x_410, 0); -lean_inc(x_422); -lean_dec(x_410); -x_374 = x_422; -x_375 = x_421; -goto block_407; +lean_object* x_237; lean_object* x_238; +lean_dec(x_188); +x_237 = lean_ctor_get(x_225, 1); +lean_inc(x_237); +lean_dec(x_225); +x_238 = lean_ctor_get(x_226, 0); +lean_inc(x_238); +lean_dec(x_226); +x_190 = x_238; +x_191 = x_237; +goto block_223; } } } case 8: { -lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; lean_object* x_432; lean_object* x_486; uint8_t x_502; -x_428 = lean_ctor_get(x_1, 1); -lean_inc(x_428); -x_429 = lean_ctor_get(x_1, 2); -lean_inc(x_429); -x_430 = lean_ctor_get(x_1, 3); -lean_inc(x_430); -x_502 = l_Lean_Expr_hasExprMVar(x_428); -if (x_502 == 0) +lean_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_302; uint8_t x_318; +x_244 = lean_ctor_get(x_1, 1); +lean_inc(x_244); +x_245 = lean_ctor_get(x_1, 2); +lean_inc(x_245); +x_246 = lean_ctor_get(x_1, 3); +lean_inc(x_246); +x_318 = l_Lean_Expr_hasExprMVar(x_244); +if (x_318 == 0) { -uint8_t x_503; -x_503 = l_Lean_Expr_hasFVar(x_428); -if (x_503 == 0) +uint8_t x_319; +x_319 = l_Lean_Expr_hasFVar(x_244); +if (x_319 == 0) { -x_431 = x_428; -x_432 = x_3; -goto block_485; +x_247 = x_244; +x_248 = x_3; +goto block_301; } else { -lean_object* x_504; -x_504 = lean_box(0); -x_486 = x_504; -goto block_501; +lean_object* x_320; +x_320 = lean_box(0); +x_302 = x_320; +goto block_317; } } else { -lean_object* x_505; -x_505 = lean_box(0); -x_486 = x_505; -goto block_501; +lean_object* x_321; +x_321 = lean_box(0); +x_302 = x_321; +goto block_317; } -block_485: +block_301: { -lean_object* x_433; lean_object* x_434; lean_object* x_465; uint8_t x_481; -x_481 = l_Lean_Expr_hasExprMVar(x_429); -if (x_481 == 0) +lean_object* x_249; lean_object* x_250; lean_object* x_281; uint8_t x_297; +x_297 = l_Lean_Expr_hasExprMVar(x_245); +if (x_297 == 0) { -uint8_t x_482; -x_482 = l_Lean_Expr_hasFVar(x_429); -if (x_482 == 0) +uint8_t x_298; +x_298 = l_Lean_Expr_hasFVar(x_245); +if (x_298 == 0) { -x_433 = x_429; -x_434 = x_432; -goto block_464; +x_249 = x_245; +x_250 = x_248; +goto block_280; } else { -lean_object* x_483; -x_483 = lean_box(0); -x_465 = x_483; -goto block_480; +lean_object* x_299; +x_299 = lean_box(0); +x_281 = x_299; +goto block_296; } } else { -lean_object* x_484; -x_484 = lean_box(0); -x_465 = x_484; -goto block_480; +lean_object* x_300; +x_300 = lean_box(0); +x_281 = x_300; +goto block_296; } -block_464: +block_280: { -lean_object* x_435; lean_object* x_436; lean_object* x_444; uint8_t x_460; -x_460 = l_Lean_Expr_hasExprMVar(x_430); -if (x_460 == 0) +lean_object* x_251; lean_object* x_252; lean_object* x_260; uint8_t x_276; +x_276 = l_Lean_Expr_hasExprMVar(x_246); +if (x_276 == 0) { -uint8_t x_461; -x_461 = l_Lean_Expr_hasFVar(x_430); -if (x_461 == 0) +uint8_t x_277; +x_277 = l_Lean_Expr_hasFVar(x_246); +if (x_277 == 0) { lean_dec(x_2); -x_435 = x_430; -x_436 = x_434; -goto block_443; +x_251 = x_246; +x_252 = x_250; +goto block_259; } else { -lean_object* x_462; -x_462 = lean_box(0); -x_444 = x_462; -goto block_459; +lean_object* x_278; +x_278 = lean_box(0); +x_260 = x_278; +goto block_275; } } else { -lean_object* x_463; -x_463 = lean_box(0); -x_444 = x_463; -goto block_459; +lean_object* x_279; +x_279 = lean_box(0); +x_260 = x_279; +goto block_275; } -block_443: +block_259: { if (lean_obj_tag(x_1) == 8) { -lean_object* x_437; lean_object* x_438; -x_437 = lean_expr_update_let(x_1, x_431, x_433, x_435); -x_438 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_438, 0, x_437); -lean_ctor_set(x_438, 1, x_436); -return x_438; +lean_object* x_253; lean_object* x_254; +x_253 = lean_expr_update_let(x_1, x_247, x_249, x_251); +x_254 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_254, 0, x_253); +lean_ctor_set(x_254, 1, x_252); +return x_254; } else { -lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; -lean_dec(x_435); -lean_dec(x_433); -lean_dec(x_431); +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +lean_dec(x_251); +lean_dec(x_249); +lean_dec(x_247); lean_dec(x_1); -x_439 = l_Lean_Expr_Inhabited; -x_440 = l_Lean_Expr_updateLet_x21___closed__1; -x_441 = lean_panic_fn(x_440); -x_442 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_442, 0, x_441); -lean_ctor_set(x_442, 1, x_436); -return x_442; +x_255 = l_Lean_Expr_Inhabited; +x_256 = l_Lean_Expr_updateLet_x21___closed__1; +x_257 = lean_panic_fn(x_256); +x_258 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_258, 0, x_257); +lean_ctor_set(x_258, 1, x_252); +return x_258; } } -block_459: +block_275: { -lean_object* x_445; lean_object* x_446; -lean_dec(x_444); -x_445 = l_Lean_Meta_CheckAssignment_findCached(x_430, x_2, x_434); -x_446 = lean_ctor_get(x_445, 0); -lean_inc(x_446); -if (lean_obj_tag(x_446) == 0) +lean_object* x_261; lean_object* x_262; +lean_dec(x_260); +x_261 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_246, x_2, x_250); +x_262 = lean_ctor_get(x_261, 0); +lean_inc(x_262); +if (lean_obj_tag(x_262) == 0) { -lean_object* x_447; lean_object* x_448; -x_447 = lean_ctor_get(x_445, 1); -lean_inc(x_447); -lean_dec(x_445); +lean_object* x_263; lean_object* x_264; +x_263 = lean_ctor_get(x_261, 1); +lean_inc(x_263); +lean_dec(x_261); lean_inc(x_2); -lean_inc(x_430); -x_448 = l_Lean_Meta_CheckAssignment_check___main(x_430, x_2, x_447); -if (lean_obj_tag(x_448) == 0) +lean_inc(x_246); +x_264 = l_Lean_Meta_CheckAssignment_check___main(x_246, x_2, x_263); +if (lean_obj_tag(x_264) == 0) { -lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; -x_449 = lean_ctor_get(x_448, 0); -lean_inc(x_449); -x_450 = lean_ctor_get(x_448, 1); -lean_inc(x_450); -lean_dec(x_448); -lean_inc(x_449); -x_451 = l_Lean_Meta_CheckAssignment_cache(x_430, x_449, x_2, x_450); +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; +x_265 = lean_ctor_get(x_264, 0); +lean_inc(x_265); +x_266 = lean_ctor_get(x_264, 1); +lean_inc(x_266); +lean_dec(x_264); +lean_inc(x_265); +x_267 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_246, x_265, x_2, x_266); lean_dec(x_2); -x_452 = lean_ctor_get(x_451, 1); -lean_inc(x_452); -lean_dec(x_451); -x_435 = x_449; -x_436 = x_452; -goto block_443; +x_268 = lean_ctor_get(x_267, 1); +lean_inc(x_268); +lean_dec(x_267); +x_251 = x_265; +x_252 = x_268; +goto block_259; } else { -uint8_t x_453; -lean_dec(x_433); -lean_dec(x_431); -lean_dec(x_430); +uint8_t x_269; +lean_dec(x_249); +lean_dec(x_247); +lean_dec(x_246); lean_dec(x_2); lean_dec(x_1); -x_453 = !lean_is_exclusive(x_448); -if (x_453 == 0) +x_269 = !lean_is_exclusive(x_264); +if (x_269 == 0) { -return x_448; +return x_264; } else { -lean_object* x_454; lean_object* x_455; lean_object* x_456; -x_454 = lean_ctor_get(x_448, 0); -x_455 = lean_ctor_get(x_448, 1); -lean_inc(x_455); -lean_inc(x_454); -lean_dec(x_448); -x_456 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_456, 0, x_454); -lean_ctor_set(x_456, 1, x_455); -return x_456; +lean_object* x_270; lean_object* x_271; lean_object* x_272; +x_270 = lean_ctor_get(x_264, 0); +x_271 = lean_ctor_get(x_264, 1); +lean_inc(x_271); +lean_inc(x_270); +lean_dec(x_264); +x_272 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_272, 0, x_270); +lean_ctor_set(x_272, 1, x_271); +return x_272; } } } else { -lean_object* x_457; lean_object* x_458; -lean_dec(x_430); +lean_object* x_273; lean_object* x_274; +lean_dec(x_246); lean_dec(x_2); -x_457 = lean_ctor_get(x_445, 1); -lean_inc(x_457); -lean_dec(x_445); -x_458 = lean_ctor_get(x_446, 0); -lean_inc(x_458); -lean_dec(x_446); -x_435 = x_458; -x_436 = x_457; -goto block_443; +x_273 = lean_ctor_get(x_261, 1); +lean_inc(x_273); +lean_dec(x_261); +x_274 = lean_ctor_get(x_262, 0); +lean_inc(x_274); +lean_dec(x_262); +x_251 = x_274; +x_252 = x_273; +goto block_259; } } } -block_480: +block_296: { -lean_object* x_466; lean_object* x_467; -lean_dec(x_465); -x_466 = l_Lean_Meta_CheckAssignment_findCached(x_429, x_2, x_432); -x_467 = lean_ctor_get(x_466, 0); -lean_inc(x_467); -if (lean_obj_tag(x_467) == 0) +lean_object* x_282; lean_object* x_283; +lean_dec(x_281); +x_282 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_245, x_2, x_248); +x_283 = lean_ctor_get(x_282, 0); +lean_inc(x_283); +if (lean_obj_tag(x_283) == 0) { -lean_object* x_468; lean_object* x_469; -x_468 = lean_ctor_get(x_466, 1); -lean_inc(x_468); -lean_dec(x_466); +lean_object* x_284; lean_object* x_285; +x_284 = lean_ctor_get(x_282, 1); +lean_inc(x_284); +lean_dec(x_282); lean_inc(x_2); -lean_inc(x_429); -x_469 = l_Lean_Meta_CheckAssignment_check___main(x_429, x_2, x_468); -if (lean_obj_tag(x_469) == 0) +lean_inc(x_245); +x_285 = l_Lean_Meta_CheckAssignment_check___main(x_245, x_2, x_284); +if (lean_obj_tag(x_285) == 0) { -lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; -x_470 = lean_ctor_get(x_469, 0); -lean_inc(x_470); -x_471 = lean_ctor_get(x_469, 1); -lean_inc(x_471); -lean_dec(x_469); -lean_inc(x_470); -x_472 = l_Lean_Meta_CheckAssignment_cache(x_429, x_470, x_2, x_471); -x_473 = lean_ctor_get(x_472, 1); -lean_inc(x_473); -lean_dec(x_472); -x_433 = x_470; -x_434 = x_473; -goto block_464; +lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; +x_286 = lean_ctor_get(x_285, 0); +lean_inc(x_286); +x_287 = lean_ctor_get(x_285, 1); +lean_inc(x_287); +lean_dec(x_285); +lean_inc(x_286); +x_288 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_245, x_286, x_2, x_287); +x_289 = lean_ctor_get(x_288, 1); +lean_inc(x_289); +lean_dec(x_288); +x_249 = x_286; +x_250 = x_289; +goto block_280; } else { -uint8_t x_474; -lean_dec(x_431); -lean_dec(x_430); -lean_dec(x_429); +uint8_t x_290; +lean_dec(x_247); +lean_dec(x_246); +lean_dec(x_245); lean_dec(x_2); lean_dec(x_1); -x_474 = !lean_is_exclusive(x_469); -if (x_474 == 0) +x_290 = !lean_is_exclusive(x_285); +if (x_290 == 0) { -return x_469; +return x_285; } else { -lean_object* x_475; lean_object* x_476; lean_object* x_477; -x_475 = lean_ctor_get(x_469, 0); -x_476 = lean_ctor_get(x_469, 1); -lean_inc(x_476); -lean_inc(x_475); -lean_dec(x_469); -x_477 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_477, 0, x_475); -lean_ctor_set(x_477, 1, x_476); -return x_477; +lean_object* x_291; lean_object* x_292; lean_object* x_293; +x_291 = lean_ctor_get(x_285, 0); +x_292 = lean_ctor_get(x_285, 1); +lean_inc(x_292); +lean_inc(x_291); +lean_dec(x_285); +x_293 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_293, 0, x_291); +lean_ctor_set(x_293, 1, x_292); +return x_293; } } } else { -lean_object* x_478; lean_object* x_479; -lean_dec(x_429); -x_478 = lean_ctor_get(x_466, 1); -lean_inc(x_478); -lean_dec(x_466); -x_479 = lean_ctor_get(x_467, 0); -lean_inc(x_479); -lean_dec(x_467); -x_433 = x_479; -x_434 = x_478; -goto block_464; +lean_object* x_294; lean_object* x_295; +lean_dec(x_245); +x_294 = lean_ctor_get(x_282, 1); +lean_inc(x_294); +lean_dec(x_282); +x_295 = lean_ctor_get(x_283, 0); +lean_inc(x_295); +lean_dec(x_283); +x_249 = x_295; +x_250 = x_294; +goto block_280; } } } -block_501: +block_317: { -lean_object* x_487; lean_object* x_488; -lean_dec(x_486); -x_487 = l_Lean_Meta_CheckAssignment_findCached(x_428, x_2, x_3); -x_488 = lean_ctor_get(x_487, 0); -lean_inc(x_488); -if (lean_obj_tag(x_488) == 0) +lean_object* x_303; lean_object* x_304; +lean_dec(x_302); +x_303 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_244, x_2, x_3); +x_304 = lean_ctor_get(x_303, 0); +lean_inc(x_304); +if (lean_obj_tag(x_304) == 0) { -lean_object* x_489; lean_object* x_490; -x_489 = lean_ctor_get(x_487, 1); -lean_inc(x_489); -lean_dec(x_487); +lean_object* x_305; lean_object* x_306; +x_305 = lean_ctor_get(x_303, 1); +lean_inc(x_305); +lean_dec(x_303); lean_inc(x_2); -lean_inc(x_428); -x_490 = l_Lean_Meta_CheckAssignment_check___main(x_428, x_2, x_489); -if (lean_obj_tag(x_490) == 0) +lean_inc(x_244); +x_306 = l_Lean_Meta_CheckAssignment_check___main(x_244, x_2, x_305); +if (lean_obj_tag(x_306) == 0) { -lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; -x_491 = lean_ctor_get(x_490, 0); -lean_inc(x_491); -x_492 = lean_ctor_get(x_490, 1); -lean_inc(x_492); -lean_dec(x_490); -lean_inc(x_491); -x_493 = l_Lean_Meta_CheckAssignment_cache(x_428, x_491, x_2, x_492); -x_494 = lean_ctor_get(x_493, 1); -lean_inc(x_494); -lean_dec(x_493); -x_431 = x_491; -x_432 = x_494; -goto block_485; +lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; +x_307 = lean_ctor_get(x_306, 0); +lean_inc(x_307); +x_308 = lean_ctor_get(x_306, 1); +lean_inc(x_308); +lean_dec(x_306); +lean_inc(x_307); +x_309 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_244, x_307, x_2, x_308); +x_310 = lean_ctor_get(x_309, 1); +lean_inc(x_310); +lean_dec(x_309); +x_247 = x_307; +x_248 = x_310; +goto block_301; } else { -uint8_t x_495; -lean_dec(x_430); -lean_dec(x_429); -lean_dec(x_428); +uint8_t x_311; +lean_dec(x_246); +lean_dec(x_245); +lean_dec(x_244); lean_dec(x_2); lean_dec(x_1); -x_495 = !lean_is_exclusive(x_490); -if (x_495 == 0) +x_311 = !lean_is_exclusive(x_306); +if (x_311 == 0) { -return x_490; +return x_306; } else { -lean_object* x_496; lean_object* x_497; lean_object* x_498; -x_496 = lean_ctor_get(x_490, 0); -x_497 = lean_ctor_get(x_490, 1); -lean_inc(x_497); -lean_inc(x_496); -lean_dec(x_490); -x_498 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_498, 0, x_496); -lean_ctor_set(x_498, 1, x_497); -return x_498; +lean_object* x_312; lean_object* x_313; lean_object* x_314; +x_312 = lean_ctor_get(x_306, 0); +x_313 = lean_ctor_get(x_306, 1); +lean_inc(x_313); +lean_inc(x_312); +lean_dec(x_306); +x_314 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_314, 0, x_312); +lean_ctor_set(x_314, 1, x_313); +return x_314; } } } else { -lean_object* x_499; lean_object* x_500; -lean_dec(x_428); -x_499 = lean_ctor_get(x_487, 1); -lean_inc(x_499); -lean_dec(x_487); -x_500 = lean_ctor_get(x_488, 0); -lean_inc(x_500); -lean_dec(x_488); -x_431 = x_500; -x_432 = x_499; -goto block_485; +lean_object* x_315; lean_object* x_316; +lean_dec(x_244); +x_315 = lean_ctor_get(x_303, 1); +lean_inc(x_315); +lean_dec(x_303); +x_316 = lean_ctor_get(x_304, 0); +lean_inc(x_316); +lean_dec(x_304); +x_247 = x_316; +x_248 = x_315; +goto block_301; } } } case 10: { -lean_object* x_506; lean_object* x_507; uint8_t x_523; -x_506 = lean_ctor_get(x_1, 1); -lean_inc(x_506); -x_523 = l_Lean_Expr_hasExprMVar(x_506); -if (x_523 == 0) +lean_object* x_322; lean_object* x_323; uint8_t x_339; +x_322 = lean_ctor_get(x_1, 1); +lean_inc(x_322); +x_339 = l_Lean_Expr_hasExprMVar(x_322); +if (x_339 == 0) { -uint8_t x_524; -x_524 = l_Lean_Expr_hasFVar(x_506); -if (x_524 == 0) +uint8_t x_340; +x_340 = l_Lean_Expr_hasFVar(x_322); +if (x_340 == 0) { lean_dec(x_2); -x_12 = x_506; -x_13 = x_3; -goto block_20; +x_4 = x_322; +x_5 = x_3; +goto block_12; } else { -lean_object* x_525; -x_525 = lean_box(0); -x_507 = x_525; -goto block_522; +lean_object* x_341; +x_341 = lean_box(0); +x_323 = x_341; +goto block_338; } } else { -lean_object* x_526; -x_526 = lean_box(0); -x_507 = x_526; -goto block_522; +lean_object* x_342; +x_342 = lean_box(0); +x_323 = x_342; +goto block_338; } -block_522: +block_338: { -lean_object* x_508; lean_object* x_509; -lean_dec(x_507); -x_508 = l_Lean_Meta_CheckAssignment_findCached(x_506, x_2, x_3); -x_509 = lean_ctor_get(x_508, 0); -lean_inc(x_509); -if (lean_obj_tag(x_509) == 0) +lean_object* x_324; lean_object* x_325; +lean_dec(x_323); +x_324 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_322, x_2, x_3); +x_325 = lean_ctor_get(x_324, 0); +lean_inc(x_325); +if (lean_obj_tag(x_325) == 0) { -lean_object* x_510; lean_object* x_511; -x_510 = lean_ctor_get(x_508, 1); -lean_inc(x_510); -lean_dec(x_508); +lean_object* x_326; lean_object* x_327; +x_326 = lean_ctor_get(x_324, 1); +lean_inc(x_326); +lean_dec(x_324); lean_inc(x_2); -lean_inc(x_506); -x_511 = l_Lean_Meta_CheckAssignment_check___main(x_506, x_2, x_510); -if (lean_obj_tag(x_511) == 0) +lean_inc(x_322); +x_327 = l_Lean_Meta_CheckAssignment_check___main(x_322, x_2, x_326); +if (lean_obj_tag(x_327) == 0) { -lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_object* x_515; -x_512 = lean_ctor_get(x_511, 0); -lean_inc(x_512); -x_513 = lean_ctor_get(x_511, 1); -lean_inc(x_513); -lean_dec(x_511); -lean_inc(x_512); -x_514 = l_Lean_Meta_CheckAssignment_cache(x_506, x_512, x_2, x_513); +lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; +x_328 = lean_ctor_get(x_327, 0); +lean_inc(x_328); +x_329 = lean_ctor_get(x_327, 1); +lean_inc(x_329); +lean_dec(x_327); +lean_inc(x_328); +x_330 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_322, x_328, x_2, x_329); lean_dec(x_2); -x_515 = lean_ctor_get(x_514, 1); -lean_inc(x_515); -lean_dec(x_514); -x_12 = x_512; -x_13 = x_515; -goto block_20; +x_331 = lean_ctor_get(x_330, 1); +lean_inc(x_331); +lean_dec(x_330); +x_4 = x_328; +x_5 = x_331; +goto block_12; } else { -uint8_t x_516; -lean_dec(x_506); +uint8_t x_332; +lean_dec(x_322); lean_dec(x_2); lean_dec(x_1); -x_516 = !lean_is_exclusive(x_511); -if (x_516 == 0) +x_332 = !lean_is_exclusive(x_327); +if (x_332 == 0) { -return x_511; +return x_327; } else { -lean_object* x_517; lean_object* x_518; lean_object* x_519; -x_517 = lean_ctor_get(x_511, 0); -x_518 = lean_ctor_get(x_511, 1); -lean_inc(x_518); -lean_inc(x_517); -lean_dec(x_511); -x_519 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_519, 0, x_517); -lean_ctor_set(x_519, 1, x_518); -return x_519; +lean_object* x_333; lean_object* x_334; lean_object* x_335; +x_333 = lean_ctor_get(x_327, 0); +x_334 = lean_ctor_get(x_327, 1); +lean_inc(x_334); +lean_inc(x_333); +lean_dec(x_327); +x_335 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_335, 0, x_333); +lean_ctor_set(x_335, 1, x_334); +return x_335; } } } else { -lean_object* x_520; lean_object* x_521; -lean_dec(x_506); +lean_object* x_336; lean_object* x_337; +lean_dec(x_322); lean_dec(x_2); -x_520 = lean_ctor_get(x_508, 1); -lean_inc(x_520); -lean_dec(x_508); -x_521 = lean_ctor_get(x_509, 0); -lean_inc(x_521); -lean_dec(x_509); -x_12 = x_521; -x_13 = x_520; -goto block_20; +x_336 = lean_ctor_get(x_324, 1); +lean_inc(x_336); +lean_dec(x_324); +x_337 = lean_ctor_get(x_325, 0); +lean_inc(x_337); +lean_dec(x_325); +x_4 = x_337; +x_5 = x_336; +goto block_12; } } } case 11: { -lean_object* x_527; lean_object* x_528; uint8_t x_544; -x_527 = lean_ctor_get(x_1, 2); -lean_inc(x_527); -x_544 = l_Lean_Expr_hasExprMVar(x_527); -if (x_544 == 0) +lean_object* x_343; lean_object* x_344; uint8_t x_360; +x_343 = lean_ctor_get(x_1, 2); +lean_inc(x_343); +x_360 = l_Lean_Expr_hasExprMVar(x_343); +if (x_360 == 0) { -uint8_t x_545; -x_545 = l_Lean_Expr_hasFVar(x_527); -if (x_545 == 0) +uint8_t x_361; +x_361 = l_Lean_Expr_hasFVar(x_343); +if (x_361 == 0) { lean_dec(x_2); -x_21 = x_527; -x_22 = x_3; -goto block_29; +x_13 = x_343; +x_14 = x_3; +goto block_21; } else { -lean_object* x_546; -x_546 = lean_box(0); -x_528 = x_546; -goto block_543; +lean_object* x_362; +x_362 = lean_box(0); +x_344 = x_362; +goto block_359; } } else { -lean_object* x_547; -x_547 = lean_box(0); -x_528 = x_547; -goto block_543; +lean_object* x_363; +x_363 = lean_box(0); +x_344 = x_363; +goto block_359; } -block_543: +block_359: { -lean_object* x_529; lean_object* x_530; -lean_dec(x_528); -x_529 = l_Lean_Meta_CheckAssignment_findCached(x_527, x_2, x_3); -x_530 = lean_ctor_get(x_529, 0); -lean_inc(x_530); -if (lean_obj_tag(x_530) == 0) +lean_object* x_345; lean_object* x_346; +lean_dec(x_344); +x_345 = l___private_Init_Lean_Meta_ExprDefEq_7__findCached(x_343, x_2, x_3); +x_346 = lean_ctor_get(x_345, 0); +lean_inc(x_346); +if (lean_obj_tag(x_346) == 0) { -lean_object* x_531; lean_object* x_532; -x_531 = lean_ctor_get(x_529, 1); -lean_inc(x_531); -lean_dec(x_529); +lean_object* x_347; lean_object* x_348; +x_347 = lean_ctor_get(x_345, 1); +lean_inc(x_347); +lean_dec(x_345); lean_inc(x_2); -lean_inc(x_527); -x_532 = l_Lean_Meta_CheckAssignment_check___main(x_527, x_2, x_531); -if (lean_obj_tag(x_532) == 0) +lean_inc(x_343); +x_348 = l_Lean_Meta_CheckAssignment_check___main(x_343, x_2, x_347); +if (lean_obj_tag(x_348) == 0) { -lean_object* x_533; lean_object* x_534; lean_object* x_535; lean_object* x_536; -x_533 = lean_ctor_get(x_532, 0); -lean_inc(x_533); -x_534 = lean_ctor_get(x_532, 1); -lean_inc(x_534); -lean_dec(x_532); -lean_inc(x_533); -x_535 = l_Lean_Meta_CheckAssignment_cache(x_527, x_533, x_2, x_534); +lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; +x_349 = lean_ctor_get(x_348, 0); +lean_inc(x_349); +x_350 = lean_ctor_get(x_348, 1); +lean_inc(x_350); +lean_dec(x_348); +lean_inc(x_349); +x_351 = l___private_Init_Lean_Meta_ExprDefEq_8__cache(x_343, x_349, x_2, x_350); lean_dec(x_2); -x_536 = lean_ctor_get(x_535, 1); -lean_inc(x_536); -lean_dec(x_535); -x_21 = x_533; -x_22 = x_536; -goto block_29; +x_352 = lean_ctor_get(x_351, 1); +lean_inc(x_352); +lean_dec(x_351); +x_13 = x_349; +x_14 = x_352; +goto block_21; } else { -uint8_t x_537; -lean_dec(x_527); +uint8_t x_353; +lean_dec(x_343); lean_dec(x_2); lean_dec(x_1); -x_537 = !lean_is_exclusive(x_532); -if (x_537 == 0) +x_353 = !lean_is_exclusive(x_348); +if (x_353 == 0) { -return x_532; +return x_348; } else { -lean_object* x_538; lean_object* x_539; lean_object* x_540; -x_538 = lean_ctor_get(x_532, 0); -x_539 = lean_ctor_get(x_532, 1); -lean_inc(x_539); -lean_inc(x_538); -lean_dec(x_532); -x_540 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_540, 0, x_538); -lean_ctor_set(x_540, 1, x_539); -return x_540; +lean_object* x_354; lean_object* x_355; lean_object* x_356; +x_354 = lean_ctor_get(x_348, 0); +x_355 = lean_ctor_get(x_348, 1); +lean_inc(x_355); +lean_inc(x_354); +lean_dec(x_348); +x_356 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_356, 0, x_354); +lean_ctor_set(x_356, 1, x_355); +return x_356; } } } else { -lean_object* x_541; lean_object* x_542; -lean_dec(x_527); +lean_object* x_357; lean_object* x_358; +lean_dec(x_343); lean_dec(x_2); -x_541 = lean_ctor_get(x_529, 1); -lean_inc(x_541); -lean_dec(x_529); -x_542 = lean_ctor_get(x_530, 0); -lean_inc(x_542); -lean_dec(x_530); -x_21 = x_542; -x_22 = x_541; -goto block_29; +x_357 = lean_ctor_get(x_345, 1); +lean_inc(x_357); +lean_dec(x_345); +x_358 = lean_ctor_get(x_346, 0); +lean_inc(x_358); +lean_dec(x_346); +x_13 = x_358; +x_14 = x_357; +goto block_21; } } } case 12: { -lean_object* x_548; lean_object* x_549; lean_object* x_550; +lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_dec(x_1); -x_548 = l_Lean_Meta_CheckAssignment_check___main___closed__1; -x_549 = l_unreachable_x21___rarg(x_548); -x_550 = lean_apply_2(x_549, x_2, x_3); -return x_550; +x_364 = l_Lean_Meta_CheckAssignment_check___main___closed__1; +x_365 = l_unreachable_x21___rarg(x_364); +x_366 = lean_apply_2(x_365, x_2, x_3); +return x_366; } default: { -lean_object* x_551; +lean_object* x_367; lean_dec(x_2); -x_551 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_551, 0, x_1); -lean_ctor_set(x_551, 1, x_3); -return x_551; +x_367 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_367, 0, x_1); +lean_ctor_set(x_367, 1, x_3); +return x_367; } } -block_11: -{ -lean_object* x_6; uint8_t x_7; -lean_inc(x_4); -x_6 = l_Lean_Meta_CheckAssignment_cache(x_1, x_4, x_2, x_5); -lean_dec(x_2); -x_7 = !lean_is_exclusive(x_6); -if (x_7 == 0) -{ -lean_object* x_8; -x_8 = lean_ctor_get(x_6, 0); -lean_dec(x_8); -lean_ctor_set(x_6, 0, x_4); -return x_6; -} -else -{ -lean_object* x_9; lean_object* x_10; -x_9 = lean_ctor_get(x_6, 1); -lean_inc(x_9); -lean_dec(x_6); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_4); -lean_ctor_set(x_10, 1, x_9); -return x_10; -} -} -block_20: +block_12: { if (lean_obj_tag(x_1) == 10) { -lean_object* x_14; lean_object* x_15; -x_14 = lean_expr_update_mdata(x_1, x_12); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_13); -return x_15; +lean_object* x_6; lean_object* x_7; +x_6 = lean_expr_update_mdata(x_1, x_4); +x_7 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_7, 0, x_6); +lean_ctor_set(x_7, 1, x_5); +return x_7; } else { -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -lean_dec(x_12); +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +lean_dec(x_4); lean_dec(x_1); -x_16 = l_Lean_Expr_Inhabited; -x_17 = l_Lean_Expr_updateMData_x21___closed__2; -x_18 = lean_panic_fn(x_17); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_18); -lean_ctor_set(x_19, 1, x_13); -return x_19; +x_8 = l_Lean_Expr_Inhabited; +x_9 = l_Lean_Expr_updateMData_x21___closed__2; +x_10 = lean_panic_fn(x_9); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_5); +return x_11; } } -block_29: +block_21: { if (lean_obj_tag(x_1) == 11) { -lean_object* x_23; lean_object* x_24; -x_23 = lean_expr_update_proj(x_1, x_21); -x_24 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_24, 0, x_23); -lean_ctor_set(x_24, 1, x_22); -return x_24; +lean_object* x_15; lean_object* x_16; +x_15 = lean_expr_update_proj(x_1, x_13); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_14); +return x_16; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_dec(x_21); +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +lean_dec(x_13); lean_dec(x_1); -x_25 = l_Lean_Expr_Inhabited; -x_26 = l_Lean_Expr_updateProj_x21___closed__2; -x_27 = lean_panic_fn(x_26); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_27); -lean_ctor_set(x_28, 1, x_22); -return x_28; +x_17 = l_Lean_Expr_Inhabited; +x_18 = l_Lean_Expr_updateProj_x21___closed__2; +x_19 = lean_panic_fn(x_18); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_14); +return x_20; } } } } +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_check___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignment_check___main___spec__3(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_7 = lean_box(x_6); +return x_7; +} +} +lean_object* l_Array_contains___at_Lean_Meta_CheckAssignment_check___main___spec__2___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +uint8_t x_3; lean_object* x_4; +x_3 = l_Array_contains___at_Lean_Meta_CheckAssignment_check___main___spec__2(x_1, x_2); +lean_dec(x_2); +lean_dec(x_1); +x_4 = lean_box(x_3); +return x_4; +} +} lean_object* l_Lean_Meta_CheckAssignment_check(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { @@ -6887,7 +7088,7 @@ x_4 = l_Lean_Meta_CheckAssignment_check___main(x_1, x_2, x_3); return x_4; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__1() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__1() { _start: { lean_object* x_1; @@ -6895,17 +7096,17 @@ x_1 = lean_mk_string("Meta"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__2() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__1; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__3() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__3() { _start: { lean_object* x_1; @@ -6913,17 +7114,17 @@ x_1 = lean_mk_string("isDefEq"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__4() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__2; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__3; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__2; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__3; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__5() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__5() { _start: { lean_object* x_1; @@ -6931,17 +7132,17 @@ x_1 = lean_mk_string("assignment"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__4; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__5; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__5; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__7() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__7() { _start: { lean_object* x_1; @@ -6949,27 +7150,27 @@ x_1 = lean_mk_string("occursCheck"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__8() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__8() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__7; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__7; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__9() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__9() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__8; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__8; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10() { _start: { lean_object* x_1; lean_object* x_2; @@ -6979,7 +7180,7 @@ lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__11() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__11() { _start: { lean_object* x_1; @@ -6987,17 +7188,17 @@ x_1 = lean_mk_string("outOfScopeFVar"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__12() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__12() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__11; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__11; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__13() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__13() { _start: { lean_object* x_1; @@ -7005,37 +7206,37 @@ x_1 = lean_mk_string(" @ "); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__14() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__14() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__13; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__13; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__14; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__14; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__16() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__16() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__12; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__12; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__17() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__17() { _start: { lean_object* x_1; @@ -7043,27 +7244,27 @@ x_1 = lean_mk_string("readOnlyMVarWithBiggerLCtx"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__18() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__18() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__17; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__17; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__19() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__19() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__18; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__18; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__20() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__20() { _start: { lean_object* x_1; @@ -7071,27 +7272,27 @@ x_1 = lean_mk_string("mvarTypeNotWellFormedInSmallerLCtx"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__21() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__21() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__20; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__20; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__22() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__22() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__21; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__21; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { switch (lean_obj_tag(x_4)) { @@ -7117,8 +7318,8 @@ return x_10; else { lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_11 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__9; -x_12 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_11, x_5, x_6); +x_11 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__9; +x_12 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_11, x_5, x_6); x_13 = lean_ctor_get(x_12, 0); lean_inc(x_13); x_14 = lean_unbox(x_13); @@ -7168,7 +7369,7 @@ lean_ctor_set(x_26, 0, x_25); x_27 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_27, 0, x_23); lean_ctor_set(x_27, 1, x_26); -x_28 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; +x_28 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; x_29 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_29, 0, x_27); lean_ctor_set(x_29, 1, x_28); @@ -7177,8 +7378,8 @@ lean_ctor_set(x_30, 0, x_3); x_31 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_31, 0, x_29); lean_ctor_set(x_31, 1, x_30); -x_32 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__8; -x_33 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_32, x_31, x_5, x_21); +x_32 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__8; +x_33 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_32, x_31, x_5, x_21); x_34 = !lean_is_exclusive(x_33); if (x_34 == 0) { @@ -7237,8 +7438,8 @@ goto block_70; else { lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_74 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__16; -x_75 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_74, x_5, x_6); +x_74 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__16; +x_75 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_74, x_5, x_6); x_76 = lean_ctor_get(x_75, 0); lean_inc(x_76); x_77 = lean_ctor_get(x_75, 1); @@ -7271,7 +7472,7 @@ lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean x_47 = l_Lean_mkFVar(x_42); x_48 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_48, 0, x_47); -x_49 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15; +x_49 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15; x_50 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_50, 0, x_48); lean_ctor_set(x_50, 1, x_49); @@ -7288,7 +7489,7 @@ lean_ctor_set(x_56, 0, x_55); x_57 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_57, 0, x_53); lean_ctor_set(x_57, 1, x_56); -x_58 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; +x_58 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; x_59 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_59, 0, x_57); lean_ctor_set(x_59, 1, x_58); @@ -7297,8 +7498,8 @@ lean_ctor_set(x_60, 0, x_3); x_61 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_61, 0, x_59); lean_ctor_set(x_61, 1, x_60); -x_62 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__12; -x_63 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_62, x_61, x_5, x_44); +x_62 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__12; +x_63 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_62, x_61, x_5, x_44); x_64 = !lean_is_exclusive(x_63); if (x_64 == 0) { @@ -7345,8 +7546,8 @@ goto block_107; else { lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; uint8_t x_115; -x_111 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__19; -x_112 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_111, x_5, x_6); +x_111 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__19; +x_112 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_111, x_5, x_6); x_113 = lean_ctor_get(x_112, 0); lean_inc(x_113); x_114 = lean_ctor_get(x_112, 1); @@ -7379,7 +7580,7 @@ lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean x_84 = l_Lean_mkMVar(x_79); x_85 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_85, 0, x_84); -x_86 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15; +x_86 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15; x_87 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_87, 0, x_85); lean_ctor_set(x_87, 1, x_86); @@ -7396,7 +7597,7 @@ lean_ctor_set(x_93, 0, x_92); x_94 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_94, 0, x_90); lean_ctor_set(x_94, 1, x_93); -x_95 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; +x_95 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; x_96 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_96, 0, x_94); lean_ctor_set(x_96, 1, x_95); @@ -7405,8 +7606,8 @@ lean_ctor_set(x_97, 0, x_3); x_98 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_98, 0, x_96); lean_ctor_set(x_98, 1, x_97); -x_99 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__18; -x_100 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_99, x_98, x_5, x_81); +x_99 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__18; +x_100 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_99, x_98, x_5, x_81); x_101 = !lean_is_exclusive(x_100); if (x_101 == 0) { @@ -7453,8 +7654,8 @@ goto block_144; else { lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; uint8_t x_152; -x_148 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__22; -x_149 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_148, x_5, x_6); +x_148 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__22; +x_149 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_148, x_5, x_6); x_150 = lean_ctor_get(x_149, 0); lean_inc(x_150); x_151 = lean_ctor_get(x_149, 1); @@ -7487,7 +7688,7 @@ lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; x_121 = l_Lean_mkMVar(x_116); x_122 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_122, 0, x_121); -x_123 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15; +x_123 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15; x_124 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_124, 0, x_122); lean_ctor_set(x_124, 1, x_123); @@ -7504,7 +7705,7 @@ lean_ctor_set(x_130, 0, x_129); x_131 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_131, 0, x_127); lean_ctor_set(x_131, 1, x_130); -x_132 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; +x_132 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; x_133 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_133, 0, x_131); lean_ctor_set(x_133, 1, x_132); @@ -7513,8 +7714,8 @@ lean_ctor_set(x_134, 0, x_3); x_135 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_135, 0, x_133); lean_ctor_set(x_135, 1, x_134); -x_136 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__21; -x_137 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_136, x_135, x_5, x_118); +x_136 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__21; +x_137 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_136, x_135, x_5, x_118); x_138 = !lean_is_exclusive(x_137); if (x_138 == 0) { @@ -7570,15 +7771,1165 @@ return x_159; } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure(x_1, x_2, x_3, x_4, x_5, x_6); +x_7 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure(x_1, x_2, x_3, x_4, x_5, x_6); lean_dec(x_5); return x_7; } } +lean_object* l___private_Init_Lean_Meta_ExprDefEq_11__visit(lean_object* x_1, lean_object* x_2) { +_start: +{ +uint8_t x_3; +x_3 = l_Lean_Expr_hasExprMVar(x_2); +if (x_3 == 0) +{ +uint8_t x_4; +x_4 = l_Lean_Expr_hasFVar(x_2); +if (x_4 == 0) +{ +uint8_t x_5; lean_object* x_6; +lean_dec(x_2); +lean_dec(x_1); +x_5 = 1; +x_6 = lean_box(x_5); +return x_6; +} +else +{ +lean_object* x_7; +x_7 = lean_apply_1(x_1, x_2); +return x_7; +} +} +else +{ +lean_object* x_8; +x_8 = lean_apply_1(x_1, x_2); +return x_8; +} +} +} +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_8 = lean_array_fget(x_3, x_5); +x_9 = l_Lean_Expr_fvarId_x21(x_8); +lean_dec(x_8); +x_10 = lean_name_eq(x_9, x_2); +lean_dec(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_5, x_11); +lean_dec(x_5); +x_5 = x_12; +goto _start; +} +else +{ +lean_dec(x_5); +return x_10; +} +} +} +} +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_8 = lean_array_fget(x_3, x_5); +x_9 = l_Lean_Expr_fvarId_x21(x_8); +lean_dec(x_8); +x_10 = lean_name_eq(x_9, x_2); +lean_dec(x_9); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_5, x_11); +lean_dec(x_5); +x_5 = x_12; +goto _start; +} +else +{ +lean_dec(x_5); +return x_10; +} +} +} +} +lean_object* l_Lean_Meta_CheckAssignmentQuick_check___main(uint8_t x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +switch (lean_obj_tag(x_8)) { +case 1: +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; +lean_dec(x_3); +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +lean_dec(x_8); +x_10 = lean_ctor_get(x_5, 1); +lean_inc(x_10); +lean_dec(x_5); +x_11 = l_Lean_LocalContext_contains(x_10, x_9); +lean_dec(x_10); +if (x_11 == 0) +{ +lean_object* x_12; +lean_inc(x_9); +x_12 = lean_local_ctx_find(x_4, x_9); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; uint8_t x_15; +x_13 = lean_array_get_size(x_7); +x_14 = lean_unsigned_to_nat(0u); +x_15 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__1(x_7, x_9, x_7, x_13, x_14); +lean_dec(x_13); +lean_dec(x_9); +if (x_15 == 0) +{ +uint8_t x_16; lean_object* x_17; +x_16 = 0; +x_17 = lean_box(x_16); +return x_17; +} +else +{ +uint8_t x_18; lean_object* x_19; +x_18 = 1; +x_19 = lean_box(x_18); +return x_19; +} +} +else +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_12, 0); +lean_inc(x_20); +lean_dec(x_12); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; lean_object* x_22; uint8_t x_23; +lean_dec(x_20); +x_21 = lean_array_get_size(x_7); +x_22 = lean_unsigned_to_nat(0u); +x_23 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__2(x_7, x_9, x_7, x_21, x_22); +lean_dec(x_21); +lean_dec(x_9); +if (x_23 == 0) +{ +uint8_t x_24; lean_object* x_25; +x_24 = 0; +x_25 = lean_box(x_24); +return x_25; +} +else +{ +uint8_t x_26; lean_object* x_27; +x_26 = 1; +x_27 = lean_box(x_26); +return x_27; +} +} +else +{ +uint8_t x_28; lean_object* x_29; +lean_dec(x_20); +lean_dec(x_9); +x_28 = 0; +x_29 = lean_box(x_28); +return x_29; +} +} +} +else +{ +uint8_t x_30; lean_object* x_31; +lean_dec(x_9); +lean_dec(x_4); +x_30 = 1; +x_31 = lean_box(x_30); +return x_31; +} +} +case 2: +{ +lean_object* x_32; lean_object* x_33; +lean_dec(x_4); +x_32 = lean_ctor_get(x_8, 0); +lean_inc(x_32); +lean_dec(x_8); +lean_inc(x_32); +lean_inc(x_3); +x_33 = lean_metavar_ctx_get_expr_assignment(x_3, x_32); +if (lean_obj_tag(x_33) == 0) +{ +uint8_t x_34; +x_34 = lean_name_eq(x_32, x_6); +if (x_34 == 0) +{ +lean_object* x_35; +lean_inc(x_3); +x_35 = lean_metavar_ctx_find_decl(x_3, x_32); +if (lean_obj_tag(x_35) == 0) +{ +uint8_t x_36; lean_object* x_37; +lean_dec(x_5); +lean_dec(x_3); +x_36 = 0; +x_37 = lean_box(x_36); +return x_37; +} +else +{ +if (x_1 == 0) +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; uint8_t x_41; +x_38 = lean_ctor_get(x_35, 0); +lean_inc(x_38); +lean_dec(x_35); +x_39 = lean_ctor_get(x_38, 1); +lean_inc(x_39); +x_40 = lean_ctor_get(x_5, 1); +lean_inc(x_40); +lean_dec(x_5); +lean_inc(x_40); +lean_inc(x_39); +x_41 = l_Lean_LocalContext_isSubPrefixOf(x_39, x_40); +if (x_41 == 0) +{ +lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_42 = lean_ctor_get(x_38, 3); +lean_inc(x_42); +x_43 = lean_ctor_get(x_3, 0); +lean_inc(x_43); +lean_dec(x_3); +x_44 = lean_nat_dec_eq(x_42, x_43); +lean_dec(x_43); +lean_dec(x_42); +if (x_44 == 0) +{ +uint8_t x_45; lean_object* x_46; +lean_dec(x_40); +lean_dec(x_39); +lean_dec(x_38); +x_45 = 0; +x_46 = lean_box(x_45); +return x_46; +} +else +{ +uint8_t x_47; +x_47 = lean_ctor_get_uint8(x_38, sizeof(void*)*4); +lean_dec(x_38); +if (x_47 == 0) +{ +if (x_2 == 0) +{ +uint8_t x_48; lean_object* x_49; +lean_dec(x_40); +lean_dec(x_39); +x_48 = 1; +x_49 = lean_box(x_48); +return x_49; +} +else +{ +uint8_t x_50; +x_50 = l_Lean_LocalContext_isSubPrefixOf(x_40, x_39); +if (x_50 == 0) +{ +uint8_t x_51; lean_object* x_52; +x_51 = 1; +x_52 = lean_box(x_51); +return x_52; +} +else +{ +uint8_t x_53; lean_object* x_54; +x_53 = 0; +x_54 = lean_box(x_53); +return x_54; +} +} +} +else +{ +uint8_t x_55; lean_object* x_56; +lean_dec(x_40); +lean_dec(x_39); +x_55 = 0; +x_56 = lean_box(x_55); +return x_56; +} +} +} +else +{ +uint8_t x_57; lean_object* x_58; +lean_dec(x_40); +lean_dec(x_39); +lean_dec(x_38); +lean_dec(x_3); +x_57 = 1; +x_58 = lean_box(x_57); +return x_58; +} +} +else +{ +uint8_t x_59; lean_object* x_60; +lean_dec(x_35); +lean_dec(x_5); +lean_dec(x_3); +x_59 = 0; +x_60 = lean_box(x_59); +return x_60; +} +} +} +else +{ +uint8_t x_61; lean_object* x_62; +lean_dec(x_32); +lean_dec(x_5); +lean_dec(x_3); +x_61 = 0; +x_62 = lean_box(x_61); +return x_62; +} +} +else +{ +uint8_t x_63; lean_object* x_64; +lean_dec(x_33); +lean_dec(x_32); +lean_dec(x_5); +lean_dec(x_3); +x_63 = 0; +x_64 = lean_box(x_63); +return x_64; +} +} +case 5: +{ +lean_object* x_65; lean_object* x_66; uint8_t x_67; +x_65 = lean_ctor_get(x_8, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_8, 1); +lean_inc(x_66); +lean_dec(x_8); +x_67 = l_Lean_Expr_hasExprMVar(x_65); +if (x_67 == 0) +{ +uint8_t x_68; +x_68 = l_Lean_Expr_hasFVar(x_65); +if (x_68 == 0) +{ +uint8_t x_69; +lean_dec(x_65); +x_69 = l_Lean_Expr_hasExprMVar(x_66); +if (x_69 == 0) +{ +uint8_t x_70; +x_70 = l_Lean_Expr_hasFVar(x_66); +if (x_70 == 0) +{ +uint8_t x_71; lean_object* x_72; +lean_dec(x_66); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_71 = 1; +x_72 = lean_box(x_71); +return x_72; +} +else +{ +x_8 = x_66; +goto _start; +} +} +else +{ +x_8 = x_66; +goto _start; +} +} +else +{ +lean_object* x_75; uint8_t x_76; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_75 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_65); +x_76 = lean_unbox(x_75); +lean_dec(x_75); +if (x_76 == 0) +{ +uint8_t x_77; lean_object* x_78; +lean_dec(x_66); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_77 = 0; +x_78 = lean_box(x_77); +return x_78; +} +else +{ +uint8_t x_79; +x_79 = l_Lean_Expr_hasExprMVar(x_66); +if (x_79 == 0) +{ +uint8_t x_80; +x_80 = l_Lean_Expr_hasFVar(x_66); +if (x_80 == 0) +{ +uint8_t x_81; lean_object* x_82; +lean_dec(x_66); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_81 = 1; +x_82 = lean_box(x_81); +return x_82; +} +else +{ +x_8 = x_66; +goto _start; +} +} +else +{ +x_8 = x_66; +goto _start; +} +} +} +} +else +{ +lean_object* x_85; uint8_t x_86; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_85 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_65); +x_86 = lean_unbox(x_85); +lean_dec(x_85); +if (x_86 == 0) +{ +uint8_t x_87; lean_object* x_88; +lean_dec(x_66); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_87 = 0; +x_88 = lean_box(x_87); +return x_88; +} +else +{ +uint8_t x_89; +x_89 = l_Lean_Expr_hasExprMVar(x_66); +if (x_89 == 0) +{ +uint8_t x_90; +x_90 = l_Lean_Expr_hasFVar(x_66); +if (x_90 == 0) +{ +uint8_t x_91; lean_object* x_92; +lean_dec(x_66); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_91 = 1; +x_92 = lean_box(x_91); +return x_92; +} +else +{ +x_8 = x_66; +goto _start; +} +} +else +{ +x_8 = x_66; +goto _start; +} +} +} +} +case 6: +{ +lean_object* x_95; lean_object* x_96; uint8_t x_97; +x_95 = lean_ctor_get(x_8, 1); +lean_inc(x_95); +x_96 = lean_ctor_get(x_8, 2); +lean_inc(x_96); +lean_dec(x_8); +x_97 = l_Lean_Expr_hasExprMVar(x_95); +if (x_97 == 0) +{ +uint8_t x_98; +x_98 = l_Lean_Expr_hasFVar(x_95); +if (x_98 == 0) +{ +uint8_t x_99; +lean_dec(x_95); +x_99 = l_Lean_Expr_hasExprMVar(x_96); +if (x_99 == 0) +{ +uint8_t x_100; +x_100 = l_Lean_Expr_hasFVar(x_96); +if (x_100 == 0) +{ +uint8_t x_101; lean_object* x_102; +lean_dec(x_96); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_101 = 1; +x_102 = lean_box(x_101); +return x_102; +} +else +{ +x_8 = x_96; +goto _start; +} +} +else +{ +x_8 = x_96; +goto _start; +} +} +else +{ +lean_object* x_105; uint8_t x_106; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_105 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_95); +x_106 = lean_unbox(x_105); +lean_dec(x_105); +if (x_106 == 0) +{ +uint8_t x_107; lean_object* x_108; +lean_dec(x_96); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_107 = 0; +x_108 = lean_box(x_107); +return x_108; +} +else +{ +uint8_t x_109; +x_109 = l_Lean_Expr_hasExprMVar(x_96); +if (x_109 == 0) +{ +uint8_t x_110; +x_110 = l_Lean_Expr_hasFVar(x_96); +if (x_110 == 0) +{ +uint8_t x_111; lean_object* x_112; +lean_dec(x_96); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_111 = 1; +x_112 = lean_box(x_111); +return x_112; +} +else +{ +x_8 = x_96; +goto _start; +} +} +else +{ +x_8 = x_96; +goto _start; +} +} +} +} +else +{ +lean_object* x_115; uint8_t x_116; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_115 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_95); +x_116 = lean_unbox(x_115); +lean_dec(x_115); +if (x_116 == 0) +{ +uint8_t x_117; lean_object* x_118; +lean_dec(x_96); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_117 = 0; +x_118 = lean_box(x_117); +return x_118; +} +else +{ +uint8_t x_119; +x_119 = l_Lean_Expr_hasExprMVar(x_96); +if (x_119 == 0) +{ +uint8_t x_120; +x_120 = l_Lean_Expr_hasFVar(x_96); +if (x_120 == 0) +{ +uint8_t x_121; lean_object* x_122; +lean_dec(x_96); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_121 = 1; +x_122 = lean_box(x_121); +return x_122; +} +else +{ +x_8 = x_96; +goto _start; +} +} +else +{ +x_8 = x_96; +goto _start; +} +} +} +} +case 7: +{ +lean_object* x_125; lean_object* x_126; uint8_t x_127; +x_125 = lean_ctor_get(x_8, 1); +lean_inc(x_125); +x_126 = lean_ctor_get(x_8, 2); +lean_inc(x_126); +lean_dec(x_8); +x_127 = l_Lean_Expr_hasExprMVar(x_125); +if (x_127 == 0) +{ +uint8_t x_128; +x_128 = l_Lean_Expr_hasFVar(x_125); +if (x_128 == 0) +{ +uint8_t x_129; +lean_dec(x_125); +x_129 = l_Lean_Expr_hasExprMVar(x_126); +if (x_129 == 0) +{ +uint8_t x_130; +x_130 = l_Lean_Expr_hasFVar(x_126); +if (x_130 == 0) +{ +uint8_t x_131; lean_object* x_132; +lean_dec(x_126); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_131 = 1; +x_132 = lean_box(x_131); +return x_132; +} +else +{ +x_8 = x_126; +goto _start; +} +} +else +{ +x_8 = x_126; +goto _start; +} +} +else +{ +lean_object* x_135; uint8_t x_136; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_135 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_125); +x_136 = lean_unbox(x_135); +lean_dec(x_135); +if (x_136 == 0) +{ +uint8_t x_137; lean_object* x_138; +lean_dec(x_126); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_137 = 0; +x_138 = lean_box(x_137); +return x_138; +} +else +{ +uint8_t x_139; +x_139 = l_Lean_Expr_hasExprMVar(x_126); +if (x_139 == 0) +{ +uint8_t x_140; +x_140 = l_Lean_Expr_hasFVar(x_126); +if (x_140 == 0) +{ +uint8_t x_141; lean_object* x_142; +lean_dec(x_126); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_141 = 1; +x_142 = lean_box(x_141); +return x_142; +} +else +{ +x_8 = x_126; +goto _start; +} +} +else +{ +x_8 = x_126; +goto _start; +} +} +} +} +else +{ +lean_object* x_145; uint8_t x_146; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_145 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_125); +x_146 = lean_unbox(x_145); +lean_dec(x_145); +if (x_146 == 0) +{ +uint8_t x_147; lean_object* x_148; +lean_dec(x_126); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_147 = 0; +x_148 = lean_box(x_147); +return x_148; +} +else +{ +uint8_t x_149; +x_149 = l_Lean_Expr_hasExprMVar(x_126); +if (x_149 == 0) +{ +uint8_t x_150; +x_150 = l_Lean_Expr_hasFVar(x_126); +if (x_150 == 0) +{ +uint8_t x_151; lean_object* x_152; +lean_dec(x_126); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_151 = 1; +x_152 = lean_box(x_151); +return x_152; +} +else +{ +x_8 = x_126; +goto _start; +} +} +else +{ +x_8 = x_126; +goto _start; +} +} +} +} +case 8: +{ +lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; uint8_t x_188; +x_155 = lean_ctor_get(x_8, 1); +lean_inc(x_155); +x_156 = lean_ctor_get(x_8, 2); +lean_inc(x_156); +x_157 = lean_ctor_get(x_8, 3); +lean_inc(x_157); +lean_dec(x_8); +x_188 = l_Lean_Expr_hasExprMVar(x_155); +if (x_188 == 0) +{ +uint8_t x_189; +x_189 = l_Lean_Expr_hasFVar(x_155); +if (x_189 == 0) +{ +lean_object* x_190; +lean_dec(x_155); +x_190 = lean_box(0); +x_158 = x_190; +goto block_187; +} +else +{ +lean_object* x_191; uint8_t x_192; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_191 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_155); +x_192 = lean_unbox(x_191); +lean_dec(x_191); +if (x_192 == 0) +{ +uint8_t x_193; lean_object* x_194; +lean_dec(x_157); +lean_dec(x_156); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_193 = 0; +x_194 = lean_box(x_193); +return x_194; +} +else +{ +lean_object* x_195; +x_195 = lean_box(0); +x_158 = x_195; +goto block_187; +} +} +} +else +{ +lean_object* x_196; uint8_t x_197; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_196 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_155); +x_197 = lean_unbox(x_196); +lean_dec(x_196); +if (x_197 == 0) +{ +uint8_t x_198; lean_object* x_199; +lean_dec(x_157); +lean_dec(x_156); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_198 = 0; +x_199 = lean_box(x_198); +return x_199; +} +else +{ +lean_object* x_200; +x_200 = lean_box(0); +x_158 = x_200; +goto block_187; +} +} +block_187: +{ +uint8_t x_159; +lean_dec(x_158); +x_159 = l_Lean_Expr_hasExprMVar(x_156); +if (x_159 == 0) +{ +uint8_t x_160; +x_160 = l_Lean_Expr_hasFVar(x_156); +if (x_160 == 0) +{ +uint8_t x_161; +lean_dec(x_156); +x_161 = l_Lean_Expr_hasExprMVar(x_157); +if (x_161 == 0) +{ +uint8_t x_162; +x_162 = l_Lean_Expr_hasFVar(x_157); +if (x_162 == 0) +{ +uint8_t x_163; lean_object* x_164; +lean_dec(x_157); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_163 = 1; +x_164 = lean_box(x_163); +return x_164; +} +else +{ +x_8 = x_157; +goto _start; +} +} +else +{ +x_8 = x_157; +goto _start; +} +} +else +{ +lean_object* x_167; uint8_t x_168; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_167 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_156); +x_168 = lean_unbox(x_167); +lean_dec(x_167); +if (x_168 == 0) +{ +uint8_t x_169; lean_object* x_170; +lean_dec(x_157); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_169 = 0; +x_170 = lean_box(x_169); +return x_170; +} +else +{ +uint8_t x_171; +x_171 = l_Lean_Expr_hasExprMVar(x_157); +if (x_171 == 0) +{ +uint8_t x_172; +x_172 = l_Lean_Expr_hasFVar(x_157); +if (x_172 == 0) +{ +uint8_t x_173; lean_object* x_174; +lean_dec(x_157); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_173 = 1; +x_174 = lean_box(x_173); +return x_174; +} +else +{ +x_8 = x_157; +goto _start; +} +} +else +{ +x_8 = x_157; +goto _start; +} +} +} +} +else +{ +lean_object* x_177; uint8_t x_178; +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +x_177 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_156); +x_178 = lean_unbox(x_177); +lean_dec(x_177); +if (x_178 == 0) +{ +uint8_t x_179; lean_object* x_180; +lean_dec(x_157); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_179 = 0; +x_180 = lean_box(x_179); +return x_180; +} +else +{ +uint8_t x_181; +x_181 = l_Lean_Expr_hasExprMVar(x_157); +if (x_181 == 0) +{ +uint8_t x_182; +x_182 = l_Lean_Expr_hasFVar(x_157); +if (x_182 == 0) +{ +uint8_t x_183; lean_object* x_184; +lean_dec(x_157); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_183 = 1; +x_184 = lean_box(x_183); +return x_184; +} +else +{ +x_8 = x_157; +goto _start; +} +} +else +{ +x_8 = x_157; +goto _start; +} +} +} +} +} +case 10: +{ +lean_object* x_201; +x_201 = lean_ctor_get(x_8, 1); +lean_inc(x_201); +lean_dec(x_8); +x_8 = x_201; +goto _start; +} +case 11: +{ +lean_object* x_203; +x_203 = lean_ctor_get(x_8, 2); +lean_inc(x_203); +lean_dec(x_8); +x_8 = x_203; +goto _start; +} +case 12: +{ +uint8_t x_205; lean_object* x_206; lean_object* x_207; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_205 = l_Bool_Inhabited; +x_206 = lean_box(x_205); +x_207 = l_unreachable_x21___rarg(x_206); +return x_207; +} +default: +{ +uint8_t x_208; lean_object* x_209; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_208 = 1; +x_209 = lean_box(x_208); +return x_209; +} +} +} +} +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_7 = lean_box(x_6); +return x_7; +} +} +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at_Lean_Meta_CheckAssignmentQuick_check___main___spec__2(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_7 = lean_box(x_6); +return x_7; +} +} +lean_object* l_Lean_Meta_CheckAssignmentQuick_check___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; uint8_t x_10; lean_object* x_11; +x_9 = lean_unbox(x_1); +lean_dec(x_1); +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_9, x_10, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_7); +lean_dec(x_6); +return x_11; +} +} +lean_object* l_Lean_Meta_CheckAssignmentQuick_check(uint8_t x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_9; +} +} +lean_object* l_Lean_Meta_CheckAssignmentQuick_check___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; uint8_t x_10; lean_object* x_11; +x_9 = lean_unbox(x_1); +lean_dec(x_1); +x_10 = lean_unbox(x_2); +lean_dec(x_2); +x_11 = l_Lean_Meta_CheckAssignmentQuick_check(x_9, x_10, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_7); +lean_dec(x_6); +return x_11; +} +} uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_checkAssignment___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { @@ -7635,246 +8986,286 @@ return x_2; lean_object* l_Lean_Meta_checkAssignment(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_6; uint8_t x_68; -x_68 = l_Lean_Expr_hasExprMVar(x_3); -if (x_68 == 0) -{ -uint8_t x_69; -x_69 = l_Lean_Expr_hasFVar(x_3); +lean_object* x_6; uint8_t x_69; +x_69 = l_Lean_Expr_hasExprMVar(x_3); if (x_69 == 0) { -lean_object* x_70; lean_object* x_71; +uint8_t x_70; +x_70 = l_Lean_Expr_hasFVar(x_3); +if (x_70 == 0) +{ +lean_object* x_71; lean_object* x_72; +lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_70 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_70, 0, x_3); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_5); -return x_71; -} -else -{ -lean_object* x_72; -x_72 = lean_box(0); -x_6 = x_72; -goto block_67; -} +x_71 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_71, 0, x_3); +x_72 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_72, 0, x_71); +lean_ctor_set(x_72, 1, x_5); +return x_72; } else { lean_object* x_73; x_73 = lean_box(0); x_6 = x_73; -goto block_67; +goto block_68; } -block_67: +} +else { -uint8_t x_7; +lean_object* x_74; +x_74 = lean_box(0); +x_6 = x_74; +goto block_68; +} +block_68: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; lean_object* x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; lean_dec(x_6); -x_7 = !lean_is_exclusive(x_5); -if (x_7 == 0) -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_7 = lean_ctor_get(x_5, 0); +lean_inc(x_7); x_8 = lean_ctor_get(x_5, 1); -x_9 = lean_ctor_get(x_5, 3); -x_10 = l_Lean_MetavarContext_getDecl(x_8, x_1); -x_11 = lean_array_get_size(x_2); -x_12 = lean_unsigned_to_nat(0u); -x_13 = l_Array_anyRangeMAux___main___at_Lean_Meta_checkAssignment___spec__1(x_2, x_10, x_2, x_11, x_12); -lean_dec(x_11); -x_14 = lean_ctor_get(x_4, 1); -x_15 = lean_ctor_get(x_4, 0); -x_16 = lean_ctor_get_uint8(x_15, sizeof(void*)*1 + 1); -lean_inc(x_2); -lean_inc(x_1); -lean_inc(x_14); -x_17 = lean_alloc_ctor(0, 4, 2); -lean_ctor_set(x_17, 0, x_14); -lean_ctor_set(x_17, 1, x_1); -lean_ctor_set(x_17, 2, x_10); -lean_ctor_set(x_17, 3, x_2); -lean_ctor_set_uint8(x_17, sizeof(void*)*4, x_16); -lean_ctor_set_uint8(x_17, sizeof(void*)*4 + 1, x_13); -x_18 = l_Lean_Meta_checkAssignment___closed__1; lean_inc(x_8); -x_19 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_19, 0, x_8); -lean_ctor_set(x_19, 1, x_9); -lean_ctor_set(x_19, 2, x_18); +x_9 = lean_ctor_get(x_5, 2); +lean_inc(x_9); +x_10 = lean_ctor_get(x_5, 3); +lean_inc(x_10); +x_11 = lean_ctor_get(x_5, 4); +lean_inc(x_11); +x_12 = lean_ctor_get(x_5, 5); +lean_inc(x_12); +x_13 = l_Lean_MetavarContext_getDecl(x_8, x_1); +x_14 = lean_array_get_size(x_2); +x_15 = lean_unsigned_to_nat(0u); +x_16 = l_Array_anyRangeMAux___main___at_Lean_Meta_checkAssignment___spec__1(x_2, x_13, x_2, x_14, x_15); +lean_dec(x_14); +x_17 = lean_ctor_get(x_4, 0); +lean_inc(x_17); +x_18 = lean_ctor_get_uint8(x_17, sizeof(void*)*1 + 1); +lean_dec(x_17); +x_19 = lean_ctor_get(x_4, 1); +lean_inc(x_19); lean_inc(x_3); -x_20 = l_Lean_Meta_CheckAssignment_check___main(x_3, x_17, x_19); -if (lean_obj_tag(x_20) == 0) -{ -uint8_t x_21; -lean_dec(x_8); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_21 = !lean_is_exclusive(x_20); +lean_inc(x_13); +lean_inc(x_19); +lean_inc(x_8); +x_20 = l_Lean_Meta_CheckAssignmentQuick_check___main(x_16, x_18, x_8, x_19, x_13, x_1, x_2, x_3); +x_21 = lean_unbox(x_20); +lean_dec(x_20); if (x_21 == 0) { -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_22 = lean_ctor_get(x_20, 0); -x_23 = lean_ctor_get(x_20, 1); -x_24 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_24, 0, x_22); -x_25 = lean_ctor_get(x_23, 0); -lean_inc(x_25); -x_26 = lean_ctor_get(x_23, 1); -lean_inc(x_26); +uint8_t x_22; +x_22 = !lean_is_exclusive(x_5); +if (x_22 == 0) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_23 = lean_ctor_get(x_5, 5); lean_dec(x_23); -lean_ctor_set(x_5, 3, x_26); -lean_ctor_set(x_5, 1, x_25); -lean_ctor_set(x_20, 1, x_5); -lean_ctor_set(x_20, 0, x_24); -return x_20; -} -else -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_27 = lean_ctor_get(x_20, 0); -x_28 = lean_ctor_get(x_20, 1); -lean_inc(x_28); -lean_inc(x_27); -lean_dec(x_20); -x_29 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_29, 0, x_27); -x_30 = lean_ctor_get(x_28, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_28, 1); -lean_inc(x_31); +x_24 = lean_ctor_get(x_5, 4); +lean_dec(x_24); +x_25 = lean_ctor_get(x_5, 3); +lean_dec(x_25); +x_26 = lean_ctor_get(x_5, 2); +lean_dec(x_26); +x_27 = lean_ctor_get(x_5, 1); +lean_dec(x_27); +x_28 = lean_ctor_get(x_5, 0); lean_dec(x_28); -lean_ctor_set(x_5, 3, x_31); -lean_ctor_set(x_5, 1, x_30); -x_32 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_32, 0, x_29); -lean_ctor_set(x_32, 1, x_5); -return x_32; -} -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_33 = lean_ctor_get(x_20, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_20, 1); -lean_inc(x_34); -lean_dec(x_20); -x_35 = lean_ctor_get(x_34, 1); -lean_inc(x_35); -lean_dec(x_34); -lean_ctor_set(x_5, 3, x_35); -x_36 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure(x_1, x_2, x_3, x_33, x_4, x_5); -return x_36; -} -} -else -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; uint8_t x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_37 = lean_ctor_get(x_5, 0); -x_38 = lean_ctor_get(x_5, 1); -x_39 = lean_ctor_get(x_5, 2); -x_40 = lean_ctor_get(x_5, 3); -x_41 = lean_ctor_get(x_5, 4); -x_42 = lean_ctor_get(x_5, 5); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_dec(x_5); -x_43 = l_Lean_MetavarContext_getDecl(x_38, x_1); -x_44 = lean_array_get_size(x_2); -x_45 = lean_unsigned_to_nat(0u); -x_46 = l_Array_anyRangeMAux___main___at_Lean_Meta_checkAssignment___spec__1(x_2, x_43, x_2, x_44, x_45); -lean_dec(x_44); -x_47 = lean_ctor_get(x_4, 1); -x_48 = lean_ctor_get(x_4, 0); -x_49 = lean_ctor_get_uint8(x_48, sizeof(void*)*1 + 1); lean_inc(x_2); lean_inc(x_1); -lean_inc(x_47); -x_50 = lean_alloc_ctor(0, 4, 2); -lean_ctor_set(x_50, 0, x_47); -lean_ctor_set(x_50, 1, x_1); -lean_ctor_set(x_50, 2, x_43); -lean_ctor_set(x_50, 3, x_2); -lean_ctor_set_uint8(x_50, sizeof(void*)*4, x_49); -lean_ctor_set_uint8(x_50, sizeof(void*)*4 + 1, x_46); -x_51 = l_Lean_Meta_checkAssignment___closed__1; -lean_inc(x_38); -x_52 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_52, 0, x_38); -lean_ctor_set(x_52, 1, x_40); -lean_ctor_set(x_52, 2, x_51); +x_29 = lean_alloc_ctor(0, 4, 2); +lean_ctor_set(x_29, 0, x_19); +lean_ctor_set(x_29, 1, x_1); +lean_ctor_set(x_29, 2, x_13); +lean_ctor_set(x_29, 3, x_2); +lean_ctor_set_uint8(x_29, sizeof(void*)*4, x_18); +lean_ctor_set_uint8(x_29, sizeof(void*)*4 + 1, x_16); +x_30 = l_Lean_Meta_checkAssignment___closed__1; +lean_inc(x_8); +x_31 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_31, 0, x_8); +lean_ctor_set(x_31, 1, x_10); +lean_ctor_set(x_31, 2, x_30); lean_inc(x_3); -x_53 = l_Lean_Meta_CheckAssignment_check___main(x_3, x_50, x_52); -if (lean_obj_tag(x_53) == 0) +x_32 = l_Lean_Meta_CheckAssignment_check___main(x_3, x_29, x_31); +if (lean_obj_tag(x_32) == 0) { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; -lean_dec(x_38); +uint8_t x_33; +lean_dec(x_8); +lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_54 = lean_ctor_get(x_53, 0); -lean_inc(x_54); -x_55 = lean_ctor_get(x_53, 1); -lean_inc(x_55); -if (lean_is_exclusive(x_53)) { - lean_ctor_release(x_53, 0); - lean_ctor_release(x_53, 1); - x_56 = x_53; -} else { - lean_dec_ref(x_53); - x_56 = lean_box(0); -} -x_57 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_57, 0, x_54); -x_58 = lean_ctor_get(x_55, 0); -lean_inc(x_58); -x_59 = lean_ctor_get(x_55, 1); -lean_inc(x_59); -lean_dec(x_55); -x_60 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_60, 0, x_37); -lean_ctor_set(x_60, 1, x_58); -lean_ctor_set(x_60, 2, x_39); -lean_ctor_set(x_60, 3, x_59); -lean_ctor_set(x_60, 4, x_41); -lean_ctor_set(x_60, 5, x_42); -if (lean_is_scalar(x_56)) { - x_61 = lean_alloc_ctor(0, 2, 0); -} else { - x_61 = x_56; -} -lean_ctor_set(x_61, 0, x_57); -lean_ctor_set(x_61, 1, x_60); -return x_61; +x_33 = !lean_is_exclusive(x_32); +if (x_33 == 0) +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_34 = lean_ctor_get(x_32, 0); +x_35 = lean_ctor_get(x_32, 1); +x_36 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_36, 0, x_34); +x_37 = lean_ctor_get(x_35, 0); +lean_inc(x_37); +x_38 = lean_ctor_get(x_35, 1); +lean_inc(x_38); +lean_dec(x_35); +lean_ctor_set(x_5, 3, x_38); +lean_ctor_set(x_5, 1, x_37); +lean_ctor_set(x_32, 1, x_5); +lean_ctor_set(x_32, 0, x_36); +return x_32; } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_62 = lean_ctor_get(x_53, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_53, 1); -lean_inc(x_63); -lean_dec(x_53); -x_64 = lean_ctor_get(x_63, 1); -lean_inc(x_64); -lean_dec(x_63); -x_65 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_65, 0, x_37); -lean_ctor_set(x_65, 1, x_38); -lean_ctor_set(x_65, 2, x_39); -lean_ctor_set(x_65, 3, x_64); -lean_ctor_set(x_65, 4, x_41); -lean_ctor_set(x_65, 5, x_42); -x_66 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure(x_1, x_2, x_3, x_62, x_4, x_65); -return x_66; +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_39 = lean_ctor_get(x_32, 0); +x_40 = lean_ctor_get(x_32, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_32); +x_41 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_41, 0, x_39); +x_42 = lean_ctor_get(x_40, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_40, 1); +lean_inc(x_43); +lean_dec(x_40); +lean_ctor_set(x_5, 3, x_43); +lean_ctor_set(x_5, 1, x_42); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_41); +lean_ctor_set(x_44, 1, x_5); +return x_44; } } +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_45 = lean_ctor_get(x_32, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_32, 1); +lean_inc(x_46); +lean_dec(x_32); +x_47 = lean_ctor_get(x_46, 1); +lean_inc(x_47); +lean_dec(x_46); +lean_ctor_set(x_5, 3, x_47); +x_48 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure(x_1, x_2, x_3, x_45, x_4, x_5); +lean_dec(x_4); +return x_48; +} +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_dec(x_5); +lean_inc(x_2); +lean_inc(x_1); +x_49 = lean_alloc_ctor(0, 4, 2); +lean_ctor_set(x_49, 0, x_19); +lean_ctor_set(x_49, 1, x_1); +lean_ctor_set(x_49, 2, x_13); +lean_ctor_set(x_49, 3, x_2); +lean_ctor_set_uint8(x_49, sizeof(void*)*4, x_18); +lean_ctor_set_uint8(x_49, sizeof(void*)*4 + 1, x_16); +x_50 = l_Lean_Meta_checkAssignment___closed__1; +lean_inc(x_8); +x_51 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_51, 0, x_8); +lean_ctor_set(x_51, 1, x_10); +lean_ctor_set(x_51, 2, x_50); +lean_inc(x_3); +x_52 = l_Lean_Meta_CheckAssignment_check___main(x_3, x_49, x_51); +if (lean_obj_tag(x_52) == 0) +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +lean_dec(x_8); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_53 = lean_ctor_get(x_52, 0); +lean_inc(x_53); +x_54 = lean_ctor_get(x_52, 1); +lean_inc(x_54); +if (lean_is_exclusive(x_52)) { + lean_ctor_release(x_52, 0); + lean_ctor_release(x_52, 1); + x_55 = x_52; +} else { + lean_dec_ref(x_52); + x_55 = lean_box(0); +} +x_56 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_56, 0, x_53); +x_57 = lean_ctor_get(x_54, 0); +lean_inc(x_57); +x_58 = lean_ctor_get(x_54, 1); +lean_inc(x_58); +lean_dec(x_54); +x_59 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_59, 0, x_7); +lean_ctor_set(x_59, 1, x_57); +lean_ctor_set(x_59, 2, x_9); +lean_ctor_set(x_59, 3, x_58); +lean_ctor_set(x_59, 4, x_11); +lean_ctor_set(x_59, 5, x_12); +if (lean_is_scalar(x_55)) { + x_60 = lean_alloc_ctor(0, 2, 0); +} else { + x_60 = x_55; +} +lean_ctor_set(x_60, 0, x_56); +lean_ctor_set(x_60, 1, x_59); +return x_60; +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_61 = lean_ctor_get(x_52, 0); +lean_inc(x_61); +x_62 = lean_ctor_get(x_52, 1); +lean_inc(x_62); +lean_dec(x_52); +x_63 = lean_ctor_get(x_62, 1); +lean_inc(x_63); +lean_dec(x_62); +x_64 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_64, 0, x_7); +lean_ctor_set(x_64, 1, x_8); +lean_ctor_set(x_64, 2, x_9); +lean_ctor_set(x_64, 3, x_63); +lean_ctor_set(x_64, 4, x_11); +lean_ctor_set(x_64, 5, x_12); +x_65 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure(x_1, x_2, x_3, x_61, x_4, x_64); +lean_dec(x_4); +return x_65; +} +} +} +else +{ +lean_object* x_66; lean_object* x_67; +lean_dec(x_19); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_66 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_66, 0, x_3); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_5); +return x_67; +} } } } @@ -7891,359 +9282,2641 @@ x_7 = lean_box(x_6); return x_7; } } -lean_object* l_Lean_Meta_checkAssignment___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_6; -x_6 = l_Lean_Meta_checkAssignment(x_1, x_2, x_3, x_4, x_5); -lean_dec(x_4); -return x_6; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: +lean_object* x_9; uint8_t x_10; +x_9 = lean_array_get_size(x_4); +x_10 = lean_nat_dec_lt(x_6, x_9); +lean_dec(x_9); +if (x_10 == 0) { -lean_object* x_10; uint8_t x_11; -x_10 = lean_array_get_size(x_5); -x_11 = lean_nat_dec_lt(x_7, x_10); -lean_dec(x_10); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_7); +lean_object* x_11; lean_dec(x_6); -x_12 = lean_apply_4(x_1, x_2, x_3, x_8, x_9); -return x_12; +lean_dec(x_5); +x_11 = l_Lean_Meta_isExprDefEqAux(x_1, x_2, x_7, x_8); +return x_11; } else { -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_13 = l_Lean_Expr_Inhabited; -x_14 = lean_array_get(x_13, x_4, x_6); -x_15 = lean_array_fget(x_5, x_7); -lean_inc(x_1); -lean_inc(x_8); -x_16 = lean_apply_4(x_1, x_14, x_15, x_8, x_9); -if (lean_obj_tag(x_16) == 0) +lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_12 = l_Lean_Expr_Inhabited; +x_13 = lean_array_get(x_12, x_3, x_5); +x_14 = lean_array_fget(x_4, x_6); +lean_inc(x_7); +x_15 = l_Lean_Meta_isExprDefEqAux(x_13, x_14, x_7, x_8); +if (lean_obj_tag(x_15) == 0) { -lean_object* x_17; uint8_t x_18; -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_unbox(x_17); -if (x_18 == 0) +lean_object* x_16; uint8_t x_17; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_unbox(x_16); +if (x_17 == 0) { -uint8_t x_19; -lean_dec(x_8); +uint8_t x_18; lean_dec(x_7); lean_dec(x_6); -lean_dec(x_3); +lean_dec(x_5); lean_dec(x_2); lean_dec(x_1); -x_19 = !lean_is_exclusive(x_16); -if (x_19 == 0) +x_18 = !lean_is_exclusive(x_15); +if (x_18 == 0) { -lean_object* x_20; -x_20 = lean_ctor_get(x_16, 0); -lean_dec(x_20); -return x_16; +lean_object* x_19; +x_19 = lean_ctor_get(x_15, 0); +lean_dec(x_19); +return x_15; } else { -lean_object* x_21; lean_object* x_22; -x_21 = lean_ctor_get(x_16, 1); -lean_inc(x_21); -lean_dec(x_16); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_17); -lean_ctor_set(x_22, 1, x_21); -return x_22; +lean_object* x_20; lean_object* x_21; +x_20 = lean_ctor_get(x_15, 1); +lean_inc(x_20); +lean_dec(x_15); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_16); +lean_ctor_set(x_21, 1, x_20); +return x_21; } } else { -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -lean_dec(x_17); -x_23 = lean_ctor_get(x_16, 1); -lean_inc(x_23); +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_dec(x_16); -x_24 = lean_unsigned_to_nat(1u); -x_25 = lean_nat_add(x_6, x_24); +x_22 = lean_ctor_get(x_15, 1); +lean_inc(x_22); +lean_dec(x_15); +x_23 = lean_unsigned_to_nat(1u); +x_24 = lean_nat_add(x_5, x_23); +lean_dec(x_5); +x_25 = lean_nat_add(x_6, x_23); lean_dec(x_6); -x_26 = lean_nat_add(x_7, x_24); -lean_dec(x_7); +x_5 = x_24; x_6 = x_25; -x_7 = x_26; -x_9 = x_23; +x_8 = x_22; goto _start; } } else { -uint8_t x_28; -lean_dec(x_8); +uint8_t x_27; lean_dec(x_7); lean_dec(x_6); -lean_dec(x_3); +lean_dec(x_5); lean_dec(x_2); lean_dec(x_1); -x_28 = !lean_is_exclusive(x_16); -if (x_28 == 0) +x_27 = !lean_is_exclusive(x_15); +if (x_27 == 0) { -return x_16; +return x_15; } else { -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_16, 0); -x_30 = lean_ctor_get(x_16, 1); -lean_inc(x_30); +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_15, 0); +x_29 = lean_ctor_get(x_15, 1); lean_inc(x_29); -lean_dec(x_16); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; +lean_inc(x_28); +lean_dec(x_15); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; } } } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_5); +lean_object* x_9; +x_9 = l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); lean_dec(x_4); -return x_10; +lean_dec(x_3); +return x_9; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_10; +lean_object* x_9; +x_9 = l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_9; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_5); +lean_object* x_9; +x_9 = l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); lean_dec(x_4); -return x_10; +lean_dec(x_3); +return x_9; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__processAssignmentFOApproxAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_13__processAssignmentFOApproxAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_7 = lean_unsigned_to_nat(0u); -x_8 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_7); -x_9 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_8); -x_10 = lean_mk_array(x_8, x_9); -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_sub(x_8, x_11); -lean_dec(x_8); -lean_inc(x_4); -x_13 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_4, x_10, x_12); -x_14 = l_Array_isEmpty___rarg(x_13); -if (x_14 == 0) +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_6 = lean_unsigned_to_nat(0u); +x_7 = l_Lean_Expr_getAppNumArgsAux___main(x_3, x_6); +x_8 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_7); +x_9 = lean_mk_array(x_7, x_8); +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_sub(x_7, x_10); +lean_dec(x_7); +lean_inc(x_3); +x_12 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_3, x_9, x_11); +x_13 = l_Array_isEmpty___rarg(x_12); +if (x_13 == 0) { -lean_object* x_15; lean_object* x_16; uint8_t x_17; -x_15 = lean_array_get_size(x_13); -x_16 = lean_array_get_size(x_3); -x_17 = lean_nat_dec_lt(x_15, x_16); +lean_object* x_14; lean_object* x_15; uint8_t x_16; +x_14 = lean_array_get_size(x_12); +x_15 = lean_array_get_size(x_2); +x_16 = lean_nat_dec_lt(x_14, x_15); +if (x_16 == 0) +{ +uint8_t x_17; +x_17 = lean_nat_dec_lt(x_15, x_14); if (x_17 == 0) { -uint8_t x_18; -x_18 = lean_nat_dec_lt(x_16, x_15); -if (x_18 == 0) +lean_object* x_18; lean_object* x_19; +lean_dec(x_15); +lean_dec(x_14); +x_18 = l_Lean_Expr_getAppFn___main(x_3); +lean_dec(x_3); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main(x_1, x_18, x_2, x_12, x_6, x_6, x_4, x_5); +lean_dec(x_12); +return x_19; +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_20 = l_Lean_Expr_getAppFn___main(x_3); +lean_dec(x_3); +x_21 = lean_nat_sub(x_14, x_15); +lean_dec(x_15); +lean_dec(x_14); +x_22 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_21, x_12, x_6, x_20); +x_23 = l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main(x_1, x_22, x_2, x_12, x_6, x_21, x_4, x_5); +lean_dec(x_12); +return x_23; +} +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_24 = lean_nat_sub(x_15, x_14); +lean_dec(x_14); +lean_dec(x_15); +x_25 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_24, x_2, x_6, x_1); +x_26 = l_Lean_Expr_getAppFn___main(x_3); +lean_dec(x_3); +x_27 = l___private_Init_Lean_Meta_ExprDefEq_12__isDefEqFOApprox___main(x_25, x_26, x_2, x_12, x_24, x_6, x_4, x_5); +lean_dec(x_12); +return x_27; +} +} +else +{ +uint8_t x_28; lean_object* x_29; lean_object* x_30; +lean_dec(x_12); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_28 = 0; +x_29 = lean_box(x_28); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_5); +return x_30; +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_13__processAssignmentFOApproxAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_ExprDefEq_13__processAssignmentFOApproxAux(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; +} +} +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_19; +x_7 = lean_ctor_get(x_5, 0); +x_8 = lean_ctor_get(x_5, 1); +x_9 = lean_ctor_get(x_5, 5); +x_10 = l_PersistentArray_empty___closed__3; +lean_inc(x_8); +lean_inc(x_7); +lean_ctor_set(x_5, 5, x_10); +lean_inc(x_4); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_13__processAssignmentFOApproxAux(x_1, x_2, x_3, x_4, x_5); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; uint8_t x_21; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +x_21 = lean_unbox(x_20); +if (x_21 == 0) +{ +lean_object* x_22; lean_object* x_23; uint8_t x_24; +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +lean_dec(x_19); +x_23 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_7, x_8, x_9, x_4, x_22); +lean_dec(x_4); +x_24 = !lean_is_exclusive(x_23); +if (x_24 == 0) +{ +lean_object* x_25; +x_25 = lean_ctor_get(x_23, 0); +lean_dec(x_25); +lean_ctor_set(x_23, 0, x_20); +return x_23; +} +else +{ +lean_object* x_26; lean_object* x_27; +x_26 = lean_ctor_get(x_23, 1); +lean_inc(x_26); +lean_dec(x_23); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_20); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +else +{ +lean_object* x_28; lean_object* x_29; +lean_dec(x_20); +x_28 = lean_ctor_get(x_19, 1); +lean_inc(x_28); +lean_dec(x_19); +x_29 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_4, x_28); +if (lean_obj_tag(x_29) == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_unbox(x_30); +if (x_31 == 0) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; +x_32 = lean_ctor_get(x_29, 1); +lean_inc(x_32); +lean_dec(x_29); +x_33 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_7, x_8, x_9, x_4, x_32); +lean_dec(x_4); +x_34 = !lean_is_exclusive(x_33); +if (x_34 == 0) +{ +lean_object* x_35; +x_35 = lean_ctor_get(x_33, 0); +lean_dec(x_35); +lean_ctor_set(x_33, 0, x_30); +return x_33; +} +else +{ +lean_object* x_36; lean_object* x_37; +x_36 = lean_ctor_get(x_33, 1); +lean_inc(x_36); +lean_dec(x_33); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_30); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +else +{ +uint8_t x_38; +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +x_38 = !lean_is_exclusive(x_29); +if (x_38 == 0) +{ +lean_object* x_39; +x_39 = lean_ctor_get(x_29, 0); +lean_dec(x_39); +return x_29; +} +else +{ +lean_object* x_40; lean_object* x_41; +x_40 = lean_ctor_get(x_29, 1); +lean_inc(x_40); +lean_dec(x_29); +x_41 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_41, 0, x_30); +lean_ctor_set(x_41, 1, x_40); +return x_41; +} +} +} +else +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_29, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_29, 1); +lean_inc(x_43); +lean_dec(x_29); +x_11 = x_42; +x_12 = x_43; +goto block_18; +} +} +} +else +{ +lean_object* x_44; lean_object* x_45; +x_44 = lean_ctor_get(x_19, 0); +lean_inc(x_44); +x_45 = lean_ctor_get(x_19, 1); +lean_inc(x_45); +lean_dec(x_19); +x_11 = x_44; +x_12 = x_45; +goto block_18; +} +block_18: +{ +lean_object* x_13; uint8_t x_14; +x_13 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_7, x_8, x_9, x_4, x_12); +lean_dec(x_4); +x_14 = !lean_is_exclusive(x_13); +if (x_14 == 0) +{ +lean_object* x_15; +x_15 = lean_ctor_get(x_13, 0); +lean_dec(x_15); +lean_ctor_set_tag(x_13, 1); +lean_ctor_set(x_13, 0, x_11); +return x_13; +} +else +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_ctor_get(x_13, 1); +lean_inc(x_16); +lean_dec(x_13); +x_17 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_17, 0, x_11); +lean_ctor_set(x_17, 1, x_16); +return x_17; +} +} +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_61; +x_46 = lean_ctor_get(x_5, 0); +x_47 = lean_ctor_get(x_5, 1); +x_48 = lean_ctor_get(x_5, 2); +x_49 = lean_ctor_get(x_5, 3); +x_50 = lean_ctor_get(x_5, 4); +x_51 = lean_ctor_get(x_5, 5); +lean_inc(x_51); +lean_inc(x_50); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_dec(x_5); +x_52 = l_PersistentArray_empty___closed__3; +lean_inc(x_47); +lean_inc(x_46); +x_53 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_53, 0, x_46); +lean_ctor_set(x_53, 1, x_47); +lean_ctor_set(x_53, 2, x_48); +lean_ctor_set(x_53, 3, x_49); +lean_ctor_set(x_53, 4, x_50); +lean_ctor_set(x_53, 5, x_52); +lean_inc(x_4); +x_61 = l___private_Init_Lean_Meta_ExprDefEq_13__processAssignmentFOApproxAux(x_1, x_2, x_3, x_4, x_53); +if (lean_obj_tag(x_61) == 0) +{ +lean_object* x_62; uint8_t x_63; +x_62 = lean_ctor_get(x_61, 0); +lean_inc(x_62); +x_63 = lean_unbox(x_62); +if (x_63 == 0) +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_64 = lean_ctor_get(x_61, 1); +lean_inc(x_64); +lean_dec(x_61); +x_65 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_46, x_47, x_51, x_4, x_64); +lean_dec(x_4); +x_66 = lean_ctor_get(x_65, 1); +lean_inc(x_66); +if (lean_is_exclusive(x_65)) { + lean_ctor_release(x_65, 0); + lean_ctor_release(x_65, 1); + x_67 = x_65; +} else { + lean_dec_ref(x_65); + x_67 = lean_box(0); +} +if (lean_is_scalar(x_67)) { + x_68 = lean_alloc_ctor(0, 2, 0); +} else { + x_68 = x_67; +} +lean_ctor_set(x_68, 0, x_62); +lean_ctor_set(x_68, 1, x_66); +return x_68; +} +else +{ +lean_object* x_69; lean_object* x_70; +lean_dec(x_62); +x_69 = lean_ctor_get(x_61, 1); +lean_inc(x_69); +lean_dec(x_61); +x_70 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_4, x_69); +if (lean_obj_tag(x_70) == 0) +{ +lean_object* x_71; uint8_t x_72; +x_71 = lean_ctor_get(x_70, 0); +lean_inc(x_71); +x_72 = lean_unbox(x_71); +if (x_72 == 0) +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_73 = lean_ctor_get(x_70, 1); +lean_inc(x_73); +lean_dec(x_70); +x_74 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_46, x_47, x_51, x_4, x_73); +lean_dec(x_4); +x_75 = lean_ctor_get(x_74, 1); +lean_inc(x_75); +if (lean_is_exclusive(x_74)) { + lean_ctor_release(x_74, 0); + lean_ctor_release(x_74, 1); + x_76 = x_74; +} else { + lean_dec_ref(x_74); + x_76 = lean_box(0); +} +if (lean_is_scalar(x_76)) { + x_77 = lean_alloc_ctor(0, 2, 0); +} else { + x_77 = x_76; +} +lean_ctor_set(x_77, 0, x_71); +lean_ctor_set(x_77, 1, x_75); +return x_77; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +lean_dec(x_51); +lean_dec(x_47); +lean_dec(x_46); +lean_dec(x_4); +x_78 = lean_ctor_get(x_70, 1); +lean_inc(x_78); +if (lean_is_exclusive(x_70)) { + lean_ctor_release(x_70, 0); + lean_ctor_release(x_70, 1); + x_79 = x_70; +} else { + lean_dec_ref(x_70); + x_79 = lean_box(0); +} +if (lean_is_scalar(x_79)) { + x_80 = lean_alloc_ctor(0, 2, 0); +} else { + x_80 = x_79; +} +lean_ctor_set(x_80, 0, x_71); +lean_ctor_set(x_80, 1, x_78); +return x_80; +} +} +else +{ +lean_object* x_81; lean_object* x_82; +x_81 = lean_ctor_get(x_70, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_70, 1); +lean_inc(x_82); +lean_dec(x_70); +x_54 = x_81; +x_55 = x_82; +goto block_60; +} +} +} +else +{ +lean_object* x_83; lean_object* x_84; +x_83 = lean_ctor_get(x_61, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_61, 1); +lean_inc(x_84); +lean_dec(x_61); +x_54 = x_83; +x_55 = x_84; +goto block_60; +} +block_60: +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_56 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_46, x_47, x_51, x_4, x_55); +lean_dec(x_4); +x_57 = lean_ctor_get(x_56, 1); +lean_inc(x_57); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_58 = x_56; +} else { + lean_dec_ref(x_56); + x_58 = lean_box(0); +} +if (lean_is_scalar(x_58)) { + x_59 = lean_alloc_ctor(1, 2, 0); +} else { + x_59 = x_58; + lean_ctor_set_tag(x_59, 1); +} +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_57); +return x_59; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__4(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_8 = l_Lean_ConstantInfo_lparams(x_4); +x_9 = lean_unsigned_to_nat(0u); +x_10 = l_List_lengthAux___main___rarg(x_8, x_9); +lean_dec(x_8); +x_11 = l_List_lengthAux___main___rarg(x_5, x_9); +x_12 = lean_nat_dec_eq(x_10, x_11); +lean_dec(x_11); +lean_dec(x_10); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_13 = lean_box(x_3); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_7); +return x_14; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_instantiate_value_lparams(x_4, x_5); +x_16 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_15); +x_17 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_16, x_6, x_7); +return x_17; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__7(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +lean_inc(x_7); +x_19 = l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at_Lean_Meta_whnfImpl___main___spec__15(x_18, x_7, x_8); +if (lean_obj_tag(x_19) == 0) +{ +uint8_t x_20; +x_20 = !lean_is_exclusive(x_19); +if (x_20 == 0) +{ +lean_object* x_21; lean_object* x_22; uint8_t x_23; +x_21 = lean_ctor_get(x_19, 0); +x_22 = lean_ctor_get(x_19, 1); +x_23 = l___private_Init_Lean_WHNF_6__isIdRhsApp(x_21); +if (x_23 == 0) +{ +lean_object* x_24; +lean_dec(x_21); +lean_dec(x_7); +lean_dec(x_1); +x_24 = lean_box(x_3); +lean_ctor_set(x_19, 0, x_24); +return x_19; +} +else +{ +lean_object* x_25; lean_object* x_26; +lean_free_object(x_19); +x_25 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_21); +x_26 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_25, x_7, x_22); +return x_26; +} +} +else +{ +lean_object* x_27; lean_object* x_28; uint8_t x_29; +x_27 = lean_ctor_get(x_19, 0); +x_28 = lean_ctor_get(x_19, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_19); +x_29 = l___private_Init_Lean_WHNF_6__isIdRhsApp(x_27); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; +lean_dec(x_27); +lean_dec(x_7); +lean_dec(x_1); +x_30 = lean_box(x_3); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_30); +lean_ctor_set(x_31, 1, x_28); +return x_31; +} +else +{ +lean_object* x_32; lean_object* x_33; +x_32 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_27); +x_33 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_32, x_7, x_28); +return x_33; +} +} +} +else +{ +uint8_t x_34; +lean_dec(x_7); +lean_dec(x_1); +x_34 = !lean_is_exclusive(x_19); +if (x_34 == 0) +{ +return x_19; +} +else +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_19, 0); +x_36 = lean_ctor_get(x_19, 1); +lean_inc(x_36); +lean_inc(x_35); +lean_dec(x_19); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_35); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_14 = lean_box(x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_instantiate_value_lparams(x_4, x_5); +x_17 = l_Lean_Expr_betaRev(x_16, x_6); +lean_dec(x_16); +x_18 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_17); +x_19 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_18, x_7, x_8); +return x_19; +} +} +} +lean_object* l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__3(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +switch (lean_obj_tag(x_4)) { +case 4: +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; lean_object* x_10; +x_7 = lean_ctor_get(x_4, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_4, 1); +lean_inc(x_8); +lean_dec(x_4); +x_9 = 0; +x_10 = l_Lean_Meta_getConstAux(x_7, x_9, x_5, x_6); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_1); +x_12 = !lean_is_exclusive(x_10); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_10, 0); +lean_dec(x_13); +x_14 = lean_box(x_3); +lean_ctor_set(x_10, 0, x_14); +return x_10; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_10, 1); +lean_inc(x_15); +lean_dec(x_10); +x_16 = lean_box(x_3); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_16); +lean_ctor_set(x_17, 1, x_15); +return x_17; +} +} +else +{ +lean_object* x_18; +x_18 = lean_ctor_get(x_11, 0); +lean_inc(x_18); +lean_dec(x_11); +if (lean_obj_tag(x_18) == 1) { lean_object* x_19; lean_object* x_20; -lean_dec(x_16); -lean_dec(x_15); -x_19 = l_Lean_Expr_getAppFn___main(x_4); -lean_dec(x_4); -x_20 = l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main(x_1, x_2, x_19, x_3, x_13, x_7, x_7, x_5, x_6); -lean_dec(x_13); +x_19 = lean_ctor_get(x_10, 1); +lean_inc(x_19); +lean_dec(x_10); +x_20 = l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__4(x_1, x_2, x_3, x_18, x_8, x_5, x_19); return x_20; } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = l_Lean_Expr_getAppFn___main(x_4); -lean_dec(x_4); -x_22 = lean_nat_sub(x_15, x_16); -lean_dec(x_16); -lean_dec(x_15); -x_23 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_22, x_13, x_7, x_21); -x_24 = l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main(x_1, x_2, x_23, x_3, x_13, x_7, x_22, x_5, x_6); -lean_dec(x_13); -return x_24; -} -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_25 = lean_nat_sub(x_16, x_15); -lean_dec(x_15); -lean_dec(x_16); -x_26 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_25, x_3, x_7, x_2); -x_27 = l_Lean_Expr_getAppFn___main(x_4); -lean_dec(x_4); -x_28 = l___private_Init_Lean_Meta_ExprDefEq_9__isDefEqFOApprox___main(x_1, x_26, x_27, x_3, x_13, x_25, x_7, x_5, x_6); -lean_dec(x_13); -return x_28; -} -} -else -{ -uint8_t x_29; lean_object* x_30; lean_object* x_31; -lean_dec(x_13); +uint8_t x_21; +lean_dec(x_18); +lean_dec(x_8); lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); lean_dec(x_1); -x_29 = 0; -x_30 = lean_box(x_29); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_30); -lean_ctor_set(x_31, 1, x_6); -return x_31; -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_10__processAssignmentFOApproxAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l___private_Init_Lean_Meta_ExprDefEq_10__processAssignmentFOApproxAux(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -return x_7; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; lean_object* x_10; -lean_inc(x_6); -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_2); -x_9 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_10__processAssignmentFOApproxAux___boxed), 6, 4); -lean_closure_set(x_9, 0, x_2); -lean_closure_set(x_9, 1, x_4); -lean_closure_set(x_9, 2, x_5); -lean_closure_set(x_9, 3, x_6); -lean_inc(x_7); -x_10 = l_Lean_Meta_try(x_9, x_7, x_8); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; uint8_t x_12; -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_unbox(x_11); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_13 = lean_ctor_get(x_10, 1); -lean_inc(x_13); -lean_dec(x_10); -lean_inc(x_1); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_14, 0, x_1); -x_15 = l_EIO_Monad___closed__1; -x_16 = lean_alloc_closure((void*)(l_ReaderT_pure___rarg___boxed), 4, 3); -lean_closure_set(x_16, 0, x_15); -lean_closure_set(x_16, 1, lean_box(0)); -lean_closure_set(x_16, 2, x_11); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_1); -x_17 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main), 8, 5); -lean_closure_set(x_17, 0, x_1); -lean_closure_set(x_17, 1, x_2); -lean_closure_set(x_17, 2, x_3); -lean_closure_set(x_17, 3, x_4); -lean_closure_set(x_17, 4, x_5); -x_18 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_14, x_2, x_3, x_6, x_16, x_17, x_7, x_13); -return x_18; -} -else -{ -uint8_t x_19; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_19 = !lean_is_exclusive(x_10); -if (x_19 == 0) -{ -lean_object* x_20; -x_20 = lean_ctor_get(x_10, 0); -lean_dec(x_20); -return x_10; -} -else -{ -lean_object* x_21; lean_object* x_22; -x_21 = lean_ctor_get(x_10, 1); -lean_inc(x_21); -lean_dec(x_10); -x_22 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_22, 0, x_11); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -uint8_t x_23; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_23 = !lean_is_exclusive(x_10); -if (x_23 == 0) +x_21 = !lean_is_exclusive(x_10); +if (x_21 == 0) { +lean_object* x_22; lean_object* x_23; +x_22 = lean_ctor_get(x_10, 0); +lean_dec(x_22); +x_23 = lean_box(x_3); +lean_ctor_set(x_10, 0, x_23); return x_10; } else { lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_10, 0); -x_25 = lean_ctor_get(x_10, 1); -lean_inc(x_25); +x_24 = lean_ctor_get(x_10, 1); lean_inc(x_24); lean_dec(x_10); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); +x_25 = lean_box(x_3); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_25); +lean_ctor_set(x_26, 1, x_24); return x_26; } } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +else +{ +uint8_t x_27; +lean_dec(x_8); +lean_dec(x_5); +lean_dec(x_1); +x_27 = !lean_is_exclusive(x_10); +if (x_27 == 0) +{ +return x_10; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_10, 0); +x_29 = lean_ctor_get(x_10, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_10); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +} +case 5: +{ +lean_object* x_31; lean_object* x_32; +x_31 = lean_ctor_get(x_4, 0); +lean_inc(x_31); +x_32 = l_Lean_Expr_getAppFn___main(x_31); +lean_dec(x_31); +if (lean_obj_tag(x_32) == 4) +{ +lean_object* x_33; lean_object* x_34; uint8_t x_35; lean_object* x_36; +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +x_34 = lean_ctor_get(x_32, 1); +lean_inc(x_34); +lean_dec(x_32); +x_35 = 0; +x_36 = l_Lean_Meta_getConstAux(x_33, x_35, x_5, x_6); +if (lean_obj_tag(x_36) == 0) +{ +lean_object* x_37; +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +if (lean_obj_tag(x_37) == 0) +{ +uint8_t x_38; +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_38 = !lean_is_exclusive(x_36); +if (x_38 == 0) +{ +lean_object* x_39; lean_object* x_40; +x_39 = lean_ctor_get(x_36, 0); +lean_dec(x_39); +x_40 = lean_box(x_3); +lean_ctor_set(x_36, 0, x_40); +return x_36; +} +else +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_41 = lean_ctor_get(x_36, 1); +lean_inc(x_41); +lean_dec(x_36); +x_42 = lean_box(x_3); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_42); +lean_ctor_set(x_43, 1, x_41); +return x_43; +} +} +else +{ +uint8_t x_44; +x_44 = !lean_is_exclusive(x_36); +if (x_44 == 0) +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; uint8_t x_52; +x_45 = lean_ctor_get(x_36, 1); +x_46 = lean_ctor_get(x_36, 0); +lean_dec(x_46); +x_47 = lean_ctor_get(x_37, 0); +lean_inc(x_47); +lean_dec(x_37); +x_48 = l_Lean_ConstantInfo_lparams(x_47); +x_49 = lean_unsigned_to_nat(0u); +x_50 = l_List_lengthAux___main___rarg(x_48, x_49); +lean_dec(x_48); +x_51 = l_List_lengthAux___main___rarg(x_34, x_49); +x_52 = lean_nat_dec_eq(x_50, x_51); +lean_dec(x_51); +lean_dec(x_50); +if (x_52 == 0) +{ +lean_object* x_53; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_53 = lean_box(x_3); +lean_ctor_set(x_36, 0, x_53); +return x_36; +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +lean_free_object(x_36); +x_54 = l_Lean_ConstantInfo_name(x_47); +x_55 = l_Lean_smartUnfoldingSuffix; +x_56 = lean_name_mk_string(x_54, x_55); +x_57 = l_Lean_Meta_getConstAux(x_56, x_35, x_5, x_45); +if (lean_obj_tag(x_57) == 0) +{ +lean_object* x_58; +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); +if (lean_obj_tag(x_58) == 0) +{ +uint8_t x_59; +x_59 = !lean_is_exclusive(x_57); +if (x_59 == 0) +{ +lean_object* x_60; lean_object* x_61; uint8_t x_62; +x_60 = lean_ctor_get(x_57, 1); +x_61 = lean_ctor_get(x_57, 0); +lean_dec(x_61); +x_62 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_62 == 0) +{ +lean_object* x_63; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_63 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_63); +return x_57; +} +else +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +lean_free_object(x_57); +x_64 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_65 = lean_mk_empty_array_with_capacity(x_64); +lean_dec(x_64); +x_66 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_65); +x_67 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5(x_1, x_2, x_3, x_47, x_34, x_66, x_5, x_60); +return x_67; +} +} +else +{ +lean_object* x_68; uint8_t x_69; +x_68 = lean_ctor_get(x_57, 1); +lean_inc(x_68); +lean_dec(x_57); +x_69 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_70 = lean_box(x_3); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_70); +lean_ctor_set(x_71, 1, x_68); +return x_71; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_72 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_73 = lean_mk_empty_array_with_capacity(x_72); +lean_dec(x_72); +x_74 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_73); +x_75 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5(x_1, x_2, x_3, x_47, x_34, x_74, x_5, x_68); +return x_75; +} +} +} +else +{ +lean_object* x_76; +x_76 = lean_ctor_get(x_58, 0); +lean_inc(x_76); +lean_dec(x_58); +switch (lean_obj_tag(x_76)) { +case 0: +{ +uint8_t x_77; +lean_dec(x_76); +x_77 = !lean_is_exclusive(x_57); +if (x_77 == 0) +{ +lean_object* x_78; lean_object* x_79; uint8_t x_80; +x_78 = lean_ctor_get(x_57, 1); +x_79 = lean_ctor_get(x_57, 0); +lean_dec(x_79); +x_80 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_80 == 0) +{ +lean_object* x_81; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_81 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_81); +return x_57; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; +lean_free_object(x_57); +x_82 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_83 = lean_mk_empty_array_with_capacity(x_82); +lean_dec(x_82); +x_84 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_83); +x_85 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6(x_1, x_2, x_3, x_47, x_34, x_84, x_5, x_78); +return x_85; +} +} +else +{ +lean_object* x_86; uint8_t x_87; +x_86 = lean_ctor_get(x_57, 1); +lean_inc(x_86); +lean_dec(x_57); +x_87 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_87 == 0) +{ +lean_object* x_88; lean_object* x_89; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_88 = lean_box(x_3); +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_88); +lean_ctor_set(x_89, 1, x_86); +return x_89; +} +else +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_90 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_91 = lean_mk_empty_array_with_capacity(x_90); +lean_dec(x_90); +x_92 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_91); +x_93 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6(x_1, x_2, x_3, x_47, x_34, x_92, x_5, x_86); +return x_93; +} +} +} +case 1: +{ +lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +lean_dec(x_47); +x_94 = lean_ctor_get(x_57, 1); +lean_inc(x_94); +lean_dec(x_57); +x_95 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_96 = lean_mk_empty_array_with_capacity(x_95); +lean_dec(x_95); +x_97 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_96); +x_98 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__7(x_1, x_2, x_3, x_76, x_34, x_97, x_5, x_94); +return x_98; +} +case 2: +{ +uint8_t x_99; +lean_dec(x_76); +x_99 = !lean_is_exclusive(x_57); +if (x_99 == 0) +{ +lean_object* x_100; lean_object* x_101; uint8_t x_102; +x_100 = lean_ctor_get(x_57, 1); +x_101 = lean_ctor_get(x_57, 0); +lean_dec(x_101); +x_102 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_102 == 0) +{ +lean_object* x_103; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_103 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_103); +return x_57; +} +else +{ +lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +lean_free_object(x_57); +x_104 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_105 = lean_mk_empty_array_with_capacity(x_104); +lean_dec(x_104); +x_106 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_105); +x_107 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8(x_1, x_2, x_3, x_47, x_34, x_106, x_5, x_100); +return x_107; +} +} +else +{ +lean_object* x_108; uint8_t x_109; +x_108 = lean_ctor_get(x_57, 1); +lean_inc(x_108); +lean_dec(x_57); +x_109 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_109 == 0) +{ +lean_object* x_110; lean_object* x_111; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_110 = lean_box(x_3); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_108); +return x_111; +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_112 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_113 = lean_mk_empty_array_with_capacity(x_112); +lean_dec(x_112); +x_114 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_113); +x_115 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8(x_1, x_2, x_3, x_47, x_34, x_114, x_5, x_108); +return x_115; +} +} +} +case 3: +{ +uint8_t x_116; +lean_dec(x_76); +x_116 = !lean_is_exclusive(x_57); +if (x_116 == 0) +{ +lean_object* x_117; lean_object* x_118; uint8_t x_119; +x_117 = lean_ctor_get(x_57, 1); +x_118 = lean_ctor_get(x_57, 0); +lean_dec(x_118); +x_119 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_119 == 0) +{ +lean_object* x_120; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_120 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_120); +return x_57; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; +lean_free_object(x_57); +x_121 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_122 = lean_mk_empty_array_with_capacity(x_121); +lean_dec(x_121); +x_123 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_122); +x_124 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9(x_1, x_2, x_3, x_47, x_34, x_123, x_5, x_117); +return x_124; +} +} +else +{ +lean_object* x_125; uint8_t x_126; +x_125 = lean_ctor_get(x_57, 1); +lean_inc(x_125); +lean_dec(x_57); +x_126 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_126 == 0) +{ +lean_object* x_127; lean_object* x_128; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_127 = lean_box(x_3); +x_128 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_128, 0, x_127); +lean_ctor_set(x_128, 1, x_125); +return x_128; +} +else +{ +lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; +x_129 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_130 = lean_mk_empty_array_with_capacity(x_129); +lean_dec(x_129); +x_131 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_130); +x_132 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9(x_1, x_2, x_3, x_47, x_34, x_131, x_5, x_125); +return x_132; +} +} +} +case 4: +{ +uint8_t x_133; +lean_dec(x_76); +x_133 = !lean_is_exclusive(x_57); +if (x_133 == 0) +{ +lean_object* x_134; lean_object* x_135; uint8_t x_136; +x_134 = lean_ctor_get(x_57, 1); +x_135 = lean_ctor_get(x_57, 0); +lean_dec(x_135); +x_136 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_136 == 0) +{ +lean_object* x_137; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_137 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_137); +return x_57; +} +else +{ +lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; +lean_free_object(x_57); +x_138 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_139 = lean_mk_empty_array_with_capacity(x_138); +lean_dec(x_138); +x_140 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_139); +x_141 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10(x_1, x_2, x_3, x_47, x_34, x_140, x_5, x_134); +return x_141; +} +} +else +{ +lean_object* x_142; uint8_t x_143; +x_142 = lean_ctor_get(x_57, 1); +lean_inc(x_142); +lean_dec(x_57); +x_143 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_143 == 0) +{ +lean_object* x_144; lean_object* x_145; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_144 = lean_box(x_3); +x_145 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_145, 0, x_144); +lean_ctor_set(x_145, 1, x_142); +return x_145; +} +else +{ +lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_146 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_147 = lean_mk_empty_array_with_capacity(x_146); +lean_dec(x_146); +x_148 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_147); +x_149 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10(x_1, x_2, x_3, x_47, x_34, x_148, x_5, x_142); +return x_149; +} +} +} +case 5: +{ +uint8_t x_150; +lean_dec(x_76); +x_150 = !lean_is_exclusive(x_57); +if (x_150 == 0) +{ +lean_object* x_151; lean_object* x_152; uint8_t x_153; +x_151 = lean_ctor_get(x_57, 1); +x_152 = lean_ctor_get(x_57, 0); +lean_dec(x_152); +x_153 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_153 == 0) +{ +lean_object* x_154; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_154 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_154); +return x_57; +} +else +{ +lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; +lean_free_object(x_57); +x_155 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_156 = lean_mk_empty_array_with_capacity(x_155); +lean_dec(x_155); +x_157 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_156); +x_158 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11(x_1, x_2, x_3, x_47, x_34, x_157, x_5, x_151); +return x_158; +} +} +else +{ +lean_object* x_159; uint8_t x_160; +x_159 = lean_ctor_get(x_57, 1); +lean_inc(x_159); +lean_dec(x_57); +x_160 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_160 == 0) +{ +lean_object* x_161; lean_object* x_162; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_161 = lean_box(x_3); +x_162 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_162, 0, x_161); +lean_ctor_set(x_162, 1, x_159); +return x_162; +} +else +{ +lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_163 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_164 = lean_mk_empty_array_with_capacity(x_163); +lean_dec(x_163); +x_165 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_164); +x_166 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11(x_1, x_2, x_3, x_47, x_34, x_165, x_5, x_159); +return x_166; +} +} +} +case 6: +{ +uint8_t x_167; +lean_dec(x_76); +x_167 = !lean_is_exclusive(x_57); +if (x_167 == 0) +{ +lean_object* x_168; lean_object* x_169; uint8_t x_170; +x_168 = lean_ctor_get(x_57, 1); +x_169 = lean_ctor_get(x_57, 0); +lean_dec(x_169); +x_170 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_170 == 0) +{ +lean_object* x_171; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_171 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_171); +return x_57; +} +else +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; +lean_free_object(x_57); +x_172 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_173 = lean_mk_empty_array_with_capacity(x_172); +lean_dec(x_172); +x_174 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_173); +x_175 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12(x_1, x_2, x_3, x_47, x_34, x_174, x_5, x_168); +return x_175; +} +} +else +{ +lean_object* x_176; uint8_t x_177; +x_176 = lean_ctor_get(x_57, 1); +lean_inc(x_176); +lean_dec(x_57); +x_177 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_177 == 0) +{ +lean_object* x_178; lean_object* x_179; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_178 = lean_box(x_3); +x_179 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_179, 0, x_178); +lean_ctor_set(x_179, 1, x_176); +return x_179; +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_180 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_181 = lean_mk_empty_array_with_capacity(x_180); +lean_dec(x_180); +x_182 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_181); +x_183 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12(x_1, x_2, x_3, x_47, x_34, x_182, x_5, x_176); +return x_183; +} +} +} +default: +{ +uint8_t x_184; +lean_dec(x_76); +x_184 = !lean_is_exclusive(x_57); +if (x_184 == 0) +{ +lean_object* x_185; lean_object* x_186; uint8_t x_187; +x_185 = lean_ctor_get(x_57, 1); +x_186 = lean_ctor_get(x_57, 0); +lean_dec(x_186); +x_187 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_187 == 0) +{ +lean_object* x_188; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_188 = lean_box(x_3); +lean_ctor_set(x_57, 0, x_188); +return x_57; +} +else +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; +lean_free_object(x_57); +x_189 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_190 = lean_mk_empty_array_with_capacity(x_189); +lean_dec(x_189); +x_191 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_190); +x_192 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13(x_1, x_2, x_3, x_47, x_34, x_191, x_5, x_185); +return x_192; +} +} +else +{ +lean_object* x_193; uint8_t x_194; +x_193 = lean_ctor_get(x_57, 1); +lean_inc(x_193); +lean_dec(x_57); +x_194 = l_Lean_ConstantInfo_hasValue(x_47); +if (x_194 == 0) +{ +lean_object* x_195; lean_object* x_196; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_195 = lean_box(x_3); +x_196 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_196, 0, x_195); +lean_ctor_set(x_196, 1, x_193); +return x_196; +} +else +{ +lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; +x_197 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_49); +x_198 = lean_mk_empty_array_with_capacity(x_197); +lean_dec(x_197); +x_199 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_198); +x_200 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13(x_1, x_2, x_3, x_47, x_34, x_199, x_5, x_193); +return x_200; +} +} +} +} +} +} +else +{ +uint8_t x_201; +lean_dec(x_47); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_201 = !lean_is_exclusive(x_57); +if (x_201 == 0) +{ +return x_57; +} +else +{ +lean_object* x_202; lean_object* x_203; lean_object* x_204; +x_202 = lean_ctor_get(x_57, 0); +x_203 = lean_ctor_get(x_57, 1); +lean_inc(x_203); +lean_inc(x_202); +lean_dec(x_57); +x_204 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_204, 0, x_202); +lean_ctor_set(x_204, 1, x_203); +return x_204; +} +} +} +} +else +{ +lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; uint8_t x_211; +x_205 = lean_ctor_get(x_36, 1); +lean_inc(x_205); +lean_dec(x_36); +x_206 = lean_ctor_get(x_37, 0); +lean_inc(x_206); +lean_dec(x_37); +x_207 = l_Lean_ConstantInfo_lparams(x_206); +x_208 = lean_unsigned_to_nat(0u); +x_209 = l_List_lengthAux___main___rarg(x_207, x_208); +lean_dec(x_207); +x_210 = l_List_lengthAux___main___rarg(x_34, x_208); +x_211 = lean_nat_dec_eq(x_209, x_210); +lean_dec(x_210); +lean_dec(x_209); +if (x_211 == 0) +{ +lean_object* x_212; lean_object* x_213; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_212 = lean_box(x_3); +x_213 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_213, 0, x_212); +lean_ctor_set(x_213, 1, x_205); +return x_213; +} +else +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; +x_214 = l_Lean_ConstantInfo_name(x_206); +x_215 = l_Lean_smartUnfoldingSuffix; +x_216 = lean_name_mk_string(x_214, x_215); +x_217 = l_Lean_Meta_getConstAux(x_216, x_35, x_5, x_205); +if (lean_obj_tag(x_217) == 0) +{ +lean_object* x_218; +x_218 = lean_ctor_get(x_217, 0); +lean_inc(x_218); +if (lean_obj_tag(x_218) == 0) +{ +lean_object* x_219; lean_object* x_220; uint8_t x_221; +x_219 = lean_ctor_get(x_217, 1); +lean_inc(x_219); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_220 = x_217; +} else { + lean_dec_ref(x_217); + x_220 = lean_box(0); +} +x_221 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_221 == 0) +{ +lean_object* x_222; lean_object* x_223; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_222 = lean_box(x_3); +if (lean_is_scalar(x_220)) { + x_223 = lean_alloc_ctor(0, 2, 0); +} else { + x_223 = x_220; +} +lean_ctor_set(x_223, 0, x_222); +lean_ctor_set(x_223, 1, x_219); +return x_223; +} +else +{ +lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; +lean_dec(x_220); +x_224 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_225 = lean_mk_empty_array_with_capacity(x_224); +lean_dec(x_224); +x_226 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_225); +x_227 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5(x_1, x_2, x_3, x_206, x_34, x_226, x_5, x_219); +return x_227; +} +} +else +{ +lean_object* x_228; +x_228 = lean_ctor_get(x_218, 0); +lean_inc(x_228); +lean_dec(x_218); +switch (lean_obj_tag(x_228)) { +case 0: +{ +lean_object* x_229; lean_object* x_230; uint8_t x_231; +lean_dec(x_228); +x_229 = lean_ctor_get(x_217, 1); +lean_inc(x_229); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_230 = x_217; +} else { + lean_dec_ref(x_217); + x_230 = lean_box(0); +} +x_231 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_231 == 0) +{ +lean_object* x_232; lean_object* x_233; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_232 = lean_box(x_3); +if (lean_is_scalar(x_230)) { + x_233 = lean_alloc_ctor(0, 2, 0); +} else { + x_233 = x_230; +} +lean_ctor_set(x_233, 0, x_232); +lean_ctor_set(x_233, 1, x_229); +return x_233; +} +else +{ +lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; +lean_dec(x_230); +x_234 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_235 = lean_mk_empty_array_with_capacity(x_234); +lean_dec(x_234); +x_236 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_235); +x_237 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6(x_1, x_2, x_3, x_206, x_34, x_236, x_5, x_229); +return x_237; +} +} +case 1: +{ +lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; +lean_dec(x_206); +x_238 = lean_ctor_get(x_217, 1); +lean_inc(x_238); +lean_dec(x_217); +x_239 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_240 = lean_mk_empty_array_with_capacity(x_239); +lean_dec(x_239); +x_241 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_240); +x_242 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__7(x_1, x_2, x_3, x_228, x_34, x_241, x_5, x_238); +return x_242; +} +case 2: +{ +lean_object* x_243; lean_object* x_244; uint8_t x_245; +lean_dec(x_228); +x_243 = lean_ctor_get(x_217, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_244 = x_217; +} else { + lean_dec_ref(x_217); + x_244 = lean_box(0); +} +x_245 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_245 == 0) +{ +lean_object* x_246; lean_object* x_247; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_246 = lean_box(x_3); +if (lean_is_scalar(x_244)) { + x_247 = lean_alloc_ctor(0, 2, 0); +} else { + x_247 = x_244; +} +lean_ctor_set(x_247, 0, x_246); +lean_ctor_set(x_247, 1, x_243); +return x_247; +} +else +{ +lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; +lean_dec(x_244); +x_248 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_249 = lean_mk_empty_array_with_capacity(x_248); +lean_dec(x_248); +x_250 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_249); +x_251 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8(x_1, x_2, x_3, x_206, x_34, x_250, x_5, x_243); +return x_251; +} +} +case 3: +{ +lean_object* x_252; lean_object* x_253; uint8_t x_254; +lean_dec(x_228); +x_252 = lean_ctor_get(x_217, 1); +lean_inc(x_252); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_253 = x_217; +} else { + lean_dec_ref(x_217); + x_253 = lean_box(0); +} +x_254 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_254 == 0) +{ +lean_object* x_255; lean_object* x_256; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_255 = lean_box(x_3); +if (lean_is_scalar(x_253)) { + x_256 = lean_alloc_ctor(0, 2, 0); +} else { + x_256 = x_253; +} +lean_ctor_set(x_256, 0, x_255); +lean_ctor_set(x_256, 1, x_252); +return x_256; +} +else +{ +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; +lean_dec(x_253); +x_257 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_258 = lean_mk_empty_array_with_capacity(x_257); +lean_dec(x_257); +x_259 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_258); +x_260 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9(x_1, x_2, x_3, x_206, x_34, x_259, x_5, x_252); +return x_260; +} +} +case 4: +{ +lean_object* x_261; lean_object* x_262; uint8_t x_263; +lean_dec(x_228); +x_261 = lean_ctor_get(x_217, 1); +lean_inc(x_261); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_262 = x_217; +} else { + lean_dec_ref(x_217); + x_262 = lean_box(0); +} +x_263 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_263 == 0) +{ +lean_object* x_264; lean_object* x_265; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_264 = lean_box(x_3); +if (lean_is_scalar(x_262)) { + x_265 = lean_alloc_ctor(0, 2, 0); +} else { + x_265 = x_262; +} +lean_ctor_set(x_265, 0, x_264); +lean_ctor_set(x_265, 1, x_261); +return x_265; +} +else +{ +lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; +lean_dec(x_262); +x_266 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_267 = lean_mk_empty_array_with_capacity(x_266); +lean_dec(x_266); +x_268 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_267); +x_269 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10(x_1, x_2, x_3, x_206, x_34, x_268, x_5, x_261); +return x_269; +} +} +case 5: +{ +lean_object* x_270; lean_object* x_271; uint8_t x_272; +lean_dec(x_228); +x_270 = lean_ctor_get(x_217, 1); +lean_inc(x_270); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_271 = x_217; +} else { + lean_dec_ref(x_217); + x_271 = lean_box(0); +} +x_272 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_272 == 0) +{ +lean_object* x_273; lean_object* x_274; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_273 = lean_box(x_3); +if (lean_is_scalar(x_271)) { + x_274 = lean_alloc_ctor(0, 2, 0); +} else { + x_274 = x_271; +} +lean_ctor_set(x_274, 0, x_273); +lean_ctor_set(x_274, 1, x_270); +return x_274; +} +else +{ +lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; +lean_dec(x_271); +x_275 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_276 = lean_mk_empty_array_with_capacity(x_275); +lean_dec(x_275); +x_277 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_276); +x_278 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11(x_1, x_2, x_3, x_206, x_34, x_277, x_5, x_270); +return x_278; +} +} +case 6: +{ +lean_object* x_279; lean_object* x_280; uint8_t x_281; +lean_dec(x_228); +x_279 = lean_ctor_get(x_217, 1); +lean_inc(x_279); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_280 = x_217; +} else { + lean_dec_ref(x_217); + x_280 = lean_box(0); +} +x_281 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_281 == 0) +{ +lean_object* x_282; lean_object* x_283; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_282 = lean_box(x_3); +if (lean_is_scalar(x_280)) { + x_283 = lean_alloc_ctor(0, 2, 0); +} else { + x_283 = x_280; +} +lean_ctor_set(x_283, 0, x_282); +lean_ctor_set(x_283, 1, x_279); +return x_283; +} +else +{ +lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; +lean_dec(x_280); +x_284 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_285 = lean_mk_empty_array_with_capacity(x_284); +lean_dec(x_284); +x_286 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_285); +x_287 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12(x_1, x_2, x_3, x_206, x_34, x_286, x_5, x_279); +return x_287; +} +} +default: +{ +lean_object* x_288; lean_object* x_289; uint8_t x_290; +lean_dec(x_228); +x_288 = lean_ctor_get(x_217, 1); +lean_inc(x_288); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_289 = x_217; +} else { + lean_dec_ref(x_217); + x_289 = lean_box(0); +} +x_290 = l_Lean_ConstantInfo_hasValue(x_206); +if (x_290 == 0) +{ +lean_object* x_291; lean_object* x_292; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_291 = lean_box(x_3); +if (lean_is_scalar(x_289)) { + x_292 = lean_alloc_ctor(0, 2, 0); +} else { + x_292 = x_289; +} +lean_ctor_set(x_292, 0, x_291); +lean_ctor_set(x_292, 1, x_288); +return x_292; +} +else +{ +lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +lean_dec(x_289); +x_293 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_208); +x_294 = lean_mk_empty_array_with_capacity(x_293); +lean_dec(x_293); +x_295 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_4, x_294); +x_296 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13(x_1, x_2, x_3, x_206, x_34, x_295, x_5, x_288); +return x_296; +} +} +} +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; +lean_dec(x_206); +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_297 = lean_ctor_get(x_217, 0); +lean_inc(x_297); +x_298 = lean_ctor_get(x_217, 1); +lean_inc(x_298); +if (lean_is_exclusive(x_217)) { + lean_ctor_release(x_217, 0); + lean_ctor_release(x_217, 1); + x_299 = x_217; +} else { + lean_dec_ref(x_217); + x_299 = lean_box(0); +} +if (lean_is_scalar(x_299)) { + x_300 = lean_alloc_ctor(1, 2, 0); +} else { + x_300 = x_299; +} +lean_ctor_set(x_300, 0, x_297); +lean_ctor_set(x_300, 1, x_298); +return x_300; +} +} +} +} +} +else +{ +uint8_t x_301; +lean_dec(x_34); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_301 = !lean_is_exclusive(x_36); +if (x_301 == 0) +{ +return x_36; +} +else +{ +lean_object* x_302; lean_object* x_303; lean_object* x_304; +x_302 = lean_ctor_get(x_36, 0); +x_303 = lean_ctor_get(x_36, 1); +lean_inc(x_303); +lean_inc(x_302); +lean_dec(x_36); +x_304 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_304, 0, x_302); +lean_ctor_set(x_304, 1, x_303); +return x_304; +} +} +} +else +{ +lean_object* x_305; lean_object* x_306; +lean_dec(x_32); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_305 = lean_box(x_3); +x_306 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_306, 0, x_305); +lean_ctor_set(x_306, 1, x_6); +return x_306; +} +} +default: +{ +lean_object* x_307; lean_object* x_308; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_307 = lean_box(x_3); +x_308 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_308, 0, x_307); +lean_ctor_set(x_308, 1, x_6); +return x_308; +} +} +} +} +lean_object* l_Lean_Meta_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__2(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_9; -x_9 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_object* x_7; +x_7 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__3(x_1, x_2, x_3, x_4, x_5, x_6); +return x_7; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_3); +lean_inc(x_1); +x_6 = l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__1(x_1, x_2, x_3, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_unbox(x_7); +if (x_8 == 0) +{ +lean_object* x_9; uint8_t x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_6, 1); +lean_inc(x_9); +lean_dec(x_6); +x_10 = lean_unbox(x_7); +lean_dec(x_7); +x_11 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__3(x_1, x_2, x_10, x_3, x_4, x_9); +return x_11; +} +else +{ +uint8_t x_12; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_12 = !lean_is_exclusive(x_6); +if (x_12 == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_6, 0); +lean_dec(x_13); +return x_6; +} +else +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_6, 1); +lean_inc(x_14); +lean_dec(x_6); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_7); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +} +else +{ +uint8_t x_16; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_16 = !lean_is_exclusive(x_6); +if (x_16 == 0) +{ +return x_6; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_6, 0); +x_18 = lean_ctor_get(x_6, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_6); +x_19 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +} +} +} +lean_object* l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; +} +} +lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +uint8_t x_8; lean_object* x_9; +x_8 = lean_unbox(x_3); +lean_dec(x_3); +x_9 = l___private_Init_Lean_WHNF_8__deltaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__4(x_1, x_2, x_8, x_4, x_5, x_6, x_7); +lean_dec(x_2); return x_9; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__simpAssignmentArgAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__5(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__6(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__7(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__8(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__9(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__10(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__11(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__12(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_3); +lean_dec(x_3); +x_10 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__13(x_1, x_2, x_9, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_10; +} +} +lean_object* l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +uint8_t x_7; lean_object* x_8; +x_7 = lean_unbox(x_3); +lean_dec(x_3); +x_8 = l_Lean_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__3(x_1, x_2, x_7, x_4, x_5, x_6); +lean_dec(x_2); +return x_8; +} +} +lean_object* l_Lean_Meta_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +uint8_t x_7; lean_object* x_8; +x_7 = lean_unbox(x_3); +lean_dec(x_3); +x_8 = l_Lean_Meta_unfoldDefinitionAux___at___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___spec__2(x_1, x_2, x_7, x_4, x_5, x_6); +lean_dec(x_2); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_5); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_2); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_15__simpAssignmentArgAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { switch (lean_obj_tag(x_1)) { @@ -8362,15 +12035,15 @@ return x_24; } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_12__simpAssignmentArgAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_15__simpAssignmentArgAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l___private_Init_Lean_Meta_ExprDefEq_12__simpAssignmentArgAux___main(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_ExprDefEq_15__simpAssignmentArgAux___main(x_1, x_2, x_3); return x_4; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_13__simpAssignmentArg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_16__simpAssignmentArg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; uint8_t x_5; @@ -8380,7 +12053,7 @@ lean_dec(x_4); if (x_5 == 0) { lean_object* x_6; -x_6 = l___private_Init_Lean_Meta_ExprDefEq_12__simpAssignmentArgAux___main(x_1, x_2, x_3); +x_6 = l___private_Init_Lean_Meta_ExprDefEq_15__simpAssignmentArgAux___main(x_1, x_2, x_3); return x_6; } else @@ -8392,39 +12065,121 @@ lean_inc(x_8); x_9 = lean_ctor_get(x_7, 1); lean_inc(x_9); lean_dec(x_7); -x_10 = l___private_Init_Lean_Meta_ExprDefEq_12__simpAssignmentArgAux___main(x_8, x_2, x_9); +x_10 = l___private_Init_Lean_Meta_ExprDefEq_15__simpAssignmentArgAux___main(x_8, x_2, x_9); return x_10; } } } -uint8_t l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__1(lean_object* x_1, lean_object* x_2) { +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_3; uint8_t x_4; -x_3 = lean_ctor_get(x_1, 1); -x_4 = l_Lean_LocalContext_containsFVar(x_3, x_2); -return x_4; +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_8 = lean_array_fget(x_3, x_5); +x_9 = lean_ctor_get(x_1, 1); +x_10 = l_Lean_LocalContext_containsFVar(x_9, x_8); +lean_dec(x_8); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_add(x_5, x_11); +lean_dec(x_5); +x_5 = x_12; +goto _start; +} +else +{ +lean_dec(x_5); +return x_10; } } -uint8_t l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__2(lean_object* x_1, lean_object* x_2) { +} +} +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -uint8_t x_3; -x_3 = lean_expr_eqv(x_2, x_1); -return x_3; +uint8_t x_8; +x_8 = lean_nat_dec_lt(x_7, x_6); +if (x_8 == 0) +{ +uint8_t x_9; +lean_dec(x_7); +x_9 = 0; +return x_9; +} +else +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_array_fget(x_5, x_7); +x_11 = lean_expr_eqv(x_10, x_4); +lean_dec(x_10); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_unsigned_to_nat(1u); +x_13 = lean_nat_add(x_7, x_12); +lean_dec(x_7); +x_3 = lean_box(0); +x_7 = x_13; +goto _start; +} +else +{ +lean_dec(x_7); +return x_11; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1() { +} +} +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Meta_tracer; -x_2 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_3 = l_Lean_simpleMonadTracerAdapter___rarg(x_1, x_2); -return x_3; +uint8_t x_9; +x_9 = lean_nat_dec_lt(x_8, x_7); +if (x_9 == 0) +{ +uint8_t x_10; +lean_dec(x_8); +x_10 = 0; +return x_10; +} +else +{ +lean_object* x_11; uint8_t x_12; +x_11 = lean_array_fget(x_6, x_8); +x_12 = lean_expr_eqv(x_11, x_4); +lean_dec(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_unsigned_to_nat(1u); +x_14 = lean_nat_add(x_8, x_13); +lean_dec(x_8); +x_3 = lean_box(0); +x_5 = lean_box(0); +x_8 = x_14; +goto _start; +} +else +{ +lean_dec(x_8); +return x_12; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__2() { +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__1() { _start: { lean_object* x_1; @@ -8432,27 +12187,27 @@ x_1 = lean_mk_string("typeMismatch"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__2; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__5() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__4() { _start: { lean_object* x_1; @@ -8460,1528 +12215,1552 @@ x_1 = lean_mk_string(" : "); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__6() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__5() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__5; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__4; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__6; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__5; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_11; uint8_t x_12; -x_11 = lean_array_get_size(x_8); -x_12 = lean_nat_dec_lt(x_7, x_11); -if (x_12 == 0) +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_5); +x_9 = lean_nat_dec_lt(x_4, x_8); +if (x_9 == 0) { -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; lean_object* x_20; -lean_dec(x_7); -x_13 = lean_ctor_get(x_9, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_9, 1); -lean_inc(x_14); -x_15 = lean_ctor_get(x_9, 2); -lean_inc(x_15); -x_16 = l_Lean_Meta_instantiateMVars(x_6, x_9, x_10); -x_17 = lean_ctor_get(x_16, 0); -lean_inc(x_17); -x_18 = lean_ctor_get(x_16, 1); -lean_inc(x_18); -lean_dec(x_16); -x_19 = lean_ctor_get_uint8(x_13, sizeof(void*)*1); -if (x_19 == 0) -{ -lean_object* x_443; -x_443 = lean_box(0); -x_20 = x_443; -goto block_442; -} -else -{ -uint8_t x_444; -x_444 = l_Array_isEmpty___rarg(x_8); -if (x_444 == 0) -{ -lean_object* x_445; -x_445 = lean_box(0); -x_20 = x_445; -goto block_442; -} -else -{ -lean_object* x_446; uint8_t x_447; -x_446 = l_Lean_Expr_getAppFn___main(x_17); -x_447 = lean_expr_eqv(x_446, x_4); -lean_dec(x_446); -if (x_447 == 0) -{ -lean_object* x_448; -x_448 = lean_box(0); -x_20 = x_448; -goto block_442; -} -else -{ -lean_object* x_449; -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_11); -lean_dec(x_5); -x_449 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_8, x_17, x_9, x_18); -return x_449; -} -} -} -block_442: -{ -lean_object* x_21; lean_object* x_22; -lean_dec(x_20); -x_21 = l_Lean_Expr_mvarId_x21(x_4); -lean_inc(x_17); -lean_inc(x_8); -lean_inc(x_21); -x_22 = l_Lean_Meta_checkAssignment(x_21, x_8, x_17, x_9, x_18); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -if (lean_obj_tag(x_23) == 0) -{ -lean_dec(x_21); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_11); -lean_dec(x_5); -if (x_19 == 0) -{ -uint8_t x_24; -lean_dec(x_17); -lean_dec(x_9); -lean_dec(x_8); +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; uint8_t x_16; lean_object* x_17; lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_24 = !lean_is_exclusive(x_22); -if (x_24 == 0) +x_10 = lean_ctor_get(x_6, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_6, 1); +lean_inc(x_11); +x_12 = lean_ctor_get(x_6, 2); +lean_inc(x_12); +x_13 = l_Lean_Meta_instantiateMVars(x_3, x_6, x_7); +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_16 = lean_ctor_get_uint8(x_10, sizeof(void*)*1); +if (x_16 == 0) { -lean_object* x_25; uint8_t x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_22, 0); -lean_dec(x_25); +lean_object* x_359; +x_359 = lean_box(0); +x_17 = x_359; +goto block_358; +} +else +{ +uint8_t x_360; +x_360 = l_Array_isEmpty___rarg(x_5); +if (x_360 == 0) +{ +lean_object* x_361; +x_361 = lean_box(0); +x_17 = x_361; +goto block_358; +} +else +{ +lean_object* x_362; uint8_t x_363; +x_362 = l_Lean_Expr_getAppFn___main(x_14); +x_363 = lean_expr_eqv(x_362, x_1); +lean_dec(x_362); +if (x_363 == 0) +{ +lean_object* x_364; +x_364 = lean_box(0); +x_17 = x_364; +goto block_358; +} +else +{ +lean_object* x_365; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +x_365 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_5, x_14, x_6, x_15); +lean_dec(x_5); +return x_365; +} +} +} +block_358: +{ +lean_object* x_18; lean_object* x_19; +lean_dec(x_17); +x_18 = l_Lean_Expr_mvarId_x21(x_1); +lean_inc(x_6); +lean_inc(x_14); +lean_inc(x_5); +lean_inc(x_18); +x_19 = l_Lean_Meta_checkAssignment(x_18, x_5, x_14, x_6, x_15); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +if (lean_obj_tag(x_20) == 0) +{ +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +if (x_16 == 0) +{ +uint8_t x_21; +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_21 = !lean_is_exclusive(x_19); +if (x_21 == 0) +{ +lean_object* x_22; uint8_t x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_19, 0); +lean_dec(x_22); +x_23 = 0; +x_24 = lean_box(x_23); +lean_ctor_set(x_19, 0, x_24); +return x_19; +} +else +{ +lean_object* x_25; uint8_t x_26; lean_object* x_27; lean_object* x_28; +x_25 = lean_ctor_get(x_19, 1); +lean_inc(x_25); +lean_dec(x_19); x_26 = 0; x_27 = lean_box(x_26); -lean_ctor_set(x_22, 0, x_27); -return x_22; -} -else -{ -lean_object* x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; -x_28 = lean_ctor_get(x_22, 1); -lean_inc(x_28); -lean_dec(x_22); -x_29 = 0; -x_30 = lean_box(x_29); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_30); -lean_ctor_set(x_31, 1, x_28); -return x_31; +x_28 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_28, 0, x_27); +lean_ctor_set(x_28, 1, x_25); +return x_28; } } else { -lean_object* x_32; lean_object* x_33; -x_32 = lean_ctor_get(x_22, 1); +lean_object* x_29; lean_object* x_30; +x_29 = lean_ctor_get(x_19, 1); +lean_inc(x_29); +lean_dec(x_19); +x_30 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_5, x_14, x_6, x_29); +lean_dec(x_5); +return x_30; +} +} +else +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_31 = lean_ctor_get(x_19, 1); +lean_inc(x_31); +lean_dec(x_19); +x_32 = lean_ctor_get(x_20, 0); lean_inc(x_32); -lean_dec(x_22); -x_33 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_8, x_17, x_9, x_32); -return x_33; -} -} -else +lean_dec(x_20); +lean_inc(x_6); +lean_inc(x_5); +x_33 = l_Lean_Meta_mkLambda(x_5, x_32, x_6, x_31); +if (lean_obj_tag(x_33) == 0) { -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_22, 1); +lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_37; +x_34 = lean_ctor_get(x_33, 0); lean_inc(x_34); -lean_dec(x_22); -x_35 = lean_ctor_get(x_23, 0); +x_35 = lean_ctor_get(x_33, 1); lean_inc(x_35); -lean_dec(x_23); -lean_inc(x_9); -lean_inc(x_8); -x_36 = l_Lean_Meta_mkLambda(x_8, x_35, x_9, x_34); -if (lean_obj_tag(x_36) == 0) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; uint8_t x_43; -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -x_39 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__1___boxed), 2, 1); -lean_closure_set(x_39, 0, x_5); -x_40 = l_Id_Monad; -x_41 = lean_unsigned_to_nat(0u); -lean_inc(x_8); -x_42 = l_Array_anyRangeMAux___main___rarg(x_40, x_8, x_11, lean_box(0), x_39, x_41); -x_43 = lean_unbox(x_42); -lean_dec(x_42); -if (x_43 == 0) -{ -lean_object* x_44; lean_object* x_45; -lean_dec(x_17); +lean_dec(x_33); +x_36 = lean_unsigned_to_nat(0u); +x_37 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__1(x_2, x_5, x_5, x_8, x_36); lean_dec(x_8); -lean_dec(x_3); -x_44 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 1); -lean_closure_set(x_44, 0, x_1); -lean_inc(x_9); -lean_inc(x_4); -lean_inc(x_44); -x_45 = l_Lean_Meta_inferTypeAuxAux___main(x_44, x_4, x_9, x_38); -if (lean_obj_tag(x_45) == 0) +if (x_37 == 0) { -lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_46 = lean_ctor_get(x_45, 0); -lean_inc(x_46); -x_47 = lean_ctor_get(x_45, 1); -lean_inc(x_47); -lean_dec(x_45); -lean_inc(x_9); -lean_inc(x_37); -x_48 = l_Lean_Meta_inferTypeAuxAux___main(x_44, x_37, x_9, x_47); -if (lean_obj_tag(x_48) == 0) +lean_object* x_38; +lean_dec(x_14); +lean_dec(x_5); +lean_inc(x_6); +lean_inc(x_1); +x_38 = l_Lean_Meta_inferType(x_1, x_6, x_35); +if (lean_obj_tag(x_38) == 0) { -lean_object* x_49; lean_object* x_50; uint8_t x_51; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = !lean_is_exclusive(x_13); -if (x_51 == 0) +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +x_40 = lean_ctor_get(x_38, 1); +lean_inc(x_40); +lean_dec(x_38); +lean_inc(x_6); +lean_inc(x_34); +x_41 = l_Lean_Meta_inferType(x_34, x_6, x_40); +if (lean_obj_tag(x_41) == 0) { -uint8_t x_52; lean_object* x_53; lean_object* x_54; -x_52 = 1; -lean_ctor_set_uint8(x_13, sizeof(void*)*1 + 4, x_52); -x_53 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_53, 0, x_13); -lean_ctor_set(x_53, 1, x_14); -lean_ctor_set(x_53, 2, x_15); -lean_inc(x_49); -lean_inc(x_46); -x_54 = lean_apply_4(x_2, x_46, x_49, x_53, x_50); -if (lean_obj_tag(x_54) == 0) +lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_42 = lean_ctor_get(x_41, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_41, 1); +lean_inc(x_43); +lean_dec(x_41); +x_44 = !lean_is_exclusive(x_10); +if (x_44 == 0) { -lean_object* x_55; uint8_t x_56; -x_55 = lean_ctor_get(x_54, 0); -lean_inc(x_55); -x_56 = lean_unbox(x_55); -if (x_56 == 0) +uint8_t x_45; lean_object* x_46; lean_object* x_47; +x_45 = 1; +lean_ctor_set_uint8(x_10, sizeof(void*)*1 + 5, x_45); +x_46 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_46, 0, x_10); +lean_ctor_set(x_46, 1, x_11); +lean_ctor_set(x_46, 2, x_12); +lean_inc(x_42); +lean_inc(x_39); +x_47 = l_Lean_Meta_isExprDefEqAux(x_39, x_42, x_46, x_43); +if (lean_obj_tag(x_47) == 0) { -uint8_t x_57; -lean_dec(x_21); -x_57 = !lean_is_exclusive(x_54); -if (x_57 == 0) +lean_object* x_48; uint8_t x_49; +x_48 = lean_ctor_get(x_47, 0); +lean_inc(x_48); +x_49 = lean_unbox(x_48); +if (x_49 == 0) { -lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; -x_58 = lean_ctor_get(x_54, 1); -x_59 = lean_ctor_get(x_54, 0); -lean_dec(x_59); -x_60 = lean_ctor_get(x_58, 4); -lean_inc(x_60); -x_61 = lean_ctor_get_uint8(x_60, sizeof(void*)*1); +uint8_t x_50; +lean_dec(x_18); +x_50 = !lean_is_exclusive(x_47); +if (x_50 == 0) +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; uint8_t x_54; +x_51 = lean_ctor_get(x_47, 1); +x_52 = lean_ctor_get(x_47, 0); +lean_dec(x_52); +x_53 = lean_ctor_get(x_51, 4); +lean_inc(x_53); +x_54 = lean_ctor_get_uint8(x_53, sizeof(void*)*1); +lean_dec(x_53); +if (x_54 == 0) +{ +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +return x_47; +} +else +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; +lean_free_object(x_47); +x_55 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3; +x_56 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_55, x_6, x_51); +x_57 = lean_ctor_get(x_56, 0); +lean_inc(x_57); +x_58 = lean_unbox(x_57); +lean_dec(x_57); +if (x_58 == 0) +{ +uint8_t x_59; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_59 = !lean_is_exclusive(x_56); +if (x_59 == 0) +{ +lean_object* x_60; +x_60 = lean_ctor_get(x_56, 0); lean_dec(x_60); -if (x_61 == 0) -{ -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -return x_54; +lean_ctor_set(x_56, 0, x_48); +return x_56; } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -lean_free_object(x_54); -x_62 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_63 = l_Lean_Meta_tracer; -x_64 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4; -x_65 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_62, x_63, x_64); -lean_inc(x_9); -x_66 = lean_apply_2(x_65, x_9, x_58); -if (lean_obj_tag(x_66) == 0) -{ -lean_object* x_67; uint8_t x_68; -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_unbox(x_67); -lean_dec(x_67); -if (x_68 == 0) -{ -uint8_t x_69; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_69 = !lean_is_exclusive(x_66); -if (x_69 == 0) -{ -lean_object* x_70; -x_70 = lean_ctor_get(x_66, 0); -lean_dec(x_70); -lean_ctor_set(x_66, 0, x_55); -return x_66; +lean_object* x_61; lean_object* x_62; +x_61 = lean_ctor_get(x_56, 1); +lean_inc(x_61); +lean_dec(x_56); +x_62 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_62, 0, x_48); +lean_ctor_set(x_62, 1, x_61); +return x_62; +} } else { -lean_object* x_71; lean_object* x_72; -x_71 = lean_ctor_get(x_66, 1); -lean_inc(x_71); -lean_dec(x_66); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_55); +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; uint8_t x_78; +x_63 = lean_ctor_get(x_56, 1); +lean_inc(x_63); +lean_dec(x_56); +x_64 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_64, 0, x_1); +x_65 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6; +x_66 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_66, 0, x_64); +lean_ctor_set(x_66, 1, x_65); +x_67 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_67, 0, x_39); +x_68 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +x_69 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; +x_70 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +x_71 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_71, 0, x_34); +x_72 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_72, 0, x_70); lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_73 = lean_ctor_get(x_66, 1); -lean_inc(x_73); -lean_dec(x_66); +x_73 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_73, 0, x_72); +lean_ctor_set(x_73, 1, x_65); x_74 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_74, 0, x_4); -x_75 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7; -x_76 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -x_77 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_77, 0, x_46); -x_78 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -x_79 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; -x_80 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -x_81 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_81, 0, x_37); -x_82 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -x_83 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_75); -x_84 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_84, 0, x_49); -x_85 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -x_86 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_87 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; -x_88 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_86, x_87, x_85); -x_89 = lean_apply_2(x_88, x_9, x_73); -if (lean_obj_tag(x_89) == 0) +lean_ctor_set(x_74, 0, x_42); +x_75 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +x_76 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; +x_77 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_76, x_75, x_6, x_63); +lean_dec(x_6); +x_78 = !lean_is_exclusive(x_77); +if (x_78 == 0) { -uint8_t x_90; -x_90 = !lean_is_exclusive(x_89); -if (x_90 == 0) -{ -lean_object* x_91; -x_91 = lean_ctor_get(x_89, 0); -lean_dec(x_91); -lean_ctor_set(x_89, 0, x_55); -return x_89; +lean_object* x_79; +x_79 = lean_ctor_get(x_77, 0); +lean_dec(x_79); +lean_ctor_set(x_77, 0, x_48); +return x_77; } else { -lean_object* x_92; lean_object* x_93; -x_92 = lean_ctor_get(x_89, 1); -lean_inc(x_92); -lean_dec(x_89); -x_93 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_93, 0, x_55); -lean_ctor_set(x_93, 1, x_92); -return x_93; -} -} -else -{ -uint8_t x_94; -lean_dec(x_55); -x_94 = !lean_is_exclusive(x_89); -if (x_94 == 0) -{ -return x_89; -} -else -{ -lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_95 = lean_ctor_get(x_89, 0); -x_96 = lean_ctor_get(x_89, 1); -lean_inc(x_96); -lean_inc(x_95); -lean_dec(x_89); -x_97 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_97, 0, x_95); -lean_ctor_set(x_97, 1, x_96); -return x_97; +lean_object* x_80; lean_object* x_81; +x_80 = lean_ctor_get(x_77, 1); +lean_inc(x_80); +lean_dec(x_77); +x_81 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_81, 0, x_48); +lean_ctor_set(x_81, 1, x_80); +return x_81; } } } } else { -uint8_t x_98; -lean_dec(x_55); -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_98 = !lean_is_exclusive(x_66); -if (x_98 == 0) +lean_object* x_82; lean_object* x_83; uint8_t x_84; +x_82 = lean_ctor_get(x_47, 1); +lean_inc(x_82); +lean_dec(x_47); +x_83 = lean_ctor_get(x_82, 4); +lean_inc(x_83); +x_84 = lean_ctor_get_uint8(x_83, sizeof(void*)*1); +lean_dec(x_83); +if (x_84 == 0) { -return x_66; +lean_object* x_85; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_48); +lean_ctor_set(x_85, 1, x_82); +return x_85; } else { -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_66, 0); -x_100 = lean_ctor_get(x_66, 1); -lean_inc(x_100); -lean_inc(x_99); -lean_dec(x_66); -x_101 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_101, 0, x_99); -lean_ctor_set(x_101, 1, x_100); -return x_101; +lean_object* x_86; lean_object* x_87; lean_object* x_88; uint8_t x_89; +x_86 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3; +x_87 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_86, x_6, x_82); +x_88 = lean_ctor_get(x_87, 0); +lean_inc(x_88); +x_89 = lean_unbox(x_88); +lean_dec(x_88); +if (x_89 == 0) +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_90 = lean_ctor_get(x_87, 1); +lean_inc(x_90); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + x_91 = x_87; +} else { + lean_dec_ref(x_87); + x_91 = lean_box(0); +} +if (lean_is_scalar(x_91)) { + x_92 = lean_alloc_ctor(0, 2, 0); +} else { + x_92 = x_91; +} +lean_ctor_set(x_92, 0, x_48); +lean_ctor_set(x_92, 1, x_90); +return x_92; +} +else +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_93 = lean_ctor_get(x_87, 1); +lean_inc(x_93); +lean_dec(x_87); +x_94 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_94, 0, x_1); +x_95 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6; +x_96 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_96, 0, x_94); +lean_ctor_set(x_96, 1, x_95); +x_97 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_97, 0, x_39); +x_98 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_98, 0, x_96); +lean_ctor_set(x_98, 1, x_97); +x_99 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; +x_100 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_100, 0, x_98); +lean_ctor_set(x_100, 1, x_99); +x_101 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_101, 0, x_34); +x_102 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_102, 0, x_100); +lean_ctor_set(x_102, 1, x_101); +x_103 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_103, 0, x_102); +lean_ctor_set(x_103, 1, x_95); +x_104 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_104, 0, x_42); +x_105 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_105, 0, x_103); +lean_ctor_set(x_105, 1, x_104); +x_106 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; +x_107 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_106, x_105, x_6, x_93); +lean_dec(x_6); +x_108 = lean_ctor_get(x_107, 1); +lean_inc(x_108); +if (lean_is_exclusive(x_107)) { + lean_ctor_release(x_107, 0); + lean_ctor_release(x_107, 1); + x_109 = x_107; +} else { + lean_dec_ref(x_107); + x_109 = lean_box(0); +} +if (lean_is_scalar(x_109)) { + x_110 = lean_alloc_ctor(0, 2, 0); +} else { + x_110 = x_109; +} +lean_ctor_set(x_110, 0, x_48); +lean_ctor_set(x_110, 1, x_108); +return x_110; } } } } else { -lean_object* x_102; lean_object* x_103; uint8_t x_104; -x_102 = lean_ctor_get(x_54, 1); -lean_inc(x_102); -lean_dec(x_54); -x_103 = lean_ctor_get(x_102, 4); -lean_inc(x_103); -x_104 = lean_ctor_get_uint8(x_103, sizeof(void*)*1); -lean_dec(x_103); -if (x_104 == 0) -{ -lean_object* x_105; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_105 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_105, 0, x_55); -lean_ctor_set(x_105, 1, x_102); -return x_105; -} -else -{ -lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_106 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_107 = l_Lean_Meta_tracer; -x_108 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4; -x_109 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_106, x_107, x_108); -lean_inc(x_9); -x_110 = lean_apply_2(x_109, x_9, x_102); -if (lean_obj_tag(x_110) == 0) -{ -lean_object* x_111; uint8_t x_112; -x_111 = lean_ctor_get(x_110, 0); +lean_object* x_111; lean_object* x_112; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_1); +x_111 = lean_ctor_get(x_47, 1); lean_inc(x_111); -x_112 = lean_unbox(x_111); -lean_dec(x_111); -if (x_112 == 0) +lean_dec(x_47); +x_112 = l_Lean_Meta_assignExprMVar(x_18, x_34, x_6, x_111); +lean_dec(x_6); +if (lean_obj_tag(x_112) == 0) { -lean_object* x_113; lean_object* x_114; lean_object* x_115; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_113 = lean_ctor_get(x_110, 1); -lean_inc(x_113); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - x_114 = x_110; -} else { - lean_dec_ref(x_110); - x_114 = lean_box(0); -} -if (lean_is_scalar(x_114)) { - x_115 = lean_alloc_ctor(0, 2, 0); -} else { - x_115 = x_114; -} -lean_ctor_set(x_115, 0, x_55); -lean_ctor_set(x_115, 1, x_113); -return x_115; +uint8_t x_113; +x_113 = !lean_is_exclusive(x_112); +if (x_113 == 0) +{ +lean_object* x_114; +x_114 = lean_ctor_get(x_112, 0); +lean_dec(x_114); +lean_ctor_set(x_112, 0, x_48); +return x_112; } else { -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_116 = lean_ctor_get(x_110, 1); -lean_inc(x_116); -lean_dec(x_110); -x_117 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_117, 0, x_4); -x_118 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7; -x_119 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_119, 0, x_117); -lean_ctor_set(x_119, 1, x_118); -x_120 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_120, 0, x_46); -x_121 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); -x_122 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; -x_123 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_123, 0, x_121); -lean_ctor_set(x_123, 1, x_122); -x_124 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_124, 0, x_37); -x_125 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_125, 0, x_123); -lean_ctor_set(x_125, 1, x_124); -x_126 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_118); -x_127 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_127, 0, x_49); -x_128 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_128, 0, x_126); -lean_ctor_set(x_128, 1, x_127); -x_129 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_130 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; -x_131 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_129, x_130, x_128); -x_132 = lean_apply_2(x_131, x_9, x_116); -if (lean_obj_tag(x_132) == 0) -{ -lean_object* x_133; lean_object* x_134; lean_object* x_135; -x_133 = lean_ctor_get(x_132, 1); -lean_inc(x_133); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_134 = x_132; -} else { - lean_dec_ref(x_132); - x_134 = lean_box(0); +lean_object* x_115; lean_object* x_116; +x_115 = lean_ctor_get(x_112, 1); +lean_inc(x_115); +lean_dec(x_112); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_48); +lean_ctor_set(x_116, 1, x_115); +return x_116; } -if (lean_is_scalar(x_134)) { - x_135 = lean_alloc_ctor(0, 2, 0); -} else { - x_135 = x_134; -} -lean_ctor_set(x_135, 0, x_55); -lean_ctor_set(x_135, 1, x_133); -return x_135; } else { -lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; -lean_dec(x_55); -x_136 = lean_ctor_get(x_132, 0); +uint8_t x_117; +lean_dec(x_48); +x_117 = !lean_is_exclusive(x_112); +if (x_117 == 0) +{ +return x_112; +} +else +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_112, 0); +x_119 = lean_ctor_get(x_112, 1); +lean_inc(x_119); +lean_inc(x_118); +lean_dec(x_112); +x_120 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_120, 0, x_118); +lean_ctor_set(x_120, 1, x_119); +return x_120; +} +} +} +} +else +{ +uint8_t x_121; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_6); +lean_dec(x_1); +x_121 = !lean_is_exclusive(x_47); +if (x_121 == 0) +{ +return x_47; +} +else +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_122 = lean_ctor_get(x_47, 0); +x_123 = lean_ctor_get(x_47, 1); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_47); +x_124 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_124, 0, x_122); +lean_ctor_set(x_124, 1, x_123); +return x_124; +} +} +} +else +{ +lean_object* x_125; uint8_t x_126; uint8_t x_127; uint8_t x_128; uint8_t x_129; uint8_t x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; +x_125 = lean_ctor_get(x_10, 0); +x_126 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 1); +x_127 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 2); +x_128 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 3); +x_129 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 4); +lean_inc(x_125); +lean_dec(x_10); +x_130 = 1; +x_131 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_131, 0, x_125); +lean_ctor_set_uint8(x_131, sizeof(void*)*1, x_16); +lean_ctor_set_uint8(x_131, sizeof(void*)*1 + 1, x_126); +lean_ctor_set_uint8(x_131, sizeof(void*)*1 + 2, x_127); +lean_ctor_set_uint8(x_131, sizeof(void*)*1 + 3, x_128); +lean_ctor_set_uint8(x_131, sizeof(void*)*1 + 4, x_129); +lean_ctor_set_uint8(x_131, sizeof(void*)*1 + 5, x_130); +x_132 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_132, 0, x_131); +lean_ctor_set(x_132, 1, x_11); +lean_ctor_set(x_132, 2, x_12); +lean_inc(x_42); +lean_inc(x_39); +x_133 = l_Lean_Meta_isExprDefEqAux(x_39, x_42, x_132, x_43); +if (lean_obj_tag(x_133) == 0) +{ +lean_object* x_134; uint8_t x_135; +x_134 = lean_ctor_get(x_133, 0); +lean_inc(x_134); +x_135 = lean_unbox(x_134); +if (x_135 == 0) +{ +lean_object* x_136; lean_object* x_137; lean_object* x_138; uint8_t x_139; +lean_dec(x_18); +x_136 = lean_ctor_get(x_133, 1); lean_inc(x_136); -x_137 = lean_ctor_get(x_132, 1); -lean_inc(x_137); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_138 = x_132; +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + x_137 = x_133; } else { - lean_dec_ref(x_132); - x_138 = lean_box(0); + lean_dec_ref(x_133); + x_137 = lean_box(0); } -if (lean_is_scalar(x_138)) { - x_139 = lean_alloc_ctor(1, 2, 0); +x_138 = lean_ctor_get(x_136, 4); +lean_inc(x_138); +x_139 = lean_ctor_get_uint8(x_138, sizeof(void*)*1); +lean_dec(x_138); +if (x_139 == 0) +{ +lean_object* x_140; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +if (lean_is_scalar(x_137)) { + x_140 = lean_alloc_ctor(0, 2, 0); } else { - x_139 = x_138; -} -lean_ctor_set(x_139, 0, x_136); -lean_ctor_set(x_139, 1, x_137); -return x_139; -} + x_140 = x_137; } +lean_ctor_set(x_140, 0, x_134); +lean_ctor_set(x_140, 1, x_136); +return x_140; } else { -lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; -lean_dec(x_55); -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_140 = lean_ctor_get(x_110, 0); -lean_inc(x_140); -x_141 = lean_ctor_get(x_110, 1); -lean_inc(x_141); -if (lean_is_exclusive(x_110)) { - lean_ctor_release(x_110, 0); - lean_ctor_release(x_110, 1); - x_142 = x_110; +lean_object* x_141; lean_object* x_142; lean_object* x_143; uint8_t x_144; +lean_dec(x_137); +x_141 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3; +x_142 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_141, x_6, x_136); +x_143 = lean_ctor_get(x_142, 0); +lean_inc(x_143); +x_144 = lean_unbox(x_143); +lean_dec(x_143); +if (x_144 == 0) +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_145 = lean_ctor_get(x_142, 1); +lean_inc(x_145); +if (lean_is_exclusive(x_142)) { + lean_ctor_release(x_142, 0); + lean_ctor_release(x_142, 1); + x_146 = x_142; } else { - lean_dec_ref(x_110); - x_142 = lean_box(0); + lean_dec_ref(x_142); + x_146 = lean_box(0); } -if (lean_is_scalar(x_142)) { - x_143 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_146)) { + x_147 = lean_alloc_ctor(0, 2, 0); } else { - x_143 = x_142; -} -lean_ctor_set(x_143, 0, x_140); -lean_ctor_set(x_143, 1, x_141); -return x_143; -} -} + x_147 = x_146; } +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_145); +return x_147; } else { -lean_object* x_144; lean_object* x_145; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_4); -x_144 = lean_ctor_get(x_54, 1); -lean_inc(x_144); -lean_dec(x_54); -x_145 = l_Lean_Meta_assignExprMVar(x_21, x_37, x_9, x_144); -lean_dec(x_9); -if (lean_obj_tag(x_145) == 0) -{ -uint8_t x_146; -x_146 = !lean_is_exclusive(x_145); -if (x_146 == 0) -{ -lean_object* x_147; -x_147 = lean_ctor_get(x_145, 0); -lean_dec(x_147); -lean_ctor_set(x_145, 0, x_55); -return x_145; -} -else -{ -lean_object* x_148; lean_object* x_149; -x_148 = lean_ctor_get(x_145, 1); +lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; +x_148 = lean_ctor_get(x_142, 1); lean_inc(x_148); -lean_dec(x_145); -x_149 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_149, 0, x_55); -lean_ctor_set(x_149, 1, x_148); -return x_149; -} -} -else -{ -uint8_t x_150; -lean_dec(x_55); -x_150 = !lean_is_exclusive(x_145); -if (x_150 == 0) -{ -return x_145; -} -else -{ -lean_object* x_151; lean_object* x_152; lean_object* x_153; -x_151 = lean_ctor_get(x_145, 0); -x_152 = lean_ctor_get(x_145, 1); -lean_inc(x_152); -lean_inc(x_151); -lean_dec(x_145); -x_153 = lean_alloc_ctor(1, 2, 0); +lean_dec(x_142); +x_149 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_149, 0, x_1); +x_150 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6; +x_151 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_151, 0, x_149); +lean_ctor_set(x_151, 1, x_150); +x_152 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_152, 0, x_39); +x_153 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_153, 0, x_151); lean_ctor_set(x_153, 1, x_152); -return x_153; -} -} -} -} -else -{ -uint8_t x_154; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_9); -lean_dec(x_4); -x_154 = !lean_is_exclusive(x_54); -if (x_154 == 0) -{ -return x_54; -} -else -{ -lean_object* x_155; lean_object* x_156; lean_object* x_157; -x_155 = lean_ctor_get(x_54, 0); -x_156 = lean_ctor_get(x_54, 1); -lean_inc(x_156); -lean_inc(x_155); -lean_dec(x_54); -x_157 = lean_alloc_ctor(1, 2, 0); +x_154 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; +x_155 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_155, 0, x_153); +lean_ctor_set(x_155, 1, x_154); +x_156 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_156, 0, x_34); +x_157 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_157, 0, x_155); lean_ctor_set(x_157, 1, x_156); -return x_157; +x_158 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_158, 0, x_157); +lean_ctor_set(x_158, 1, x_150); +x_159 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_159, 0, x_42); +x_160 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_160, 0, x_158); +lean_ctor_set(x_160, 1, x_159); +x_161 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; +x_162 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_161, x_160, x_6, x_148); +lean_dec(x_6); +x_163 = lean_ctor_get(x_162, 1); +lean_inc(x_163); +if (lean_is_exclusive(x_162)) { + lean_ctor_release(x_162, 0); + lean_ctor_release(x_162, 1); + x_164 = x_162; +} else { + lean_dec_ref(x_162); + x_164 = lean_box(0); +} +if (lean_is_scalar(x_164)) { + x_165 = lean_alloc_ctor(0, 2, 0); +} else { + x_165 = x_164; +} +lean_ctor_set(x_165, 0, x_134); +lean_ctor_set(x_165, 1, x_163); +return x_165; } } } else { -lean_object* x_158; uint8_t x_159; uint8_t x_160; uint8_t x_161; uint8_t x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_158 = lean_ctor_get(x_13, 0); -x_159 = lean_ctor_get_uint8(x_13, sizeof(void*)*1 + 1); -x_160 = lean_ctor_get_uint8(x_13, sizeof(void*)*1 + 2); -x_161 = lean_ctor_get_uint8(x_13, sizeof(void*)*1 + 3); -lean_inc(x_158); -lean_dec(x_13); -x_162 = 1; -x_163 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_163, 0, x_158); -lean_ctor_set_uint8(x_163, sizeof(void*)*1, x_19); -lean_ctor_set_uint8(x_163, sizeof(void*)*1 + 1, x_159); -lean_ctor_set_uint8(x_163, sizeof(void*)*1 + 2, x_160); -lean_ctor_set_uint8(x_163, sizeof(void*)*1 + 3, x_161); -lean_ctor_set_uint8(x_163, sizeof(void*)*1 + 4, x_162); -x_164 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_164, 0, x_163); -lean_ctor_set(x_164, 1, x_14); -lean_ctor_set(x_164, 2, x_15); -lean_inc(x_49); -lean_inc(x_46); -x_165 = lean_apply_4(x_2, x_46, x_49, x_164, x_50); -if (lean_obj_tag(x_165) == 0) -{ -lean_object* x_166; uint8_t x_167; -x_166 = lean_ctor_get(x_165, 0); +lean_object* x_166; lean_object* x_167; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_1); +x_166 = lean_ctor_get(x_133, 1); lean_inc(x_166); -x_167 = lean_unbox(x_166); -if (x_167 == 0) +lean_dec(x_133); +x_167 = l_Lean_Meta_assignExprMVar(x_18, x_34, x_6, x_166); +lean_dec(x_6); +if (lean_obj_tag(x_167) == 0) { -lean_object* x_168; lean_object* x_169; lean_object* x_170; uint8_t x_171; -lean_dec(x_21); -x_168 = lean_ctor_get(x_165, 1); +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_167, 1); lean_inc(x_168); -if (lean_is_exclusive(x_165)) { - lean_ctor_release(x_165, 0); - lean_ctor_release(x_165, 1); - x_169 = x_165; +if (lean_is_exclusive(x_167)) { + lean_ctor_release(x_167, 0); + lean_ctor_release(x_167, 1); + x_169 = x_167; } else { - lean_dec_ref(x_165); + lean_dec_ref(x_167); x_169 = lean_box(0); } -x_170 = lean_ctor_get(x_168, 4); -lean_inc(x_170); -x_171 = lean_ctor_get_uint8(x_170, sizeof(void*)*1); -lean_dec(x_170); -if (x_171 == 0) -{ -lean_object* x_172; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); if (lean_is_scalar(x_169)) { - x_172 = lean_alloc_ctor(0, 2, 0); + x_170 = lean_alloc_ctor(0, 2, 0); } else { - x_172 = x_169; + x_170 = x_169; } -lean_ctor_set(x_172, 0, x_166); -lean_ctor_set(x_172, 1, x_168); -return x_172; +lean_ctor_set(x_170, 0, x_134); +lean_ctor_set(x_170, 1, x_168); +return x_170; } else { -lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; -lean_dec(x_169); -x_173 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_174 = l_Lean_Meta_tracer; -x_175 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4; -x_176 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_173, x_174, x_175); -lean_inc(x_9); -x_177 = lean_apply_2(x_176, x_9, x_168); -if (lean_obj_tag(x_177) == 0) +lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; +lean_dec(x_134); +x_171 = lean_ctor_get(x_167, 0); +lean_inc(x_171); +x_172 = lean_ctor_get(x_167, 1); +lean_inc(x_172); +if (lean_is_exclusive(x_167)) { + lean_ctor_release(x_167, 0); + lean_ctor_release(x_167, 1); + x_173 = x_167; +} else { + lean_dec_ref(x_167); + x_173 = lean_box(0); +} +if (lean_is_scalar(x_173)) { + x_174 = lean_alloc_ctor(1, 2, 0); +} else { + x_174 = x_173; +} +lean_ctor_set(x_174, 0, x_171); +lean_ctor_set(x_174, 1, x_172); +return x_174; +} +} +} +else { -lean_object* x_178; uint8_t x_179; -x_178 = lean_ctor_get(x_177, 0); -lean_inc(x_178); -x_179 = lean_unbox(x_178); -lean_dec(x_178); +lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; +lean_dec(x_42); +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_6); +lean_dec(x_1); +x_175 = lean_ctor_get(x_133, 0); +lean_inc(x_175); +x_176 = lean_ctor_get(x_133, 1); +lean_inc(x_176); +if (lean_is_exclusive(x_133)) { + lean_ctor_release(x_133, 0); + lean_ctor_release(x_133, 1); + x_177 = x_133; +} else { + lean_dec_ref(x_133); + x_177 = lean_box(0); +} +if (lean_is_scalar(x_177)) { + x_178 = lean_alloc_ctor(1, 2, 0); +} else { + x_178 = x_177; +} +lean_ctor_set(x_178, 0, x_175); +lean_ctor_set(x_178, 1, x_176); +return x_178; +} +} +} +else +{ +uint8_t x_179; +lean_dec(x_39); +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_1); +x_179 = !lean_is_exclusive(x_41); if (x_179 == 0) { +return x_41; +} +else +{ lean_object* x_180; lean_object* x_181; lean_object* x_182; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_180 = lean_ctor_get(x_177, 1); +x_180 = lean_ctor_get(x_41, 0); +x_181 = lean_ctor_get(x_41, 1); +lean_inc(x_181); lean_inc(x_180); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_181 = x_177; -} else { - lean_dec_ref(x_177); - x_181 = lean_box(0); -} -if (lean_is_scalar(x_181)) { - x_182 = lean_alloc_ctor(0, 2, 0); -} else { - x_182 = x_181; -} -lean_ctor_set(x_182, 0, x_166); -lean_ctor_set(x_182, 1, x_180); +lean_dec(x_41); +x_182 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_182, 0, x_180); +lean_ctor_set(x_182, 1, x_181); return x_182; } +} +} else { -lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; -x_183 = lean_ctor_get(x_177, 1); -lean_inc(x_183); -lean_dec(x_177); -x_184 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_184, 0, x_4); -x_185 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7; -x_186 = lean_alloc_ctor(8, 2, 0); +uint8_t x_183; +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_1); +x_183 = !lean_is_exclusive(x_38); +if (x_183 == 0) +{ +return x_38; +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_184 = lean_ctor_get(x_38, 0); +x_185 = lean_ctor_get(x_38, 1); +lean_inc(x_185); +lean_inc(x_184); +lean_dec(x_38); +x_186 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_186, 0, x_184); lean_ctor_set(x_186, 1, x_185); -x_187 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_187, 0, x_46); -x_188 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_188, 0, x_186); -lean_ctor_set(x_188, 1, x_187); -x_189 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; -x_190 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_190, 0, x_188); -lean_ctor_set(x_190, 1, x_189); -x_191 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_191, 0, x_37); -x_192 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_192, 0, x_190); -lean_ctor_set(x_192, 1, x_191); -x_193 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_193, 0, x_192); -lean_ctor_set(x_193, 1, x_185); -x_194 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_194, 0, x_49); -x_195 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_195, 0, x_193); -lean_ctor_set(x_195, 1, x_194); -x_196 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_197 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; -x_198 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_196, x_197, x_195); -x_199 = lean_apply_2(x_198, x_9, x_183); -if (lean_obj_tag(x_199) == 0) +return x_186; +} +} +} +else { -lean_object* x_200; lean_object* x_201; lean_object* x_202; -x_200 = lean_ctor_get(x_199, 1); +lean_object* x_187; lean_object* x_188; uint8_t x_189; +lean_inc(x_6); +lean_inc(x_34); +x_187 = l_Lean_Meta_isTypeCorrect(x_34, x_6, x_35); +x_188 = lean_ctor_get(x_187, 0); +lean_inc(x_188); +x_189 = lean_unbox(x_188); +lean_dec(x_188); +if (x_189 == 0) +{ +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +if (x_16 == 0) +{ +uint8_t x_190; +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_190 = !lean_is_exclusive(x_187); +if (x_190 == 0) +{ +lean_object* x_191; uint8_t x_192; lean_object* x_193; +x_191 = lean_ctor_get(x_187, 0); +lean_dec(x_191); +x_192 = 0; +x_193 = lean_box(x_192); +lean_ctor_set(x_187, 0, x_193); +return x_187; +} +else +{ +lean_object* x_194; uint8_t x_195; lean_object* x_196; lean_object* x_197; +x_194 = lean_ctor_get(x_187, 1); +lean_inc(x_194); +lean_dec(x_187); +x_195 = 0; +x_196 = lean_box(x_195); +x_197 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_197, 0, x_196); +lean_ctor_set(x_197, 1, x_194); +return x_197; +} +} +else +{ +lean_object* x_198; lean_object* x_199; +x_198 = lean_ctor_get(x_187, 1); +lean_inc(x_198); +lean_dec(x_187); +x_199 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_5, x_14, x_6, x_198); +lean_dec(x_5); +return x_199; +} +} +else +{ +lean_object* x_200; lean_object* x_201; +lean_dec(x_14); +lean_dec(x_5); +x_200 = lean_ctor_get(x_187, 1); lean_inc(x_200); -if (lean_is_exclusive(x_199)) { - lean_ctor_release(x_199, 0); - lean_ctor_release(x_199, 1); - x_201 = x_199; -} else { - lean_dec_ref(x_199); - x_201 = lean_box(0); -} -if (lean_is_scalar(x_201)) { - x_202 = lean_alloc_ctor(0, 2, 0); -} else { - x_202 = x_201; -} -lean_ctor_set(x_202, 0, x_166); -lean_ctor_set(x_202, 1, x_200); -return x_202; -} -else +lean_dec(x_187); +lean_inc(x_6); +lean_inc(x_1); +x_201 = l_Lean_Meta_inferType(x_1, x_6, x_200); +if (lean_obj_tag(x_201) == 0) { -lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; -lean_dec(x_166); -x_203 = lean_ctor_get(x_199, 0); +lean_object* x_202; lean_object* x_203; lean_object* x_204; +x_202 = lean_ctor_get(x_201, 0); +lean_inc(x_202); +x_203 = lean_ctor_get(x_201, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_199, 1); -lean_inc(x_204); -if (lean_is_exclusive(x_199)) { - lean_ctor_release(x_199, 0); - lean_ctor_release(x_199, 1); - x_205 = x_199; -} else { - lean_dec_ref(x_199); - x_205 = lean_box(0); -} -if (lean_is_scalar(x_205)) { - x_206 = lean_alloc_ctor(1, 2, 0); -} else { - x_206 = x_205; -} -lean_ctor_set(x_206, 0, x_203); -lean_ctor_set(x_206, 1, x_204); -return x_206; -} -} -} -else +lean_dec(x_201); +lean_inc(x_6); +lean_inc(x_34); +x_204 = l_Lean_Meta_inferType(x_34, x_6, x_203); +if (lean_obj_tag(x_204) == 0) { -lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; -lean_dec(x_166); -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_207 = lean_ctor_get(x_177, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_177, 1); -lean_inc(x_208); -if (lean_is_exclusive(x_177)) { - lean_ctor_release(x_177, 0); - lean_ctor_release(x_177, 1); - x_209 = x_177; -} else { - lean_dec_ref(x_177); - x_209 = lean_box(0); -} -if (lean_is_scalar(x_209)) { - x_210 = lean_alloc_ctor(1, 2, 0); -} else { - x_210 = x_209; -} -lean_ctor_set(x_210, 0, x_207); -lean_ctor_set(x_210, 1, x_208); +lean_object* x_205; lean_object* x_206; uint8_t x_207; +x_205 = lean_ctor_get(x_204, 0); +lean_inc(x_205); +x_206 = lean_ctor_get(x_204, 1); +lean_inc(x_206); +lean_dec(x_204); +x_207 = !lean_is_exclusive(x_10); +if (x_207 == 0) +{ +uint8_t x_208; lean_object* x_209; lean_object* x_210; +x_208 = 1; +lean_ctor_set_uint8(x_10, sizeof(void*)*1 + 5, x_208); +x_209 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_209, 0, x_10); +lean_ctor_set(x_209, 1, x_11); +lean_ctor_set(x_209, 2, x_12); +lean_inc(x_205); +lean_inc(x_202); +x_210 = l_Lean_Meta_isExprDefEqAux(x_202, x_205, x_209, x_206); +if (lean_obj_tag(x_210) == 0) +{ +lean_object* x_211; uint8_t x_212; +x_211 = lean_ctor_get(x_210, 0); +lean_inc(x_211); +x_212 = lean_unbox(x_211); +if (x_212 == 0) +{ +uint8_t x_213; +lean_dec(x_18); +x_213 = !lean_is_exclusive(x_210); +if (x_213 == 0) +{ +lean_object* x_214; lean_object* x_215; lean_object* x_216; uint8_t x_217; +x_214 = lean_ctor_get(x_210, 1); +x_215 = lean_ctor_get(x_210, 0); +lean_dec(x_215); +x_216 = lean_ctor_get(x_214, 4); +lean_inc(x_216); +x_217 = lean_ctor_get_uint8(x_216, sizeof(void*)*1); +lean_dec(x_216); +if (x_217 == 0) +{ +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); return x_210; } -} -} else { -lean_object* x_211; lean_object* x_212; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_4); -x_211 = lean_ctor_get(x_165, 1); -lean_inc(x_211); -lean_dec(x_165); -x_212 = l_Lean_Meta_assignExprMVar(x_21, x_37, x_9, x_211); -lean_dec(x_9); -if (lean_obj_tag(x_212) == 0) +lean_object* x_218; lean_object* x_219; lean_object* x_220; uint8_t x_221; +lean_free_object(x_210); +x_218 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3; +x_219 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_218, x_6, x_214); +x_220 = lean_ctor_get(x_219, 0); +lean_inc(x_220); +x_221 = lean_unbox(x_220); +lean_dec(x_220); +if (x_221 == 0) { -lean_object* x_213; lean_object* x_214; lean_object* x_215; -x_213 = lean_ctor_get(x_212, 1); -lean_inc(x_213); -if (lean_is_exclusive(x_212)) { - lean_ctor_release(x_212, 0); - lean_ctor_release(x_212, 1); - x_214 = x_212; -} else { - lean_dec_ref(x_212); - x_214 = lean_box(0); -} -if (lean_is_scalar(x_214)) { - x_215 = lean_alloc_ctor(0, 2, 0); -} else { - x_215 = x_214; -} -lean_ctor_set(x_215, 0, x_166); -lean_ctor_set(x_215, 1, x_213); -return x_215; -} -else +uint8_t x_222; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_222 = !lean_is_exclusive(x_219); +if (x_222 == 0) { -lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; -lean_dec(x_166); -x_216 = lean_ctor_get(x_212, 0); -lean_inc(x_216); -x_217 = lean_ctor_get(x_212, 1); -lean_inc(x_217); -if (lean_is_exclusive(x_212)) { - lean_ctor_release(x_212, 0); - lean_ctor_release(x_212, 1); - x_218 = x_212; -} else { - lean_dec_ref(x_212); - x_218 = lean_box(0); -} -if (lean_is_scalar(x_218)) { - x_219 = lean_alloc_ctor(1, 2, 0); -} else { - x_219 = x_218; -} -lean_ctor_set(x_219, 0, x_216); -lean_ctor_set(x_219, 1, x_217); +lean_object* x_223; +x_223 = lean_ctor_get(x_219, 0); +lean_dec(x_223); +lean_ctor_set(x_219, 0, x_211); return x_219; } +else +{ +lean_object* x_224; lean_object* x_225; +x_224 = lean_ctor_get(x_219, 1); +lean_inc(x_224); +lean_dec(x_219); +x_225 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_225, 0, x_211); +lean_ctor_set(x_225, 1, x_224); +return x_225; } } else { -lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; -lean_dec(x_49); -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_9); -lean_dec(x_4); -x_220 = lean_ctor_get(x_165, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_165, 1); -lean_inc(x_221); -if (lean_is_exclusive(x_165)) { - lean_ctor_release(x_165, 0); - lean_ctor_release(x_165, 1); - x_222 = x_165; -} else { - lean_dec_ref(x_165); - x_222 = lean_box(0); -} -if (lean_is_scalar(x_222)) { - x_223 = lean_alloc_ctor(1, 2, 0); -} else { - x_223 = x_222; -} -lean_ctor_set(x_223, 0, x_220); -lean_ctor_set(x_223, 1, x_221); -return x_223; -} -} -} -else -{ -uint8_t x_224; -lean_dec(x_46); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_9); -lean_dec(x_4); -lean_dec(x_2); -x_224 = !lean_is_exclusive(x_48); -if (x_224 == 0) -{ -return x_48; -} -else -{ -lean_object* x_225; lean_object* x_226; lean_object* x_227; -x_225 = lean_ctor_get(x_48, 0); -x_226 = lean_ctor_get(x_48, 1); +lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; uint8_t x_241; +x_226 = lean_ctor_get(x_219, 1); lean_inc(x_226); -lean_inc(x_225); -lean_dec(x_48); -x_227 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_227, 0, x_225); -lean_ctor_set(x_227, 1, x_226); -return x_227; -} -} -} -else -{ -uint8_t x_228; -lean_dec(x_44); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_9); -lean_dec(x_4); -lean_dec(x_2); -x_228 = !lean_is_exclusive(x_45); -if (x_228 == 0) -{ -return x_45; -} -else -{ -lean_object* x_229; lean_object* x_230; lean_object* x_231; -x_229 = lean_ctor_get(x_45, 0); -x_230 = lean_ctor_get(x_45, 1); -lean_inc(x_230); -lean_inc(x_229); -lean_dec(x_45); -x_231 = lean_alloc_ctor(1, 2, 0); +lean_dec(x_219); +x_227 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_227, 0, x_1); +x_228 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6; +x_229 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_229, 0, x_227); +lean_ctor_set(x_229, 1, x_228); +x_230 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_230, 0, x_202); +x_231 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_231, 0, x_229); lean_ctor_set(x_231, 1, x_230); -return x_231; -} -} -} -else +x_232 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; +x_233 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_233, 0, x_231); +lean_ctor_set(x_233, 1, x_232); +x_234 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_234, 0, x_34); +x_235 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_235, 0, x_233); +lean_ctor_set(x_235, 1, x_234); +x_236 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_236, 0, x_235); +lean_ctor_set(x_236, 1, x_228); +x_237 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_237, 0, x_205); +x_238 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_238, 0, x_236); +lean_ctor_set(x_238, 1, x_237); +x_239 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; +x_240 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_239, x_238, x_6, x_226); +lean_dec(x_6); +x_241 = !lean_is_exclusive(x_240); +if (x_241 == 0) { -lean_object* x_232; lean_object* x_233; uint8_t x_234; -lean_inc(x_9); -lean_inc(x_37); -lean_inc(x_2); -lean_inc(x_1); -x_232 = l_Lean_Meta_isTypeCorrectAux(x_1, x_2, x_37, x_9, x_38); -x_233 = lean_ctor_get(x_232, 0); -lean_inc(x_233); -x_234 = lean_unbox(x_233); -lean_dec(x_233); -if (x_234 == 0) -{ -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -if (x_19 == 0) -{ -uint8_t x_235; -lean_dec(x_17); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_235 = !lean_is_exclusive(x_232); -if (x_235 == 0) -{ -lean_object* x_236; uint8_t x_237; lean_object* x_238; -x_236 = lean_ctor_get(x_232, 0); -lean_dec(x_236); -x_237 = 0; -x_238 = lean_box(x_237); -lean_ctor_set(x_232, 0, x_238); -return x_232; -} -else -{ -lean_object* x_239; uint8_t x_240; lean_object* x_241; lean_object* x_242; -x_239 = lean_ctor_get(x_232, 1); -lean_inc(x_239); -lean_dec(x_232); -x_240 = 0; -x_241 = lean_box(x_240); -x_242 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_242, 0, x_241); -lean_ctor_set(x_242, 1, x_239); -return x_242; -} +lean_object* x_242; +x_242 = lean_ctor_get(x_240, 0); +lean_dec(x_242); +lean_ctor_set(x_240, 0, x_211); +return x_240; } else { lean_object* x_243; lean_object* x_244; -x_243 = lean_ctor_get(x_232, 1); +x_243 = lean_ctor_get(x_240, 1); lean_inc(x_243); -lean_dec(x_232); -x_244 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_8, x_17, x_9, x_243); +lean_dec(x_240); +x_244 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_244, 0, x_211); +lean_ctor_set(x_244, 1, x_243); return x_244; } } +} +} else { -lean_object* x_245; lean_object* x_246; lean_object* x_247; -lean_dec(x_17); -lean_dec(x_8); -lean_dec(x_3); -x_245 = lean_ctor_get(x_232, 1); +lean_object* x_245; lean_object* x_246; uint8_t x_247; +x_245 = lean_ctor_get(x_210, 1); lean_inc(x_245); -lean_dec(x_232); -x_246 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 1); -lean_closure_set(x_246, 0, x_1); -lean_inc(x_9); -lean_inc(x_4); +lean_dec(x_210); +x_246 = lean_ctor_get(x_245, 4); lean_inc(x_246); -x_247 = l_Lean_Meta_inferTypeAuxAux___main(x_246, x_4, x_9, x_245); -if (lean_obj_tag(x_247) == 0) +x_247 = lean_ctor_get_uint8(x_246, sizeof(void*)*1); +lean_dec(x_246); +if (x_247 == 0) { -lean_object* x_248; lean_object* x_249; lean_object* x_250; -x_248 = lean_ctor_get(x_247, 0); -lean_inc(x_248); -x_249 = lean_ctor_get(x_247, 1); -lean_inc(x_249); -lean_dec(x_247); -lean_inc(x_9); -lean_inc(x_37); -x_250 = l_Lean_Meta_inferTypeAuxAux___main(x_246, x_37, x_9, x_249); -if (lean_obj_tag(x_250) == 0) +lean_object* x_248; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_248 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_248, 0, x_211); +lean_ctor_set(x_248, 1, x_245); +return x_248; +} +else { -lean_object* x_251; lean_object* x_252; uint8_t x_253; +lean_object* x_249; lean_object* x_250; lean_object* x_251; uint8_t x_252; +x_249 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3; +x_250 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_249, x_6, x_245); x_251 = lean_ctor_get(x_250, 0); lean_inc(x_251); -x_252 = lean_ctor_get(x_250, 1); -lean_inc(x_252); +x_252 = lean_unbox(x_251); +lean_dec(x_251); +if (x_252 == 0) +{ +lean_object* x_253; lean_object* x_254; lean_object* x_255; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_253 = lean_ctor_get(x_250, 1); +lean_inc(x_253); +if (lean_is_exclusive(x_250)) { + lean_ctor_release(x_250, 0); + lean_ctor_release(x_250, 1); + x_254 = x_250; +} else { + lean_dec_ref(x_250); + x_254 = lean_box(0); +} +if (lean_is_scalar(x_254)) { + x_255 = lean_alloc_ctor(0, 2, 0); +} else { + x_255 = x_254; +} +lean_ctor_set(x_255, 0, x_211); +lean_ctor_set(x_255, 1, x_253); +return x_255; +} +else +{ +lean_object* x_256; lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; lean_object* x_273; +x_256 = lean_ctor_get(x_250, 1); +lean_inc(x_256); lean_dec(x_250); -x_253 = !lean_is_exclusive(x_13); -if (x_253 == 0) -{ -uint8_t x_254; lean_object* x_255; lean_object* x_256; -x_254 = 1; -lean_ctor_set_uint8(x_13, sizeof(void*)*1 + 4, x_254); -x_255 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_255, 0, x_13); -lean_ctor_set(x_255, 1, x_14); -lean_ctor_set(x_255, 2, x_15); -lean_inc(x_251); -lean_inc(x_248); -x_256 = lean_apply_4(x_2, x_248, x_251, x_255, x_252); -if (lean_obj_tag(x_256) == 0) -{ -lean_object* x_257; uint8_t x_258; -x_257 = lean_ctor_get(x_256, 0); -lean_inc(x_257); -x_258 = lean_unbox(x_257); -if (x_258 == 0) -{ -uint8_t x_259; -lean_dec(x_21); -x_259 = !lean_is_exclusive(x_256); -if (x_259 == 0) -{ -lean_object* x_260; lean_object* x_261; lean_object* x_262; uint8_t x_263; -x_260 = lean_ctor_get(x_256, 1); -x_261 = lean_ctor_get(x_256, 0); -lean_dec(x_261); -x_262 = lean_ctor_get(x_260, 4); -lean_inc(x_262); -x_263 = lean_ctor_get_uint8(x_262, sizeof(void*)*1); -lean_dec(x_262); -if (x_263 == 0) -{ -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -return x_256; +x_257 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_257, 0, x_1); +x_258 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6; +x_259 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_259, 0, x_257); +lean_ctor_set(x_259, 1, x_258); +x_260 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_260, 0, x_202); +x_261 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_261, 0, x_259); +lean_ctor_set(x_261, 1, x_260); +x_262 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; +x_263 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_263, 0, x_261); +lean_ctor_set(x_263, 1, x_262); +x_264 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_264, 0, x_34); +x_265 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_265, 0, x_263); +lean_ctor_set(x_265, 1, x_264); +x_266 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_266, 0, x_265); +lean_ctor_set(x_266, 1, x_258); +x_267 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_267, 0, x_205); +x_268 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_268, 0, x_266); +lean_ctor_set(x_268, 1, x_267); +x_269 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; +x_270 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_269, x_268, x_6, x_256); +lean_dec(x_6); +x_271 = lean_ctor_get(x_270, 1); +lean_inc(x_271); +if (lean_is_exclusive(x_270)) { + lean_ctor_release(x_270, 0); + lean_ctor_release(x_270, 1); + x_272 = x_270; +} else { + lean_dec_ref(x_270); + x_272 = lean_box(0); +} +if (lean_is_scalar(x_272)) { + x_273 = lean_alloc_ctor(0, 2, 0); +} else { + x_273 = x_272; +} +lean_ctor_set(x_273, 0, x_211); +lean_ctor_set(x_273, 1, x_271); +return x_273; } -else -{ -lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; -lean_free_object(x_256); -x_264 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_265 = l_Lean_Meta_tracer; -x_266 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4; -x_267 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_264, x_265, x_266); -lean_inc(x_9); -x_268 = lean_apply_2(x_267, x_9, x_260); -if (lean_obj_tag(x_268) == 0) -{ -lean_object* x_269; uint8_t x_270; -x_269 = lean_ctor_get(x_268, 0); -lean_inc(x_269); -x_270 = lean_unbox(x_269); -lean_dec(x_269); -if (x_270 == 0) -{ -uint8_t x_271; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_271 = !lean_is_exclusive(x_268); -if (x_271 == 0) -{ -lean_object* x_272; -x_272 = lean_ctor_get(x_268, 0); -lean_dec(x_272); -lean_ctor_set(x_268, 0, x_257); -return x_268; } -else -{ -lean_object* x_273; lean_object* x_274; -x_273 = lean_ctor_get(x_268, 1); -lean_inc(x_273); -lean_dec(x_268); -x_274 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_274, 0, x_257); -lean_ctor_set(x_274, 1, x_273); -return x_274; } } else { -lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; -x_275 = lean_ctor_get(x_268, 1); -lean_inc(x_275); -lean_dec(x_268); -x_276 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_276, 0, x_4); -x_277 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7; -x_278 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_278, 0, x_276); -lean_ctor_set(x_278, 1, x_277); -x_279 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_279, 0, x_248); -x_280 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_280, 0, x_278); -lean_ctor_set(x_280, 1, x_279); -x_281 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; -x_282 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_282, 0, x_280); -lean_ctor_set(x_282, 1, x_281); -x_283 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_283, 0, x_37); -x_284 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_284, 0, x_282); -lean_ctor_set(x_284, 1, x_283); -x_285 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_285, 0, x_284); -lean_ctor_set(x_285, 1, x_277); -x_286 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_286, 0, x_251); -x_287 = lean_alloc_ctor(8, 2, 0); +lean_object* x_274; lean_object* x_275; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_1); +x_274 = lean_ctor_get(x_210, 1); +lean_inc(x_274); +lean_dec(x_210); +x_275 = l_Lean_Meta_assignExprMVar(x_18, x_34, x_6, x_274); +lean_dec(x_6); +if (lean_obj_tag(x_275) == 0) +{ +uint8_t x_276; +x_276 = !lean_is_exclusive(x_275); +if (x_276 == 0) +{ +lean_object* x_277; +x_277 = lean_ctor_get(x_275, 0); +lean_dec(x_277); +lean_ctor_set(x_275, 0, x_211); +return x_275; +} +else +{ +lean_object* x_278; lean_object* x_279; +x_278 = lean_ctor_get(x_275, 1); +lean_inc(x_278); +lean_dec(x_275); +x_279 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_279, 0, x_211); +lean_ctor_set(x_279, 1, x_278); +return x_279; +} +} +else +{ +uint8_t x_280; +lean_dec(x_211); +x_280 = !lean_is_exclusive(x_275); +if (x_280 == 0) +{ +return x_275; +} +else +{ +lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_281 = lean_ctor_get(x_275, 0); +x_282 = lean_ctor_get(x_275, 1); +lean_inc(x_282); +lean_inc(x_281); +lean_dec(x_275); +x_283 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_283, 0, x_281); +lean_ctor_set(x_283, 1, x_282); +return x_283; +} +} +} +} +else +{ +uint8_t x_284; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_6); +lean_dec(x_1); +x_284 = !lean_is_exclusive(x_210); +if (x_284 == 0) +{ +return x_210; +} +else +{ +lean_object* x_285; lean_object* x_286; lean_object* x_287; +x_285 = lean_ctor_get(x_210, 0); +x_286 = lean_ctor_get(x_210, 1); +lean_inc(x_286); +lean_inc(x_285); +lean_dec(x_210); +x_287 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_287, 0, x_285); lean_ctor_set(x_287, 1, x_286); -x_288 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_289 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; -x_290 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_288, x_289, x_287); -x_291 = lean_apply_2(x_290, x_9, x_275); -if (lean_obj_tag(x_291) == 0) -{ -uint8_t x_292; -x_292 = !lean_is_exclusive(x_291); -if (x_292 == 0) -{ -lean_object* x_293; -x_293 = lean_ctor_get(x_291, 0); -lean_dec(x_293); -lean_ctor_set(x_291, 0, x_257); -return x_291; +return x_287; } -else -{ -lean_object* x_294; lean_object* x_295; -x_294 = lean_ctor_get(x_291, 1); -lean_inc(x_294); -lean_dec(x_291); -x_295 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_295, 0, x_257); -lean_ctor_set(x_295, 1, x_294); -return x_295; } } else { -uint8_t x_296; -lean_dec(x_257); -x_296 = !lean_is_exclusive(x_291); -if (x_296 == 0) +lean_object* x_288; uint8_t x_289; uint8_t x_290; uint8_t x_291; uint8_t x_292; uint8_t x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +x_288 = lean_ctor_get(x_10, 0); +x_289 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 1); +x_290 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 2); +x_291 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 3); +x_292 = lean_ctor_get_uint8(x_10, sizeof(void*)*1 + 4); +lean_inc(x_288); +lean_dec(x_10); +x_293 = 1; +x_294 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_294, 0, x_288); +lean_ctor_set_uint8(x_294, sizeof(void*)*1, x_16); +lean_ctor_set_uint8(x_294, sizeof(void*)*1 + 1, x_289); +lean_ctor_set_uint8(x_294, sizeof(void*)*1 + 2, x_290); +lean_ctor_set_uint8(x_294, sizeof(void*)*1 + 3, x_291); +lean_ctor_set_uint8(x_294, sizeof(void*)*1 + 4, x_292); +lean_ctor_set_uint8(x_294, sizeof(void*)*1 + 5, x_293); +x_295 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_295, 0, x_294); +lean_ctor_set(x_295, 1, x_11); +lean_ctor_set(x_295, 2, x_12); +lean_inc(x_205); +lean_inc(x_202); +x_296 = l_Lean_Meta_isExprDefEqAux(x_202, x_205, x_295, x_206); +if (lean_obj_tag(x_296) == 0) { -return x_291; -} -else -{ -lean_object* x_297; lean_object* x_298; lean_object* x_299; -x_297 = lean_ctor_get(x_291, 0); -x_298 = lean_ctor_get(x_291, 1); -lean_inc(x_298); +lean_object* x_297; uint8_t x_298; +x_297 = lean_ctor_get(x_296, 0); lean_inc(x_297); -lean_dec(x_291); -x_299 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_299, 0, x_297); -lean_ctor_set(x_299, 1, x_298); -return x_299; -} -} -} -} -else +x_298 = lean_unbox(x_297); +if (x_298 == 0) { -uint8_t x_300; -lean_dec(x_257); -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_300 = !lean_is_exclusive(x_268); -if (x_300 == 0) -{ -return x_268; +lean_object* x_299; lean_object* x_300; lean_object* x_301; uint8_t x_302; +lean_dec(x_18); +x_299 = lean_ctor_get(x_296, 1); +lean_inc(x_299); +if (lean_is_exclusive(x_296)) { + lean_ctor_release(x_296, 0); + lean_ctor_release(x_296, 1); + x_300 = x_296; +} else { + lean_dec_ref(x_296); + x_300 = lean_box(0); } -else -{ -lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_301 = lean_ctor_get(x_268, 0); -x_302 = lean_ctor_get(x_268, 1); -lean_inc(x_302); +x_301 = lean_ctor_get(x_299, 4); lean_inc(x_301); -lean_dec(x_268); -x_303 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_303, 0, x_301); -lean_ctor_set(x_303, 1, x_302); +x_302 = lean_ctor_get_uint8(x_301, sizeof(void*)*1); +lean_dec(x_301); +if (x_302 == 0) +{ +lean_object* x_303; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +if (lean_is_scalar(x_300)) { + x_303 = lean_alloc_ctor(0, 2, 0); +} else { + x_303 = x_300; +} +lean_ctor_set(x_303, 0, x_297); +lean_ctor_set(x_303, 1, x_299); return x_303; } +else +{ +lean_object* x_304; lean_object* x_305; lean_object* x_306; uint8_t x_307; +lean_dec(x_300); +x_304 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3; +x_305 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_304, x_6, x_299); +x_306 = lean_ctor_get(x_305, 0); +lean_inc(x_306); +x_307 = lean_unbox(x_306); +lean_dec(x_306); +if (x_307 == 0) +{ +lean_object* x_308; lean_object* x_309; lean_object* x_310; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_6); +lean_dec(x_1); +x_308 = lean_ctor_get(x_305, 1); +lean_inc(x_308); +if (lean_is_exclusive(x_305)) { + lean_ctor_release(x_305, 0); + lean_ctor_release(x_305, 1); + x_309 = x_305; +} else { + lean_dec_ref(x_305); + x_309 = lean_box(0); } +if (lean_is_scalar(x_309)) { + x_310 = lean_alloc_ctor(0, 2, 0); +} else { + x_310 = x_309; } +lean_ctor_set(x_310, 0, x_297); +lean_ctor_set(x_310, 1, x_308); +return x_310; } else { -lean_object* x_304; lean_object* x_305; uint8_t x_306; -x_304 = lean_ctor_get(x_256, 1); -lean_inc(x_304); -lean_dec(x_256); -x_305 = lean_ctor_get(x_304, 4); -lean_inc(x_305); -x_306 = lean_ctor_get_uint8(x_305, sizeof(void*)*1); +lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; +x_311 = lean_ctor_get(x_305, 1); +lean_inc(x_311); lean_dec(x_305); -if (x_306 == 0) -{ -lean_object* x_307; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_307 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_307, 0, x_257); -lean_ctor_set(x_307, 1, x_304); -return x_307; -} -else -{ -lean_object* x_308; lean_object* x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; -x_308 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_309 = l_Lean_Meta_tracer; -x_310 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4; -x_311 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_308, x_309, x_310); -lean_inc(x_9); -x_312 = lean_apply_2(x_311, x_9, x_304); -if (lean_obj_tag(x_312) == 0) -{ -lean_object* x_313; uint8_t x_314; -x_313 = lean_ctor_get(x_312, 0); -lean_inc(x_313); -x_314 = lean_unbox(x_313); -lean_dec(x_313); -if (x_314 == 0) -{ -lean_object* x_315; lean_object* x_316; lean_object* x_317; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_315 = lean_ctor_get(x_312, 1); -lean_inc(x_315); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - x_316 = x_312; -} else { - lean_dec_ref(x_312); - x_316 = lean_box(0); -} -if (lean_is_scalar(x_316)) { - x_317 = lean_alloc_ctor(0, 2, 0); -} else { - x_317 = x_316; -} -lean_ctor_set(x_317, 0, x_257); -lean_ctor_set(x_317, 1, x_315); -return x_317; -} -else -{ -lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; -x_318 = lean_ctor_get(x_312, 1); -lean_inc(x_318); -lean_dec(x_312); +x_312 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_312, 0, x_1); +x_313 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6; +x_314 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_314, 0, x_312); +lean_ctor_set(x_314, 1, x_313); +x_315 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_315, 0, x_202); +x_316 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_316, 0, x_314); +lean_ctor_set(x_316, 1, x_315); +x_317 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10; +x_318 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_318, 0, x_316); +lean_ctor_set(x_318, 1, x_317); x_319 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_319, 0, x_4); -x_320 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7; +lean_ctor_set(x_319, 0, x_34); +x_320 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_320, 0, x_318); +lean_ctor_set(x_320, 1, x_319); x_321 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_321, 0, x_319); -lean_ctor_set(x_321, 1, x_320); +lean_ctor_set(x_321, 0, x_320); +lean_ctor_set(x_321, 1, x_313); x_322 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_322, 0, x_248); +lean_ctor_set(x_322, 0, x_205); x_323 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_323, 0, x_321); lean_ctor_set(x_323, 1, x_322); -x_324 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; -x_325 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_325, 0, x_323); -lean_ctor_set(x_325, 1, x_324); -x_326 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_326, 0, x_37); -x_327 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_327, 0, x_325); -lean_ctor_set(x_327, 1, x_326); -x_328 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_328, 0, x_327); -lean_ctor_set(x_328, 1, x_320); -x_329 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_329, 0, x_251); -x_330 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_330, 0, x_328); -lean_ctor_set(x_330, 1, x_329); -x_331 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_332 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; -x_333 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_331, x_332, x_330); -x_334 = lean_apply_2(x_333, x_9, x_318); -if (lean_obj_tag(x_334) == 0) -{ -lean_object* x_335; lean_object* x_336; lean_object* x_337; -x_335 = lean_ctor_get(x_334, 1); -lean_inc(x_335); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - x_336 = x_334; +x_324 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2; +x_325 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_324, x_323, x_6, x_311); +lean_dec(x_6); +x_326 = lean_ctor_get(x_325, 1); +lean_inc(x_326); +if (lean_is_exclusive(x_325)) { + lean_ctor_release(x_325, 0); + lean_ctor_release(x_325, 1); + x_327 = x_325; } else { - lean_dec_ref(x_334); + lean_dec_ref(x_325); + x_327 = lean_box(0); +} +if (lean_is_scalar(x_327)) { + x_328 = lean_alloc_ctor(0, 2, 0); +} else { + x_328 = x_327; +} +lean_ctor_set(x_328, 0, x_297); +lean_ctor_set(x_328, 1, x_326); +return x_328; +} +} +} +else +{ +lean_object* x_329; lean_object* x_330; +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_1); +x_329 = lean_ctor_get(x_296, 1); +lean_inc(x_329); +lean_dec(x_296); +x_330 = l_Lean_Meta_assignExprMVar(x_18, x_34, x_6, x_329); +lean_dec(x_6); +if (lean_obj_tag(x_330) == 0) +{ +lean_object* x_331; lean_object* x_332; lean_object* x_333; +x_331 = lean_ctor_get(x_330, 1); +lean_inc(x_331); +if (lean_is_exclusive(x_330)) { + lean_ctor_release(x_330, 0); + lean_ctor_release(x_330, 1); + x_332 = x_330; +} else { + lean_dec_ref(x_330); + x_332 = lean_box(0); +} +if (lean_is_scalar(x_332)) { + x_333 = lean_alloc_ctor(0, 2, 0); +} else { + x_333 = x_332; +} +lean_ctor_set(x_333, 0, x_297); +lean_ctor_set(x_333, 1, x_331); +return x_333; +} +else +{ +lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; +lean_dec(x_297); +x_334 = lean_ctor_get(x_330, 0); +lean_inc(x_334); +x_335 = lean_ctor_get(x_330, 1); +lean_inc(x_335); +if (lean_is_exclusive(x_330)) { + lean_ctor_release(x_330, 0); + lean_ctor_release(x_330, 1); + x_336 = x_330; +} else { + lean_dec_ref(x_330); x_336 = lean_box(0); } if (lean_is_scalar(x_336)) { - x_337 = lean_alloc_ctor(0, 2, 0); + x_337 = lean_alloc_ctor(1, 2, 0); } else { x_337 = x_336; } -lean_ctor_set(x_337, 0, x_257); +lean_ctor_set(x_337, 0, x_334); lean_ctor_set(x_337, 1, x_335); return x_337; } +} +} else { lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; -lean_dec(x_257); -x_338 = lean_ctor_get(x_334, 0); +lean_dec(x_205); +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_6); +lean_dec(x_1); +x_338 = lean_ctor_get(x_296, 0); lean_inc(x_338); -x_339 = lean_ctor_get(x_334, 1); +x_339 = lean_ctor_get(x_296, 1); lean_inc(x_339); -if (lean_is_exclusive(x_334)) { - lean_ctor_release(x_334, 0); - lean_ctor_release(x_334, 1); - x_340 = x_334; +if (lean_is_exclusive(x_296)) { + lean_ctor_release(x_296, 0); + lean_ctor_release(x_296, 1); + x_340 = x_296; } else { - lean_dec_ref(x_334); + lean_dec_ref(x_296); x_340 = lean_box(0); } if (lean_is_scalar(x_340)) { @@ -9997,1284 +13776,806 @@ return x_341; } else { -lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; -lean_dec(x_257); -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_342 = lean_ctor_get(x_312, 0); -lean_inc(x_342); -x_343 = lean_ctor_get(x_312, 1); +uint8_t x_342; +lean_dec(x_202); +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_1); +x_342 = !lean_is_exclusive(x_204); +if (x_342 == 0) +{ +return x_204; +} +else +{ +lean_object* x_343; lean_object* x_344; lean_object* x_345; +x_343 = lean_ctor_get(x_204, 0); +x_344 = lean_ctor_get(x_204, 1); +lean_inc(x_344); lean_inc(x_343); -if (lean_is_exclusive(x_312)) { - lean_ctor_release(x_312, 0); - lean_ctor_release(x_312, 1); - x_344 = x_312; -} else { - lean_dec_ref(x_312); - x_344 = lean_box(0); -} -if (lean_is_scalar(x_344)) { - x_345 = lean_alloc_ctor(1, 2, 0); -} else { - x_345 = x_344; -} -lean_ctor_set(x_345, 0, x_342); -lean_ctor_set(x_345, 1, x_343); +lean_dec(x_204); +x_345 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_345, 0, x_343); +lean_ctor_set(x_345, 1, x_344); return x_345; } } } +else +{ +uint8_t x_346; +lean_dec(x_34); +lean_dec(x_18); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_6); +lean_dec(x_1); +x_346 = !lean_is_exclusive(x_201); +if (x_346 == 0) +{ +return x_201; } else { -lean_object* x_346; lean_object* x_347; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_4); -x_346 = lean_ctor_get(x_256, 1); -lean_inc(x_346); -lean_dec(x_256); -x_347 = l_Lean_Meta_assignExprMVar(x_21, x_37, x_9, x_346); -lean_dec(x_9); -if (lean_obj_tag(x_347) == 0) -{ -uint8_t x_348; -x_348 = !lean_is_exclusive(x_347); -if (x_348 == 0) -{ -lean_object* x_349; -x_349 = lean_ctor_get(x_347, 0); -lean_dec(x_349); -lean_ctor_set(x_347, 0, x_257); -return x_347; +lean_object* x_347; lean_object* x_348; lean_object* x_349; +x_347 = lean_ctor_get(x_201, 0); +x_348 = lean_ctor_get(x_201, 1); +lean_inc(x_348); +lean_inc(x_347); +lean_dec(x_201); +x_349 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_349, 0, x_347); +lean_ctor_set(x_349, 1, x_348); +return x_349; } -else -{ -lean_object* x_350; lean_object* x_351; -x_350 = lean_ctor_get(x_347, 1); -lean_inc(x_350); -lean_dec(x_347); -x_351 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_351, 0, x_257); -lean_ctor_set(x_351, 1, x_350); -return x_351; -} -} -else -{ -uint8_t x_352; -lean_dec(x_257); -x_352 = !lean_is_exclusive(x_347); -if (x_352 == 0) -{ -return x_347; -} -else -{ -lean_object* x_353; lean_object* x_354; lean_object* x_355; -x_353 = lean_ctor_get(x_347, 0); -x_354 = lean_ctor_get(x_347, 1); -lean_inc(x_354); -lean_inc(x_353); -lean_dec(x_347); -x_355 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_355, 0, x_353); -lean_ctor_set(x_355, 1, x_354); -return x_355; } } } } else { -uint8_t x_356; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_9); -lean_dec(x_4); -x_356 = !lean_is_exclusive(x_256); -if (x_356 == 0) +uint8_t x_350; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_350 = !lean_is_exclusive(x_33); +if (x_350 == 0) { -return x_256; +return x_33; } else { -lean_object* x_357; lean_object* x_358; lean_object* x_359; -x_357 = lean_ctor_get(x_256, 0); -x_358 = lean_ctor_get(x_256, 1); -lean_inc(x_358); -lean_inc(x_357); -lean_dec(x_256); -x_359 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_359, 0, x_357); -lean_ctor_set(x_359, 1, x_358); -return x_359; +lean_object* x_351; lean_object* x_352; lean_object* x_353; +x_351 = lean_ctor_get(x_33, 0); +x_352 = lean_ctor_get(x_33, 1); +lean_inc(x_352); +lean_inc(x_351); +lean_dec(x_33); +x_353 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_353, 0, x_351); +lean_ctor_set(x_353, 1, x_352); +return x_353; +} } } } else { -lean_object* x_360; uint8_t x_361; uint8_t x_362; uint8_t x_363; uint8_t x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; -x_360 = lean_ctor_get(x_13, 0); -x_361 = lean_ctor_get_uint8(x_13, sizeof(void*)*1 + 1); -x_362 = lean_ctor_get_uint8(x_13, sizeof(void*)*1 + 2); -x_363 = lean_ctor_get_uint8(x_13, sizeof(void*)*1 + 3); -lean_inc(x_360); -lean_dec(x_13); -x_364 = 1; -x_365 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_365, 0, x_360); -lean_ctor_set_uint8(x_365, sizeof(void*)*1, x_19); -lean_ctor_set_uint8(x_365, sizeof(void*)*1 + 1, x_361); -lean_ctor_set_uint8(x_365, sizeof(void*)*1 + 2, x_362); -lean_ctor_set_uint8(x_365, sizeof(void*)*1 + 3, x_363); -lean_ctor_set_uint8(x_365, sizeof(void*)*1 + 4, x_364); -x_366 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_366, 0, x_365); -lean_ctor_set(x_366, 1, x_14); -lean_ctor_set(x_366, 2, x_15); -lean_inc(x_251); -lean_inc(x_248); -x_367 = lean_apply_4(x_2, x_248, x_251, x_366, x_252); -if (lean_obj_tag(x_367) == 0) +uint8_t x_354; +lean_dec(x_18); +lean_dec(x_14); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_354 = !lean_is_exclusive(x_19); +if (x_354 == 0) { -lean_object* x_368; uint8_t x_369; -x_368 = lean_ctor_get(x_367, 0); -lean_inc(x_368); -x_369 = lean_unbox(x_368); +return x_19; +} +else +{ +lean_object* x_355; lean_object* x_356; lean_object* x_357; +x_355 = lean_ctor_get(x_19, 0); +x_356 = lean_ctor_get(x_19, 1); +lean_inc(x_356); +lean_inc(x_355); +lean_dec(x_19); +x_357 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_357, 0, x_355); +lean_ctor_set(x_357, 1, x_356); +return x_357; +} +} +} +} +else +{ +lean_object* x_366; lean_object* x_367; lean_object* x_368; +lean_dec(x_8); +x_366 = lean_ctor_get(x_6, 0); +lean_inc(x_366); +x_367 = lean_array_fget(x_5, x_4); +lean_inc(x_6); +x_368 = l___private_Init_Lean_Meta_ExprDefEq_16__simpAssignmentArg(x_367, x_6, x_7); +if (lean_obj_tag(x_368) == 0) +{ +uint8_t x_369; +x_369 = !lean_is_exclusive(x_368); if (x_369 == 0) { -lean_object* x_370; lean_object* x_371; lean_object* x_372; uint8_t x_373; -lean_dec(x_21); -x_370 = lean_ctor_get(x_367, 1); +lean_object* x_370; lean_object* x_371; lean_object* x_372; +x_370 = lean_ctor_get(x_368, 0); +x_371 = lean_ctor_get(x_368, 1); lean_inc(x_370); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_371 = x_367; -} else { - lean_dec_ref(x_367); - x_371 = lean_box(0); -} -x_372 = lean_ctor_get(x_370, 4); -lean_inc(x_372); -x_373 = lean_ctor_get_uint8(x_372, sizeof(void*)*1); -lean_dec(x_372); -if (x_373 == 0) +lean_inc(x_5); +x_372 = lean_array_fset(x_5, x_4, x_370); +if (lean_obj_tag(x_370) == 1) { -lean_object* x_374; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -if (lean_is_scalar(x_371)) { - x_374 = lean_alloc_ctor(0, 2, 0); -} else { - x_374 = x_371; -} -lean_ctor_set(x_374, 0, x_368); -lean_ctor_set(x_374, 1, x_370); -return x_374; -} -else +lean_object* x_373; lean_object* x_374; uint8_t x_375; +x_373 = lean_ctor_get(x_370, 0); +lean_inc(x_373); +x_374 = lean_array_get_size(x_372); +x_375 = lean_nat_dec_le(x_4, x_374); +if (x_375 == 0) { -lean_object* x_375; lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; -lean_dec(x_371); -x_375 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_376 = l_Lean_Meta_tracer; -x_377 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4; -x_378 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_375, x_376, x_377); -lean_inc(x_9); -x_379 = lean_apply_2(x_378, x_9, x_370); -if (lean_obj_tag(x_379) == 0) -{ -lean_object* x_380; uint8_t x_381; -x_380 = lean_ctor_get(x_379, 0); -lean_inc(x_380); -x_381 = lean_unbox(x_380); -lean_dec(x_380); -if (x_381 == 0) -{ -lean_object* x_382; lean_object* x_383; lean_object* x_384; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_382 = lean_ctor_get(x_379, 1); -lean_inc(x_382); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - x_383 = x_379; -} else { - lean_dec_ref(x_379); - x_383 = lean_box(0); -} -if (lean_is_scalar(x_383)) { - x_384 = lean_alloc_ctor(0, 2, 0); -} else { - x_384 = x_383; -} -lean_ctor_set(x_384, 0, x_368); -lean_ctor_set(x_384, 1, x_382); -return x_384; -} -else -{ -lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; lean_object* x_401; -x_385 = lean_ctor_get(x_379, 1); -lean_inc(x_385); -lean_dec(x_379); -x_386 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_386, 0, x_4); -x_387 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7; -x_388 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_388, 0, x_386); -lean_ctor_set(x_388, 1, x_387); -x_389 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_389, 0, x_248); -x_390 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_390, 0, x_388); -lean_ctor_set(x_390, 1, x_389); -x_391 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10; -x_392 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_392, 0, x_390); -lean_ctor_set(x_392, 1, x_391); -x_393 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_393, 0, x_37); -x_394 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_394, 0, x_392); -lean_ctor_set(x_394, 1, x_393); -x_395 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_395, 0, x_394); -lean_ctor_set(x_395, 1, x_387); -x_396 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_396, 0, x_251); -x_397 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_397, 0, x_395); -lean_ctor_set(x_397, 1, x_396); -x_398 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_399 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3; -x_400 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_398, x_399, x_397); -x_401 = lean_apply_2(x_400, x_9, x_385); -if (lean_obj_tag(x_401) == 0) -{ -lean_object* x_402; lean_object* x_403; lean_object* x_404; -x_402 = lean_ctor_get(x_401, 1); -lean_inc(x_402); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - x_403 = x_401; -} else { - lean_dec_ref(x_401); - x_403 = lean_box(0); -} -if (lean_is_scalar(x_403)) { - x_404 = lean_alloc_ctor(0, 2, 0); -} else { - x_404 = x_403; -} -lean_ctor_set(x_404, 0, x_368); -lean_ctor_set(x_404, 1, x_402); -return x_404; -} -else -{ -lean_object* x_405; lean_object* x_406; lean_object* x_407; lean_object* x_408; -lean_dec(x_368); -x_405 = lean_ctor_get(x_401, 0); -lean_inc(x_405); -x_406 = lean_ctor_get(x_401, 1); -lean_inc(x_406); -if (lean_is_exclusive(x_401)) { - lean_ctor_release(x_401, 0); - lean_ctor_release(x_401, 1); - x_407 = x_401; -} else { - lean_dec_ref(x_401); - x_407 = lean_box(0); -} -if (lean_is_scalar(x_407)) { - x_408 = lean_alloc_ctor(1, 2, 0); -} else { - x_408 = x_407; -} -lean_ctor_set(x_408, 0, x_405); -lean_ctor_set(x_408, 1, x_406); -return x_408; -} -} -} -else -{ -lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; -lean_dec(x_368); -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_9); -lean_dec(x_4); -x_409 = lean_ctor_get(x_379, 0); -lean_inc(x_409); -x_410 = lean_ctor_get(x_379, 1); -lean_inc(x_410); -if (lean_is_exclusive(x_379)) { - lean_ctor_release(x_379, 0); - lean_ctor_release(x_379, 1); - x_411 = x_379; -} else { - lean_dec_ref(x_379); - x_411 = lean_box(0); -} -if (lean_is_scalar(x_411)) { - x_412 = lean_alloc_ctor(1, 2, 0); -} else { - x_412 = x_411; -} -lean_ctor_set(x_412, 0, x_409); -lean_ctor_set(x_412, 1, x_410); -return x_412; -} -} -} -else -{ -lean_object* x_413; lean_object* x_414; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_4); -x_413 = lean_ctor_get(x_367, 1); -lean_inc(x_413); -lean_dec(x_367); -x_414 = l_Lean_Meta_assignExprMVar(x_21, x_37, x_9, x_413); -lean_dec(x_9); -if (lean_obj_tag(x_414) == 0) -{ -lean_object* x_415; lean_object* x_416; lean_object* x_417; -x_415 = lean_ctor_get(x_414, 1); -lean_inc(x_415); -if (lean_is_exclusive(x_414)) { - lean_ctor_release(x_414, 0); - lean_ctor_release(x_414, 1); - x_416 = x_414; -} else { - lean_dec_ref(x_414); - x_416 = lean_box(0); -} -if (lean_is_scalar(x_416)) { - x_417 = lean_alloc_ctor(0, 2, 0); -} else { - x_417 = x_416; -} -lean_ctor_set(x_417, 0, x_368); -lean_ctor_set(x_417, 1, x_415); -return x_417; -} -else -{ -lean_object* x_418; lean_object* x_419; lean_object* x_420; lean_object* x_421; -lean_dec(x_368); -x_418 = lean_ctor_get(x_414, 0); -lean_inc(x_418); -x_419 = lean_ctor_get(x_414, 1); -lean_inc(x_419); -if (lean_is_exclusive(x_414)) { - lean_ctor_release(x_414, 0); - lean_ctor_release(x_414, 1); - x_420 = x_414; -} else { - lean_dec_ref(x_414); - x_420 = lean_box(0); -} -if (lean_is_scalar(x_420)) { - x_421 = lean_alloc_ctor(1, 2, 0); -} else { - x_421 = x_420; -} -lean_ctor_set(x_421, 0, x_418); -lean_ctor_set(x_421, 1, x_419); -return x_421; -} -} -} -else -{ -lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; -lean_dec(x_251); -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_9); -lean_dec(x_4); -x_422 = lean_ctor_get(x_367, 0); -lean_inc(x_422); -x_423 = lean_ctor_get(x_367, 1); -lean_inc(x_423); -if (lean_is_exclusive(x_367)) { - lean_ctor_release(x_367, 0); - lean_ctor_release(x_367, 1); - x_424 = x_367; -} else { - lean_dec_ref(x_367); - x_424 = lean_box(0); -} -if (lean_is_scalar(x_424)) { - x_425 = lean_alloc_ctor(1, 2, 0); -} else { - x_425 = x_424; -} -lean_ctor_set(x_425, 0, x_422); -lean_ctor_set(x_425, 1, x_423); -return x_425; -} -} -} -else -{ -uint8_t x_426; -lean_dec(x_248); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_9); -lean_dec(x_4); -lean_dec(x_2); -x_426 = !lean_is_exclusive(x_250); -if (x_426 == 0) -{ -return x_250; -} -else -{ -lean_object* x_427; lean_object* x_428; lean_object* x_429; -x_427 = lean_ctor_get(x_250, 0); -x_428 = lean_ctor_get(x_250, 1); -lean_inc(x_428); -lean_inc(x_427); -lean_dec(x_250); -x_429 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_429, 0, x_427); -lean_ctor_set(x_429, 1, x_428); -return x_429; -} -} -} -else -{ -uint8_t x_430; -lean_dec(x_246); -lean_dec(x_37); -lean_dec(x_21); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_9); -lean_dec(x_4); -lean_dec(x_2); -x_430 = !lean_is_exclusive(x_247); -if (x_430 == 0) -{ -return x_247; -} -else -{ -lean_object* x_431; lean_object* x_432; lean_object* x_433; -x_431 = lean_ctor_get(x_247, 0); -x_432 = lean_ctor_get(x_247, 1); -lean_inc(x_432); -lean_inc(x_431); -lean_dec(x_247); -x_433 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_433, 0, x_431); -lean_ctor_set(x_433, 1, x_432); -return x_433; -} -} -} -} -} -else -{ -uint8_t x_434; -lean_dec(x_21); -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); +lean_object* x_376; uint8_t x_377; +x_376 = lean_unsigned_to_nat(0u); +x_377 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__2(x_4, x_5, lean_box(0), x_370, x_372, x_374, x_376); +lean_dec(x_374); +lean_dec(x_370); lean_dec(x_5); +if (x_377 == 0) +{ +lean_object* x_378; uint8_t x_379; +x_378 = lean_ctor_get(x_2, 1); +x_379 = l_Lean_LocalContext_contains(x_378, x_373); +lean_dec(x_373); +if (x_379 == 0) +{ +lean_object* x_380; lean_object* x_381; +lean_free_object(x_368); +lean_dec(x_366); +x_380 = lean_unsigned_to_nat(1u); +x_381 = lean_nat_add(x_4, x_380); lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_434 = !lean_is_exclusive(x_36); -if (x_434 == 0) -{ -return x_36; -} -else -{ -lean_object* x_435; lean_object* x_436; lean_object* x_437; -x_435 = lean_ctor_get(x_36, 0); -x_436 = lean_ctor_get(x_36, 1); -lean_inc(x_436); -lean_inc(x_435); -lean_dec(x_36); -x_437 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_437, 0, x_435); -lean_ctor_set(x_437, 1, x_436); -return x_437; -} -} -} -} -else -{ -uint8_t x_438; -lean_dec(x_21); -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_438 = !lean_is_exclusive(x_22); -if (x_438 == 0) -{ -return x_22; -} -else -{ -lean_object* x_439; lean_object* x_440; lean_object* x_441; -x_439 = lean_ctor_get(x_22, 0); -x_440 = lean_ctor_get(x_22, 1); -lean_inc(x_440); -lean_inc(x_439); -lean_dec(x_22); -x_441 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_441, 0, x_439); -lean_ctor_set(x_441, 1, x_440); -return x_441; -} -} -} -} -else -{ -lean_object* x_450; lean_object* x_451; lean_object* x_452; -lean_dec(x_11); -x_450 = lean_ctor_get(x_9, 0); -lean_inc(x_450); -x_451 = lean_array_fget(x_8, x_7); -lean_inc(x_9); -x_452 = l___private_Init_Lean_Meta_ExprDefEq_13__simpAssignmentArg(x_451, x_9, x_10); -if (lean_obj_tag(x_452) == 0) -{ -uint8_t x_453; -x_453 = !lean_is_exclusive(x_452); -if (x_453 == 0) -{ -lean_object* x_454; lean_object* x_455; lean_object* x_456; -x_454 = lean_ctor_get(x_452, 0); -x_455 = lean_ctor_get(x_452, 1); -lean_inc(x_454); -x_456 = lean_array_fset(x_8, x_7, x_454); -if (lean_obj_tag(x_454) == 1) -{ -lean_object* x_457; lean_object* x_458; lean_object* x_459; uint8_t x_460; -x_457 = lean_ctor_get(x_454, 0); -lean_inc(x_457); -x_458 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__2___boxed), 2, 1); -lean_closure_set(x_458, 0, x_454); -x_459 = lean_array_get_size(x_456); -x_460 = lean_nat_dec_le(x_7, x_459); -if (x_460 == 0) -{ -lean_object* x_461; lean_object* x_462; lean_object* x_463; uint8_t x_464; -x_461 = l_Id_Monad; -x_462 = lean_unsigned_to_nat(0u); -lean_inc(x_456); -x_463 = l_Array_anyRangeMAux___main___rarg(x_461, x_456, x_459, lean_box(0), x_458, x_462); -x_464 = lean_unbox(x_463); -lean_dec(x_463); -if (x_464 == 0) -{ -lean_object* x_465; uint8_t x_466; -x_465 = lean_ctor_get(x_5, 1); -lean_inc(x_465); -x_466 = l_Lean_LocalContext_contains(x_465, x_457); -lean_dec(x_457); -lean_dec(x_465); -if (x_466 == 0) -{ -lean_object* x_467; lean_object* x_468; -lean_free_object(x_452); -lean_dec(x_450); -x_467 = lean_unsigned_to_nat(1u); -x_468 = lean_nat_add(x_7, x_467); -lean_dec(x_7); -x_7 = x_468; -x_8 = x_456; -x_10 = x_455; +x_4 = x_381; +x_5 = x_372; +x_7 = x_371; goto _start; } else { -uint8_t x_470; -x_470 = lean_ctor_get_uint8(x_450, sizeof(void*)*1 + 2); -if (x_470 == 0) +uint8_t x_383; +x_383 = lean_ctor_get_uint8(x_366, sizeof(void*)*1 + 2); +if (x_383 == 0) { -uint8_t x_471; -lean_dec(x_7); -lean_dec(x_5); -x_471 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_471 == 0) -{ -uint8_t x_472; lean_object* x_473; -lean_dec(x_456); -lean_dec(x_9); -lean_dec(x_6); +uint8_t x_384; lean_dec(x_4); +x_384 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_384 == 0) +{ +uint8_t x_385; lean_object* x_386; +lean_dec(x_372); +lean_dec(x_6); lean_dec(x_3); -lean_dec(x_2); lean_dec(x_1); -x_472 = 0; -x_473 = lean_box(x_472); -lean_ctor_set(x_452, 0, x_473); -return x_452; +x_385 = 0; +x_386 = lean_box(x_385); +lean_ctor_set(x_368, 0, x_386); +return x_368; } else { -lean_object* x_474; -lean_free_object(x_452); -x_474 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_456, x_6, x_9, x_455); +lean_object* x_387; +lean_free_object(x_368); +x_387 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_372, x_3, x_6, x_371); +lean_dec(x_372); +return x_387; +} +} +else +{ +lean_object* x_388; lean_object* x_389; +lean_free_object(x_368); +lean_dec(x_366); +x_388 = lean_unsigned_to_nat(1u); +x_389 = lean_nat_add(x_4, x_388); +lean_dec(x_4); +x_4 = x_389; +x_5 = x_372; +x_7 = x_371; +goto _start; +} +} +} +else +{ +uint8_t x_391; +lean_dec(x_373); +lean_dec(x_4); +x_391 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_391 == 0) +{ +uint8_t x_392; lean_object* x_393; +lean_dec(x_372); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_392 = 0; +x_393 = lean_box(x_392); +lean_ctor_set(x_368, 0, x_393); +return x_368; +} +else +{ +lean_object* x_394; +lean_free_object(x_368); +x_394 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_372, x_3, x_6, x_371); +lean_dec(x_372); +return x_394; +} +} +} +else +{ +lean_object* x_395; uint8_t x_396; +lean_dec(x_374); +x_395 = lean_unsigned_to_nat(0u); +x_396 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__3(x_4, x_5, lean_box(0), x_370, lean_box(0), x_372, x_4, x_395); +lean_dec(x_370); +lean_dec(x_5); +if (x_396 == 0) +{ +lean_object* x_397; uint8_t x_398; +x_397 = lean_ctor_get(x_2, 1); +x_398 = l_Lean_LocalContext_contains(x_397, x_373); +lean_dec(x_373); +if (x_398 == 0) +{ +lean_object* x_399; lean_object* x_400; +lean_free_object(x_368); +lean_dec(x_366); +x_399 = lean_unsigned_to_nat(1u); +x_400 = lean_nat_add(x_4, x_399); +lean_dec(x_4); +x_4 = x_400; +x_5 = x_372; +x_7 = x_371; +goto _start; +} +else +{ +uint8_t x_402; +x_402 = lean_ctor_get_uint8(x_366, sizeof(void*)*1 + 2); +if (x_402 == 0) +{ +uint8_t x_403; +lean_dec(x_4); +x_403 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_403 == 0) +{ +uint8_t x_404; lean_object* x_405; +lean_dec(x_372); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_404 = 0; +x_405 = lean_box(x_404); +lean_ctor_set(x_368, 0, x_405); +return x_368; +} +else +{ +lean_object* x_406; +lean_free_object(x_368); +x_406 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_372, x_3, x_6, x_371); +lean_dec(x_372); +return x_406; +} +} +else +{ +lean_object* x_407; lean_object* x_408; +lean_free_object(x_368); +lean_dec(x_366); +x_407 = lean_unsigned_to_nat(1u); +x_408 = lean_nat_add(x_4, x_407); +lean_dec(x_4); +x_4 = x_408; +x_5 = x_372; +x_7 = x_371; +goto _start; +} +} +} +else +{ +uint8_t x_410; +lean_dec(x_373); +lean_dec(x_4); +x_410 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_410 == 0) +{ +uint8_t x_411; lean_object* x_412; +lean_dec(x_372); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_411 = 0; +x_412 = lean_box(x_411); +lean_ctor_set(x_368, 0, x_412); +return x_368; +} +else +{ +lean_object* x_413; +lean_free_object(x_368); +x_413 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_372, x_3, x_6, x_371); +lean_dec(x_372); +return x_413; +} +} +} +} +else +{ +uint8_t x_414; +lean_dec(x_370); +lean_dec(x_5); +lean_dec(x_4); +x_414 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_414 == 0) +{ +uint8_t x_415; lean_object* x_416; +lean_dec(x_372); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_415 = 0; +x_416 = lean_box(x_415); +lean_ctor_set(x_368, 0, x_416); +return x_368; +} +else +{ +lean_object* x_417; +lean_free_object(x_368); +x_417 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_372, x_3, x_6, x_371); +lean_dec(x_372); +return x_417; +} +} +} +else +{ +lean_object* x_418; lean_object* x_419; lean_object* x_420; +x_418 = lean_ctor_get(x_368, 0); +x_419 = lean_ctor_get(x_368, 1); +lean_inc(x_419); +lean_inc(x_418); +lean_dec(x_368); +lean_inc(x_418); +lean_inc(x_5); +x_420 = lean_array_fset(x_5, x_4, x_418); +if (lean_obj_tag(x_418) == 1) +{ +lean_object* x_421; lean_object* x_422; uint8_t x_423; +x_421 = lean_ctor_get(x_418, 0); +lean_inc(x_421); +x_422 = lean_array_get_size(x_420); +x_423 = lean_nat_dec_le(x_4, x_422); +if (x_423 == 0) +{ +lean_object* x_424; uint8_t x_425; +x_424 = lean_unsigned_to_nat(0u); +x_425 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__2(x_4, x_5, lean_box(0), x_418, x_420, x_422, x_424); +lean_dec(x_422); +lean_dec(x_418); +lean_dec(x_5); +if (x_425 == 0) +{ +lean_object* x_426; uint8_t x_427; +x_426 = lean_ctor_get(x_2, 1); +x_427 = l_Lean_LocalContext_contains(x_426, x_421); +lean_dec(x_421); +if (x_427 == 0) +{ +lean_object* x_428; lean_object* x_429; +lean_dec(x_366); +x_428 = lean_unsigned_to_nat(1u); +x_429 = lean_nat_add(x_4, x_428); +lean_dec(x_4); +x_4 = x_429; +x_5 = x_420; +x_7 = x_419; +goto _start; +} +else +{ +uint8_t x_431; +x_431 = lean_ctor_get_uint8(x_366, sizeof(void*)*1 + 2); +if (x_431 == 0) +{ +uint8_t x_432; +lean_dec(x_4); +x_432 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_432 == 0) +{ +uint8_t x_433; lean_object* x_434; lean_object* x_435; +lean_dec(x_420); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_433 = 0; +x_434 = lean_box(x_433); +x_435 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_435, 0, x_434); +lean_ctor_set(x_435, 1, x_419); +return x_435; +} +else +{ +lean_object* x_436; +x_436 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_420, x_3, x_6, x_419); +lean_dec(x_420); +return x_436; +} +} +else +{ +lean_object* x_437; lean_object* x_438; +lean_dec(x_366); +x_437 = lean_unsigned_to_nat(1u); +x_438 = lean_nat_add(x_4, x_437); +lean_dec(x_4); +x_4 = x_438; +x_5 = x_420; +x_7 = x_419; +goto _start; +} +} +} +else +{ +uint8_t x_440; +lean_dec(x_421); +lean_dec(x_4); +x_440 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_440 == 0) +{ +uint8_t x_441; lean_object* x_442; lean_object* x_443; +lean_dec(x_420); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_441 = 0; +x_442 = lean_box(x_441); +x_443 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_443, 0, x_442); +lean_ctor_set(x_443, 1, x_419); +return x_443; +} +else +{ +lean_object* x_444; +x_444 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_420, x_3, x_6, x_419); +lean_dec(x_420); +return x_444; +} +} +} +else +{ +lean_object* x_445; uint8_t x_446; +lean_dec(x_422); +x_445 = lean_unsigned_to_nat(0u); +x_446 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__3(x_4, x_5, lean_box(0), x_418, lean_box(0), x_420, x_4, x_445); +lean_dec(x_418); +lean_dec(x_5); +if (x_446 == 0) +{ +lean_object* x_447; uint8_t x_448; +x_447 = lean_ctor_get(x_2, 1); +x_448 = l_Lean_LocalContext_contains(x_447, x_421); +lean_dec(x_421); +if (x_448 == 0) +{ +lean_object* x_449; lean_object* x_450; +lean_dec(x_366); +x_449 = lean_unsigned_to_nat(1u); +x_450 = lean_nat_add(x_4, x_449); +lean_dec(x_4); +x_4 = x_450; +x_5 = x_420; +x_7 = x_419; +goto _start; +} +else +{ +uint8_t x_452; +x_452 = lean_ctor_get_uint8(x_366, sizeof(void*)*1 + 2); +if (x_452 == 0) +{ +uint8_t x_453; +lean_dec(x_4); +x_453 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_453 == 0) +{ +uint8_t x_454; lean_object* x_455; lean_object* x_456; +lean_dec(x_420); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_454 = 0; +x_455 = lean_box(x_454); +x_456 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_456, 0, x_455); +lean_ctor_set(x_456, 1, x_419); +return x_456; +} +else +{ +lean_object* x_457; +x_457 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_420, x_3, x_6, x_419); +lean_dec(x_420); +return x_457; +} +} +else +{ +lean_object* x_458; lean_object* x_459; +lean_dec(x_366); +x_458 = lean_unsigned_to_nat(1u); +x_459 = lean_nat_add(x_4, x_458); +lean_dec(x_4); +x_4 = x_459; +x_5 = x_420; +x_7 = x_419; +goto _start; +} +} +} +else +{ +uint8_t x_461; +lean_dec(x_421); +lean_dec(x_4); +x_461 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_461 == 0) +{ +uint8_t x_462; lean_object* x_463; lean_object* x_464; +lean_dec(x_420); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_462 = 0; +x_463 = lean_box(x_462); +x_464 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_464, 0, x_463); +lean_ctor_set(x_464, 1, x_419); +return x_464; +} +else +{ +lean_object* x_465; +x_465 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_420, x_3, x_6, x_419); +lean_dec(x_420); +return x_465; +} +} +} +} +else +{ +uint8_t x_466; +lean_dec(x_418); +lean_dec(x_5); +lean_dec(x_4); +x_466 = lean_ctor_get_uint8(x_366, sizeof(void*)*1); +lean_dec(x_366); +if (x_466 == 0) +{ +uint8_t x_467; lean_object* x_468; lean_object* x_469; +lean_dec(x_420); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_467 = 0; +x_468 = lean_box(x_467); +x_469 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_469, 0, x_468); +lean_ctor_set(x_469, 1, x_419); +return x_469; +} +else +{ +lean_object* x_470; +x_470 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentFOApprox___main(x_1, x_420, x_3, x_6, x_419); +lean_dec(x_420); +return x_470; +} +} +} +} +else +{ +uint8_t x_471; +lean_dec(x_366); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_471 = !lean_is_exclusive(x_368); +if (x_471 == 0) +{ +return x_368; +} +else +{ +lean_object* x_472; lean_object* x_473; lean_object* x_474; +x_472 = lean_ctor_get(x_368, 0); +x_473 = lean_ctor_get(x_368, 1); +lean_inc(x_473); +lean_inc(x_472); +lean_dec(x_368); +x_474 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_474, 0, x_472); +lean_ctor_set(x_474, 1, x_473); return x_474; } } -else -{ -lean_object* x_475; lean_object* x_476; -lean_free_object(x_452); -lean_dec(x_450); -x_475 = lean_unsigned_to_nat(1u); -x_476 = lean_nat_add(x_7, x_475); -lean_dec(x_7); -x_7 = x_476; -x_8 = x_456; -x_10 = x_455; -goto _start; } } } -else -{ -uint8_t x_478; -lean_dec(x_457); -lean_dec(x_7); -lean_dec(x_5); -x_478 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_478 == 0) -{ -uint8_t x_479; lean_object* x_480; -lean_dec(x_456); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_479 = 0; -x_480 = lean_box(x_479); -lean_ctor_set(x_452, 0, x_480); -return x_452; -} -else -{ -lean_object* x_481; -lean_free_object(x_452); -x_481 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_456, x_6, x_9, x_455); -return x_481; -} -} -} -else -{ -lean_object* x_482; lean_object* x_483; lean_object* x_484; uint8_t x_485; -lean_dec(x_459); -x_482 = l_Id_Monad; -x_483 = lean_unsigned_to_nat(0u); -lean_inc(x_7); -lean_inc(x_456); -x_484 = l_Array_anyRangeMAux___main___rarg(x_482, x_456, x_7, lean_box(0), x_458, x_483); -x_485 = lean_unbox(x_484); -lean_dec(x_484); -if (x_485 == 0) -{ -lean_object* x_486; uint8_t x_487; -x_486 = lean_ctor_get(x_5, 1); -lean_inc(x_486); -x_487 = l_Lean_LocalContext_contains(x_486, x_457); -lean_dec(x_457); -lean_dec(x_486); -if (x_487 == 0) -{ -lean_object* x_488; lean_object* x_489; -lean_free_object(x_452); -lean_dec(x_450); -x_488 = lean_unsigned_to_nat(1u); -x_489 = lean_nat_add(x_7, x_488); -lean_dec(x_7); -x_7 = x_489; -x_8 = x_456; -x_10 = x_455; -goto _start; -} -else -{ -uint8_t x_491; -x_491 = lean_ctor_get_uint8(x_450, sizeof(void*)*1 + 2); -if (x_491 == 0) -{ -uint8_t x_492; -lean_dec(x_7); -lean_dec(x_5); -x_492 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_492 == 0) -{ -uint8_t x_493; lean_object* x_494; -lean_dec(x_456); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_493 = 0; -x_494 = lean_box(x_493); -lean_ctor_set(x_452, 0, x_494); -return x_452; -} -else -{ -lean_object* x_495; -lean_free_object(x_452); -x_495 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_456, x_6, x_9, x_455); -return x_495; -} -} -else -{ -lean_object* x_496; lean_object* x_497; -lean_free_object(x_452); -lean_dec(x_450); -x_496 = lean_unsigned_to_nat(1u); -x_497 = lean_nat_add(x_7, x_496); -lean_dec(x_7); -x_7 = x_497; -x_8 = x_456; -x_10 = x_455; -goto _start; -} -} -} -else -{ -uint8_t x_499; -lean_dec(x_457); -lean_dec(x_7); -lean_dec(x_5); -x_499 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_499 == 0) -{ -uint8_t x_500; lean_object* x_501; -lean_dec(x_456); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_500 = 0; -x_501 = lean_box(x_500); -lean_ctor_set(x_452, 0, x_501); -return x_452; -} -else -{ -lean_object* x_502; -lean_free_object(x_452); -x_502 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_456, x_6, x_9, x_455); -return x_502; -} -} -} -} -else -{ -uint8_t x_503; -lean_dec(x_454); -lean_dec(x_7); -lean_dec(x_5); -x_503 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_503 == 0) -{ -uint8_t x_504; lean_object* x_505; -lean_dec(x_456); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_504 = 0; -x_505 = lean_box(x_504); -lean_ctor_set(x_452, 0, x_505); -return x_452; -} -else -{ -lean_object* x_506; -lean_free_object(x_452); -x_506 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_456, x_6, x_9, x_455); -return x_506; -} -} -} -else -{ -lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_507 = lean_ctor_get(x_452, 0); -x_508 = lean_ctor_get(x_452, 1); -lean_inc(x_508); -lean_inc(x_507); -lean_dec(x_452); -lean_inc(x_507); -x_509 = lean_array_fset(x_8, x_7, x_507); -if (lean_obj_tag(x_507) == 1) -{ -lean_object* x_510; lean_object* x_511; lean_object* x_512; uint8_t x_513; -x_510 = lean_ctor_get(x_507, 0); -lean_inc(x_510); -x_511 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__2___boxed), 2, 1); -lean_closure_set(x_511, 0, x_507); -x_512 = lean_array_get_size(x_509); -x_513 = lean_nat_dec_le(x_7, x_512); -if (x_513 == 0) -{ -lean_object* x_514; lean_object* x_515; lean_object* x_516; uint8_t x_517; -x_514 = l_Id_Monad; -x_515 = lean_unsigned_to_nat(0u); -lean_inc(x_509); -x_516 = l_Array_anyRangeMAux___main___rarg(x_514, x_509, x_512, lean_box(0), x_511, x_515); -x_517 = lean_unbox(x_516); -lean_dec(x_516); -if (x_517 == 0) -{ -lean_object* x_518; uint8_t x_519; -x_518 = lean_ctor_get(x_5, 1); -lean_inc(x_518); -x_519 = l_Lean_LocalContext_contains(x_518, x_510); -lean_dec(x_510); -lean_dec(x_518); -if (x_519 == 0) -{ -lean_object* x_520; lean_object* x_521; -lean_dec(x_450); -x_520 = lean_unsigned_to_nat(1u); -x_521 = lean_nat_add(x_7, x_520); -lean_dec(x_7); -x_7 = x_521; -x_8 = x_509; -x_10 = x_508; -goto _start; -} -else -{ -uint8_t x_523; -x_523 = lean_ctor_get_uint8(x_450, sizeof(void*)*1 + 2); -if (x_523 == 0) -{ -uint8_t x_524; -lean_dec(x_7); -lean_dec(x_5); -x_524 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_524 == 0) -{ -uint8_t x_525; lean_object* x_526; lean_object* x_527; -lean_dec(x_509); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_525 = 0; -x_526 = lean_box(x_525); -x_527 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_527, 0, x_526); -lean_ctor_set(x_527, 1, x_508); -return x_527; -} -else -{ -lean_object* x_528; -x_528 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_509, x_6, x_9, x_508); -return x_528; -} -} -else -{ -lean_object* x_529; lean_object* x_530; -lean_dec(x_450); -x_529 = lean_unsigned_to_nat(1u); -x_530 = lean_nat_add(x_7, x_529); -lean_dec(x_7); -x_7 = x_530; -x_8 = x_509; -x_10 = x_508; -goto _start; -} -} -} -else -{ -uint8_t x_532; -lean_dec(x_510); -lean_dec(x_7); -lean_dec(x_5); -x_532 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_532 == 0) -{ -uint8_t x_533; lean_object* x_534; lean_object* x_535; -lean_dec(x_509); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_533 = 0; -x_534 = lean_box(x_533); -x_535 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_535, 0, x_534); -lean_ctor_set(x_535, 1, x_508); -return x_535; -} -else -{ -lean_object* x_536; -x_536 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_509, x_6, x_9, x_508); -return x_536; -} -} -} -else -{ -lean_object* x_537; lean_object* x_538; lean_object* x_539; uint8_t x_540; -lean_dec(x_512); -x_537 = l_Id_Monad; -x_538 = lean_unsigned_to_nat(0u); -lean_inc(x_7); -lean_inc(x_509); -x_539 = l_Array_anyRangeMAux___main___rarg(x_537, x_509, x_7, lean_box(0), x_511, x_538); -x_540 = lean_unbox(x_539); -lean_dec(x_539); -if (x_540 == 0) -{ -lean_object* x_541; uint8_t x_542; -x_541 = lean_ctor_get(x_5, 1); -lean_inc(x_541); -x_542 = l_Lean_LocalContext_contains(x_541, x_510); -lean_dec(x_510); -lean_dec(x_541); -if (x_542 == 0) -{ -lean_object* x_543; lean_object* x_544; -lean_dec(x_450); -x_543 = lean_unsigned_to_nat(1u); -x_544 = lean_nat_add(x_7, x_543); -lean_dec(x_7); -x_7 = x_544; -x_8 = x_509; -x_10 = x_508; -goto _start; -} -else -{ -uint8_t x_546; -x_546 = lean_ctor_get_uint8(x_450, sizeof(void*)*1 + 2); -if (x_546 == 0) -{ -uint8_t x_547; -lean_dec(x_7); -lean_dec(x_5); -x_547 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_547 == 0) -{ -uint8_t x_548; lean_object* x_549; lean_object* x_550; -lean_dec(x_509); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_548 = 0; -x_549 = lean_box(x_548); -x_550 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_550, 0, x_549); -lean_ctor_set(x_550, 1, x_508); -return x_550; -} -else -{ -lean_object* x_551; -x_551 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_509, x_6, x_9, x_508); -return x_551; -} -} -else -{ -lean_object* x_552; lean_object* x_553; -lean_dec(x_450); -x_552 = lean_unsigned_to_nat(1u); -x_553 = lean_nat_add(x_7, x_552); -lean_dec(x_7); -x_7 = x_553; -x_8 = x_509; -x_10 = x_508; -goto _start; -} -} -} -else -{ -uint8_t x_555; -lean_dec(x_510); -lean_dec(x_7); -lean_dec(x_5); -x_555 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_555 == 0) -{ -uint8_t x_556; lean_object* x_557; lean_object* x_558; -lean_dec(x_509); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_556 = 0; -x_557 = lean_box(x_556); -x_558 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_558, 0, x_557); -lean_ctor_set(x_558, 1, x_508); -return x_558; -} -else -{ -lean_object* x_559; -x_559 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_509, x_6, x_9, x_508); -return x_559; -} -} -} -} -else -{ -uint8_t x_560; -lean_dec(x_507); -lean_dec(x_7); -lean_dec(x_5); -x_560 = lean_ctor_get_uint8(x_450, sizeof(void*)*1); -lean_dec(x_450); -if (x_560 == 0) -{ -uint8_t x_561; lean_object* x_562; lean_object* x_563; -lean_dec(x_509); -lean_dec(x_9); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_561 = 0; -x_562 = lean_box(x_561); -x_563 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_563, 0, x_562); -lean_ctor_set(x_563, 1, x_508); -return x_563; -} -else -{ -lean_object* x_564; -x_564 = l___private_Init_Lean_Meta_ExprDefEq_11__processAssignmentFOApprox___main(x_1, x_2, x_3, x_4, x_509, x_6, x_9, x_508); -return x_564; -} -} -} -} -else -{ -uint8_t x_565; -lean_dec(x_450); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_565 = !lean_is_exclusive(x_452); -if (x_565 == 0) -{ -return x_452; -} -else -{ -lean_object* x_566; lean_object* x_567; lean_object* x_568; -x_566 = lean_ctor_get(x_452, 0); -x_567 = lean_ctor_get(x_452, 1); -lean_inc(x_567); -lean_inc(x_566); -lean_dec(x_452); -x_568 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_568, 0, x_566); -lean_ctor_set(x_568, 1, x_567); -return x_568; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__1___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -uint8_t x_3; lean_object* x_4; -x_3 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__1(x_1, x_2); +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_4 = lean_box(x_3); -return x_4; +x_7 = lean_box(x_6); +return x_7; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__2___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -uint8_t x_3; lean_object* x_4; -x_3 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___lambda__2(x_1, x_2); +uint8_t x_8; lean_object* x_9; +x_8 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); lean_dec(x_2); lean_dec(x_1); -x_4 = lean_box(x_3); -return x_4; +x_9 = lean_box(x_8); +return x_9; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_11; -x_11 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -return x_11; +uint8_t x_9; lean_object* x_10; +x_9 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_10 = lean_box(x_9); +return x_10; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_15__processAssignment(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_9; lean_object* x_10; -x_9 = l_Lean_Expr_mvarId_x21(x_4); -x_10 = l_Lean_Meta_getMVarDecl(x_9, x_7, x_8); -if (lean_obj_tag(x_10) == 0) +lean_object* x_8; +x_8 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_2); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: { -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_11 = lean_ctor_get(x_10, 0); +lean_object* x_8; +x_8 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_2); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = l_Lean_Expr_getAppFn___main(x_1); +x_6 = l_Lean_Expr_mvarId_x21(x_5); +x_7 = l_Lean_Meta_getMVarDecl(x_6, x_3, x_4); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +lean_dec(x_7); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_10); +x_12 = l_Lean_Expr_getAppArgs___closed__1; lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); -lean_inc(x_12); -lean_dec(x_10); -x_13 = lean_unsigned_to_nat(0u); -x_14 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main(x_1, x_2, x_3, x_4, x_11, x_6, x_13, x_5, x_7, x_12); -return x_14; +x_13 = lean_mk_array(x_11, x_12); +x_14 = lean_unsigned_to_nat(1u); +x_15 = lean_nat_sub(x_11, x_14); +lean_dec(x_11); +x_16 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_13, x_15); +x_17 = l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main(x_5, x_8, x_2, x_10, x_16, x_3, x_9); +lean_dec(x_8); +return x_17; } else { -uint8_t x_15; -lean_dec(x_7); -lean_dec(x_6); +uint8_t x_18; lean_dec(x_5); -lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_15 = !lean_is_exclusive(x_10); -if (x_15 == 0) +x_18 = !lean_is_exclusive(x_7); +if (x_18 == 0) { -return x_10; +return x_7; } else { -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_10, 0); -x_17 = lean_ctor_get(x_10, 1); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_10); -x_18 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_18, 0, x_16); -lean_ctor_set(x_18, 1, x_17); -return x_18; +lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_19 = lean_ctor_get(x_7, 0); +x_20 = lean_ctor_get(x_7, 1); +lean_inc(x_20); +lean_inc(x_19); +lean_dec(x_7); +x_21 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_21, 0, x_19); +lean_ctor_set(x_21, 1, x_20); +return x_21; } } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_16__unfold___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; lean_object* x_10; -lean_inc(x_1); -x_9 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_9, 0, x_1); -x_10 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -return x_10; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_16__unfold(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_16__unfold___rarg), 8, 0); -return x_2; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; @@ -11301,17 +14602,17 @@ return x_9; } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate(x_1, x_2, x_3); lean_dec(x_2); lean_dec(x_1); return x_4; } } -uint8_t l___private_Init_Lean_Meta_ExprDefEq_18__sameHeadSymbol(lean_object* x_1, lean_object* x_2) { +uint8_t l___private_Init_Lean_Meta_ExprDefEq_20__sameHeadSymbol(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; @@ -11345,24 +14646,23 @@ return x_7; } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_18__sameHeadSymbol___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_20__sameHeadSymbol___boxed(lean_object* x_1, lean_object* x_2) { _start: { uint8_t x_3; lean_object* x_4; -x_3 = l___private_Init_Lean_Meta_ExprDefEq_18__sameHeadSymbol(x_1, x_2); +x_3 = l___private_Init_Lean_Meta_ExprDefEq_20__sameHeadSymbol(x_1, x_2); lean_dec(x_2); lean_dec(x_1); x_4 = lean_box(x_3); return x_4; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5) { _start: { if (x_3 == 0) { lean_object* x_6; lean_object* x_7; -lean_dec(x_4); x_6 = lean_box(x_3); x_7 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_7, 0, x_6); @@ -11374,12 +14674,12 @@ else lean_object* x_8; lean_object* x_9; lean_object* x_10; x_8 = l_Lean_Expr_constLevels_x21(x_1); x_9 = l_Lean_Expr_constLevels_x21(x_2); -x_10 = l_Lean_Meta_isListLevelDefEq___main(x_8, x_9, x_4, x_5); +x_10 = l_Lean_Meta_isListLevelDefEqAux___main(x_8, x_9, x_4, x_5); return x_10; } } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1() { _start: { lean_object* x_1; @@ -11387,298 +14687,296 @@ x_1 = lean_mk_string("unfoldRight"); return x_1; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_9, 4); -lean_inc(x_10); -x_11 = lean_ctor_get_uint8(x_10, sizeof(void*)*1); -lean_dec(x_10); -if (x_11 == 0) +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_8, 4); +lean_inc(x_9); +x_10 = lean_ctor_get_uint8(x_9, sizeof(void*)*1); +lean_dec(x_9); +if (x_10 == 0) { -lean_object* x_12; -lean_dec(x_6); +lean_object* x_11; lean_dec(x_5); lean_dec(x_4); -x_12 = lean_apply_4(x_1, x_2, x_7, x_8, x_9); -if (lean_obj_tag(x_12) == 0) +lean_dec(x_3); +x_11 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_8); +if (lean_obj_tag(x_11) == 0) { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) { -lean_object* x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_unbox(x_14); -lean_dec(x_14); -x_16 = l_Bool_toLBool(x_15); -x_17 = lean_box(x_16); -lean_ctor_set(x_12, 0, x_17); -return x_12; +lean_object* x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); +x_14 = lean_unbox(x_13); +lean_dec(x_13); +x_15 = l_Bool_toLBool(x_14); +x_16 = lean_box(x_15); +lean_ctor_set(x_11, 0, x_16); +return x_11; } else { -lean_object* x_18; lean_object* x_19; uint8_t x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); -lean_inc(x_19); +lean_object* x_17; lean_object* x_18; uint8_t x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); lean_inc(x_18); -lean_dec(x_12); -x_20 = lean_unbox(x_18); -lean_dec(x_18); -x_21 = l_Bool_toLBool(x_20); -x_22 = lean_box(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); -return x_23; +lean_inc(x_17); +lean_dec(x_11); +x_19 = lean_unbox(x_17); +lean_dec(x_17); +x_20 = l_Bool_toLBool(x_19); +x_21 = lean_box(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; } } else { -uint8_t x_24; -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) +uint8_t x_23; +x_23 = !lean_is_exclusive(x_11); +if (x_23 == 0) { -return x_12; +return x_11; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; } } } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_28 = l_Lean_ConstantInfo_name(x_3); -x_29 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1; -x_30 = lean_name_mk_string(x_4, x_29); -x_31 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_30); -x_32 = l_Lean_Name_append___main(x_31, x_30); -x_33 = l_Lean_Meta_tracer; -x_34 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_5, x_33, x_32); -lean_inc(x_8); -x_35 = lean_apply_2(x_34, x_8, x_9); -if (lean_obj_tag(x_35) == 0) +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_27 = l_Lean_ConstantInfo_name(x_2); +x_28 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1; +x_29 = lean_name_mk_string(x_3, x_28); +x_30 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +lean_inc(x_29); +x_31 = l_Lean_Name_append___main(x_30, x_29); +x_32 = l_Lean_Meta_tracer; +x_33 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_4, x_32, x_31); +lean_inc(x_7); +x_34 = lean_apply_2(x_33, x_7, x_8); +if (lean_obj_tag(x_34) == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_unbox(x_36); -lean_dec(x_36); -if (x_37 == 0) -{ -lean_object* x_38; lean_object* x_39; -lean_dec(x_30); -lean_dec(x_28); -lean_dec(x_6); -x_38 = lean_ctor_get(x_35, 1); -lean_inc(x_38); +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_unbox(x_35); lean_dec(x_35); -x_39 = lean_apply_4(x_1, x_2, x_7, x_8, x_38); -if (lean_obj_tag(x_39) == 0) +if (x_36 == 0) { -uint8_t x_40; -x_40 = !lean_is_exclusive(x_39); -if (x_40 == 0) +lean_object* x_37; lean_object* x_38; +lean_dec(x_29); +lean_dec(x_27); +lean_dec(x_5); +x_37 = lean_ctor_get(x_34, 1); +lean_inc(x_37); +lean_dec(x_34); +x_38 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_37); +if (lean_obj_tag(x_38) == 0) { -lean_object* x_41; uint8_t x_42; uint8_t x_43; lean_object* x_44; -x_41 = lean_ctor_get(x_39, 0); -x_42 = lean_unbox(x_41); -lean_dec(x_41); -x_43 = l_Bool_toLBool(x_42); -x_44 = lean_box(x_43); -lean_ctor_set(x_39, 0, x_44); -return x_39; +uint8_t x_39; +x_39 = !lean_is_exclusive(x_38); +if (x_39 == 0) +{ +lean_object* x_40; uint8_t x_41; uint8_t x_42; lean_object* x_43; +x_40 = lean_ctor_get(x_38, 0); +x_41 = lean_unbox(x_40); +lean_dec(x_40); +x_42 = l_Bool_toLBool(x_41); +x_43 = lean_box(x_42); +lean_ctor_set(x_38, 0, x_43); +return x_38; } else { -lean_object* x_45; lean_object* x_46; uint8_t x_47; uint8_t x_48; lean_object* x_49; lean_object* x_50; -x_45 = lean_ctor_get(x_39, 0); -x_46 = lean_ctor_get(x_39, 1); -lean_inc(x_46); +lean_object* x_44; lean_object* x_45; uint8_t x_46; uint8_t x_47; lean_object* x_48; lean_object* x_49; +x_44 = lean_ctor_get(x_38, 0); +x_45 = lean_ctor_get(x_38, 1); lean_inc(x_45); -lean_dec(x_39); -x_47 = lean_unbox(x_45); -lean_dec(x_45); -x_48 = l_Bool_toLBool(x_47); -x_49 = lean_box(x_48); -x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_49); -lean_ctor_set(x_50, 1, x_46); -return x_50; +lean_inc(x_44); +lean_dec(x_38); +x_46 = lean_unbox(x_44); +lean_dec(x_44); +x_47 = l_Bool_toLBool(x_46); +x_48 = lean_box(x_47); +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_45); +return x_49; } } else { -uint8_t x_51; -x_51 = !lean_is_exclusive(x_39); -if (x_51 == 0) +uint8_t x_50; +x_50 = !lean_is_exclusive(x_38); +if (x_50 == 0) { -return x_39; +return x_38; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_39, 0); -x_53 = lean_ctor_get(x_39, 1); -lean_inc(x_53); +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_38, 0); +x_52 = lean_ctor_get(x_38, 1); lean_inc(x_52); -lean_dec(x_39); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; +lean_inc(x_51); +lean_dec(x_38); +x_53 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_53, 0, x_51); +lean_ctor_set(x_53, 1, x_52); +return x_53; } } } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_55 = lean_ctor_get(x_35, 1); -lean_inc(x_55); -lean_dec(x_35); -x_56 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_56, 0, x_28); -x_57 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_30, x_56); -lean_inc(x_8); -x_58 = lean_apply_2(x_57, x_8, x_55); -if (lean_obj_tag(x_58) == 0) +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_54 = lean_ctor_get(x_34, 1); +lean_inc(x_54); +lean_dec(x_34); +x_55 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_55, 0, x_27); +x_56 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_5, x_29, x_55); +lean_inc(x_7); +x_57 = lean_apply_2(x_56, x_7, x_54); +if (lean_obj_tag(x_57) == 0) { -lean_object* x_59; lean_object* x_60; -x_59 = lean_ctor_get(x_58, 1); -lean_inc(x_59); -lean_dec(x_58); -x_60 = lean_apply_4(x_1, x_2, x_7, x_8, x_59); -if (lean_obj_tag(x_60) == 0) +lean_object* x_58; lean_object* x_59; +x_58 = lean_ctor_get(x_57, 1); +lean_inc(x_58); +lean_dec(x_57); +x_59 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_58); +if (lean_obj_tag(x_59) == 0) { -uint8_t x_61; -x_61 = !lean_is_exclusive(x_60); -if (x_61 == 0) +uint8_t x_60; +x_60 = !lean_is_exclusive(x_59); +if (x_60 == 0) { -lean_object* x_62; uint8_t x_63; uint8_t x_64; lean_object* x_65; -x_62 = lean_ctor_get(x_60, 0); -x_63 = lean_unbox(x_62); -lean_dec(x_62); -x_64 = l_Bool_toLBool(x_63); -x_65 = lean_box(x_64); -lean_ctor_set(x_60, 0, x_65); -return x_60; +lean_object* x_61; uint8_t x_62; uint8_t x_63; lean_object* x_64; +x_61 = lean_ctor_get(x_59, 0); +x_62 = lean_unbox(x_61); +lean_dec(x_61); +x_63 = l_Bool_toLBool(x_62); +x_64 = lean_box(x_63); +lean_ctor_set(x_59, 0, x_64); +return x_59; } else { -lean_object* x_66; lean_object* x_67; uint8_t x_68; uint8_t x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_60, 0); -x_67 = lean_ctor_get(x_60, 1); -lean_inc(x_67); +lean_object* x_65; lean_object* x_66; uint8_t x_67; uint8_t x_68; lean_object* x_69; lean_object* x_70; +x_65 = lean_ctor_get(x_59, 0); +x_66 = lean_ctor_get(x_59, 1); lean_inc(x_66); -lean_dec(x_60); -x_68 = lean_unbox(x_66); -lean_dec(x_66); -x_69 = l_Bool_toLBool(x_68); -x_70 = lean_box(x_69); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_67); -return x_71; +lean_inc(x_65); +lean_dec(x_59); +x_67 = lean_unbox(x_65); +lean_dec(x_65); +x_68 = l_Bool_toLBool(x_67); +x_69 = lean_box(x_68); +x_70 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_70, 0, x_69); +lean_ctor_set(x_70, 1, x_66); +return x_70; } } else { -uint8_t x_72; -x_72 = !lean_is_exclusive(x_60); -if (x_72 == 0) +uint8_t x_71; +x_71 = !lean_is_exclusive(x_59); +if (x_71 == 0) { -return x_60; +return x_59; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_60, 0); -x_74 = lean_ctor_get(x_60, 1); -lean_inc(x_74); +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_59, 0); +x_73 = lean_ctor_get(x_59, 1); lean_inc(x_73); -lean_dec(x_60); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_inc(x_72); +lean_dec(x_59); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; } } } else { -uint8_t x_76; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_2); -lean_dec(x_1); -x_76 = !lean_is_exclusive(x_58); -if (x_76 == 0) -{ -return x_58; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_58, 0); -x_78 = lean_ctor_get(x_58, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_58); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -else -{ -uint8_t x_80; -lean_dec(x_30); -lean_dec(x_28); -lean_dec(x_8); +uint8_t x_75; lean_dec(x_7); lean_dec(x_6); -lean_dec(x_2); lean_dec(x_1); -x_80 = !lean_is_exclusive(x_35); -if (x_80 == 0) +x_75 = !lean_is_exclusive(x_57); +if (x_75 == 0) { -return x_35; +return x_57; } else { -lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_35, 0); -x_82 = lean_ctor_get(x_35, 1); -lean_inc(x_82); +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_57, 0); +x_77 = lean_ctor_get(x_57, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_57); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +} +else +{ +uint8_t x_79; +lean_dec(x_29); +lean_dec(x_27); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_79 = !lean_is_exclusive(x_34); +if (x_79 == 0) +{ +return x_34; +} +else +{ +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_34, 0); +x_81 = lean_ctor_get(x_34, 1); lean_inc(x_81); -lean_dec(x_35); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_inc(x_80); +lean_dec(x_34); +x_82 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_82, 0, x_80); +lean_ctor_set(x_82, 1, x_81); +return x_82; } } } } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1() { _start: { lean_object* x_1; @@ -11686,298 +14984,296 @@ x_1 = lean_mk_string("unfoldLeft"); return x_1; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_9, 4); -lean_inc(x_10); -x_11 = lean_ctor_get_uint8(x_10, sizeof(void*)*1); -lean_dec(x_10); -if (x_11 == 0) +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_8, 4); +lean_inc(x_9); +x_10 = lean_ctor_get_uint8(x_9, sizeof(void*)*1); +lean_dec(x_9); +if (x_10 == 0) { -lean_object* x_12; -lean_dec(x_6); +lean_object* x_11; lean_dec(x_5); lean_dec(x_4); -x_12 = lean_apply_4(x_1, x_7, x_2, x_8, x_9); -if (lean_obj_tag(x_12) == 0) +lean_dec(x_3); +x_11 = l_Lean_Meta_isExprDefEqAux(x_6, x_1, x_7, x_8); +if (lean_obj_tag(x_11) == 0) { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) { -lean_object* x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_unbox(x_14); -lean_dec(x_14); -x_16 = l_Bool_toLBool(x_15); -x_17 = lean_box(x_16); -lean_ctor_set(x_12, 0, x_17); -return x_12; +lean_object* x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); +x_14 = lean_unbox(x_13); +lean_dec(x_13); +x_15 = l_Bool_toLBool(x_14); +x_16 = lean_box(x_15); +lean_ctor_set(x_11, 0, x_16); +return x_11; } else { -lean_object* x_18; lean_object* x_19; uint8_t x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); -lean_inc(x_19); +lean_object* x_17; lean_object* x_18; uint8_t x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); lean_inc(x_18); -lean_dec(x_12); -x_20 = lean_unbox(x_18); -lean_dec(x_18); -x_21 = l_Bool_toLBool(x_20); -x_22 = lean_box(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); -return x_23; +lean_inc(x_17); +lean_dec(x_11); +x_19 = lean_unbox(x_17); +lean_dec(x_17); +x_20 = l_Bool_toLBool(x_19); +x_21 = lean_box(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; } } else { -uint8_t x_24; -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) +uint8_t x_23; +x_23 = !lean_is_exclusive(x_11); +if (x_23 == 0) { -return x_12; +return x_11; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; } } } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_28 = l_Lean_ConstantInfo_name(x_3); -x_29 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1; -x_30 = lean_name_mk_string(x_4, x_29); -x_31 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_30); -x_32 = l_Lean_Name_append___main(x_31, x_30); -x_33 = l_Lean_Meta_tracer; -x_34 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_5, x_33, x_32); -lean_inc(x_8); -x_35 = lean_apply_2(x_34, x_8, x_9); -if (lean_obj_tag(x_35) == 0) +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_27 = l_Lean_ConstantInfo_name(x_2); +x_28 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1; +x_29 = lean_name_mk_string(x_3, x_28); +x_30 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +lean_inc(x_29); +x_31 = l_Lean_Name_append___main(x_30, x_29); +x_32 = l_Lean_Meta_tracer; +x_33 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_4, x_32, x_31); +lean_inc(x_7); +x_34 = lean_apply_2(x_33, x_7, x_8); +if (lean_obj_tag(x_34) == 0) { -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_unbox(x_36); -lean_dec(x_36); -if (x_37 == 0) -{ -lean_object* x_38; lean_object* x_39; -lean_dec(x_30); -lean_dec(x_28); -lean_dec(x_6); -x_38 = lean_ctor_get(x_35, 1); -lean_inc(x_38); +lean_object* x_35; uint8_t x_36; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_unbox(x_35); lean_dec(x_35); -x_39 = lean_apply_4(x_1, x_7, x_2, x_8, x_38); -if (lean_obj_tag(x_39) == 0) +if (x_36 == 0) { -uint8_t x_40; -x_40 = !lean_is_exclusive(x_39); -if (x_40 == 0) +lean_object* x_37; lean_object* x_38; +lean_dec(x_29); +lean_dec(x_27); +lean_dec(x_5); +x_37 = lean_ctor_get(x_34, 1); +lean_inc(x_37); +lean_dec(x_34); +x_38 = l_Lean_Meta_isExprDefEqAux(x_6, x_1, x_7, x_37); +if (lean_obj_tag(x_38) == 0) { -lean_object* x_41; uint8_t x_42; uint8_t x_43; lean_object* x_44; -x_41 = lean_ctor_get(x_39, 0); -x_42 = lean_unbox(x_41); -lean_dec(x_41); -x_43 = l_Bool_toLBool(x_42); -x_44 = lean_box(x_43); -lean_ctor_set(x_39, 0, x_44); -return x_39; +uint8_t x_39; +x_39 = !lean_is_exclusive(x_38); +if (x_39 == 0) +{ +lean_object* x_40; uint8_t x_41; uint8_t x_42; lean_object* x_43; +x_40 = lean_ctor_get(x_38, 0); +x_41 = lean_unbox(x_40); +lean_dec(x_40); +x_42 = l_Bool_toLBool(x_41); +x_43 = lean_box(x_42); +lean_ctor_set(x_38, 0, x_43); +return x_38; } else { -lean_object* x_45; lean_object* x_46; uint8_t x_47; uint8_t x_48; lean_object* x_49; lean_object* x_50; -x_45 = lean_ctor_get(x_39, 0); -x_46 = lean_ctor_get(x_39, 1); -lean_inc(x_46); +lean_object* x_44; lean_object* x_45; uint8_t x_46; uint8_t x_47; lean_object* x_48; lean_object* x_49; +x_44 = lean_ctor_get(x_38, 0); +x_45 = lean_ctor_get(x_38, 1); lean_inc(x_45); -lean_dec(x_39); -x_47 = lean_unbox(x_45); -lean_dec(x_45); -x_48 = l_Bool_toLBool(x_47); -x_49 = lean_box(x_48); -x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_49); -lean_ctor_set(x_50, 1, x_46); -return x_50; +lean_inc(x_44); +lean_dec(x_38); +x_46 = lean_unbox(x_44); +lean_dec(x_44); +x_47 = l_Bool_toLBool(x_46); +x_48 = lean_box(x_47); +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_45); +return x_49; } } else { -uint8_t x_51; -x_51 = !lean_is_exclusive(x_39); -if (x_51 == 0) +uint8_t x_50; +x_50 = !lean_is_exclusive(x_38); +if (x_50 == 0) { -return x_39; +return x_38; } else { -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_39, 0); -x_53 = lean_ctor_get(x_39, 1); -lean_inc(x_53); +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_38, 0); +x_52 = lean_ctor_get(x_38, 1); lean_inc(x_52); -lean_dec(x_39); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -return x_54; +lean_inc(x_51); +lean_dec(x_38); +x_53 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_53, 0, x_51); +lean_ctor_set(x_53, 1, x_52); +return x_53; } } } else { -lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_55 = lean_ctor_get(x_35, 1); -lean_inc(x_55); -lean_dec(x_35); -x_56 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_56, 0, x_28); -x_57 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_30, x_56); -lean_inc(x_8); -x_58 = lean_apply_2(x_57, x_8, x_55); -if (lean_obj_tag(x_58) == 0) +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_54 = lean_ctor_get(x_34, 1); +lean_inc(x_54); +lean_dec(x_34); +x_55 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_55, 0, x_27); +x_56 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_5, x_29, x_55); +lean_inc(x_7); +x_57 = lean_apply_2(x_56, x_7, x_54); +if (lean_obj_tag(x_57) == 0) { -lean_object* x_59; lean_object* x_60; -x_59 = lean_ctor_get(x_58, 1); -lean_inc(x_59); -lean_dec(x_58); -x_60 = lean_apply_4(x_1, x_7, x_2, x_8, x_59); -if (lean_obj_tag(x_60) == 0) +lean_object* x_58; lean_object* x_59; +x_58 = lean_ctor_get(x_57, 1); +lean_inc(x_58); +lean_dec(x_57); +x_59 = l_Lean_Meta_isExprDefEqAux(x_6, x_1, x_7, x_58); +if (lean_obj_tag(x_59) == 0) { -uint8_t x_61; -x_61 = !lean_is_exclusive(x_60); -if (x_61 == 0) +uint8_t x_60; +x_60 = !lean_is_exclusive(x_59); +if (x_60 == 0) { -lean_object* x_62; uint8_t x_63; uint8_t x_64; lean_object* x_65; -x_62 = lean_ctor_get(x_60, 0); -x_63 = lean_unbox(x_62); -lean_dec(x_62); -x_64 = l_Bool_toLBool(x_63); -x_65 = lean_box(x_64); -lean_ctor_set(x_60, 0, x_65); -return x_60; +lean_object* x_61; uint8_t x_62; uint8_t x_63; lean_object* x_64; +x_61 = lean_ctor_get(x_59, 0); +x_62 = lean_unbox(x_61); +lean_dec(x_61); +x_63 = l_Bool_toLBool(x_62); +x_64 = lean_box(x_63); +lean_ctor_set(x_59, 0, x_64); +return x_59; } else { -lean_object* x_66; lean_object* x_67; uint8_t x_68; uint8_t x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_60, 0); -x_67 = lean_ctor_get(x_60, 1); -lean_inc(x_67); +lean_object* x_65; lean_object* x_66; uint8_t x_67; uint8_t x_68; lean_object* x_69; lean_object* x_70; +x_65 = lean_ctor_get(x_59, 0); +x_66 = lean_ctor_get(x_59, 1); lean_inc(x_66); -lean_dec(x_60); -x_68 = lean_unbox(x_66); -lean_dec(x_66); -x_69 = l_Bool_toLBool(x_68); -x_70 = lean_box(x_69); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_67); -return x_71; +lean_inc(x_65); +lean_dec(x_59); +x_67 = lean_unbox(x_65); +lean_dec(x_65); +x_68 = l_Bool_toLBool(x_67); +x_69 = lean_box(x_68); +x_70 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_70, 0, x_69); +lean_ctor_set(x_70, 1, x_66); +return x_70; } } else { -uint8_t x_72; -x_72 = !lean_is_exclusive(x_60); -if (x_72 == 0) +uint8_t x_71; +x_71 = !lean_is_exclusive(x_59); +if (x_71 == 0) { -return x_60; +return x_59; } else { -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_60, 0); -x_74 = lean_ctor_get(x_60, 1); -lean_inc(x_74); +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_59, 0); +x_73 = lean_ctor_get(x_59, 1); lean_inc(x_73); -lean_dec(x_60); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; +lean_inc(x_72); +lean_dec(x_59); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; } } } else { -uint8_t x_76; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_2); -lean_dec(x_1); -x_76 = !lean_is_exclusive(x_58); -if (x_76 == 0) -{ -return x_58; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_58, 0); -x_78 = lean_ctor_get(x_58, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_58); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -else -{ -uint8_t x_80; -lean_dec(x_30); -lean_dec(x_28); -lean_dec(x_8); +uint8_t x_75; lean_dec(x_7); lean_dec(x_6); -lean_dec(x_2); lean_dec(x_1); -x_80 = !lean_is_exclusive(x_35); -if (x_80 == 0) +x_75 = !lean_is_exclusive(x_57); +if (x_75 == 0) { -return x_35; +return x_57; } else { -lean_object* x_81; lean_object* x_82; lean_object* x_83; -x_81 = lean_ctor_get(x_35, 0); -x_82 = lean_ctor_get(x_35, 1); -lean_inc(x_82); +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_57, 0); +x_77 = lean_ctor_get(x_57, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_57); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +} +else +{ +uint8_t x_79; +lean_dec(x_29); +lean_dec(x_27); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_79 = !lean_is_exclusive(x_34); +if (x_79 == 0) +{ +return x_34; +} +else +{ +lean_object* x_80; lean_object* x_81; lean_object* x_82; +x_80 = lean_ctor_get(x_34, 0); +x_81 = lean_ctor_get(x_34, 1); lean_inc(x_81); -lean_dec(x_35); -x_83 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_83, 0, x_81); -lean_ctor_set(x_83, 1, x_82); -return x_83; +lean_inc(x_80); +lean_dec(x_34); +x_82 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_82, 0, x_80); +lean_ctor_set(x_82, 1, x_81); +return x_82; } } } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { uint8_t x_6; @@ -12007,7 +15303,7 @@ return x_14; } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { _start: { if (x_4 == 0) @@ -12034,69 +15330,69 @@ return x_11; } } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_7; -x_7 = lean_apply_4(x_1, x_2, x_3, x_5, x_6); -if (lean_obj_tag(x_7) == 0) +lean_object* x_6; +x_6 = l_Lean_Meta_isExprDefEqAux(x_1, x_2, x_4, x_5); +if (lean_obj_tag(x_6) == 0) { -uint8_t x_8; -x_8 = !lean_is_exclusive(x_7); -if (x_8 == 0) +uint8_t x_7; +x_7 = !lean_is_exclusive(x_6); +if (x_7 == 0) { -lean_object* x_9; uint8_t x_10; uint8_t x_11; lean_object* x_12; -x_9 = lean_ctor_get(x_7, 0); -x_10 = lean_unbox(x_9); -lean_dec(x_9); -x_11 = l_Bool_toLBool(x_10); -x_12 = lean_box(x_11); -lean_ctor_set(x_7, 0, x_12); -return x_7; +lean_object* x_8; uint8_t x_9; uint8_t x_10; lean_object* x_11; +x_8 = lean_ctor_get(x_6, 0); +x_9 = lean_unbox(x_8); +lean_dec(x_8); +x_10 = l_Bool_toLBool(x_9); +x_11 = lean_box(x_10); +lean_ctor_set(x_6, 0, x_11); +return x_6; } else { -lean_object* x_13; lean_object* x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; -x_13 = lean_ctor_get(x_7, 0); -x_14 = lean_ctor_get(x_7, 1); -lean_inc(x_14); +lean_object* x_12; lean_object* x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; +x_12 = lean_ctor_get(x_6, 0); +x_13 = lean_ctor_get(x_6, 1); lean_inc(x_13); -lean_dec(x_7); -x_15 = lean_unbox(x_13); -lean_dec(x_13); -x_16 = l_Bool_toLBool(x_15); -x_17 = lean_box(x_16); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_14); -return x_18; +lean_inc(x_12); +lean_dec(x_6); +x_14 = lean_unbox(x_12); +lean_dec(x_12); +x_15 = l_Bool_toLBool(x_14); +x_16 = lean_box(x_15); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_16); +lean_ctor_set(x_17, 1, x_13); +return x_17; } } else { -uint8_t x_19; -x_19 = !lean_is_exclusive(x_7); -if (x_19 == 0) +uint8_t x_18; +x_18 = !lean_is_exclusive(x_6); +if (x_18 == 0) { -return x_7; +return x_6; } else { -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_7, 0); -x_21 = lean_ctor_get(x_7, 1); -lean_inc(x_21); +lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_19 = lean_ctor_get(x_6, 0); +x_20 = lean_ctor_get(x_6, 1); lean_inc(x_20); -lean_dec(x_7); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; +lean_inc(x_19); +lean_dec(x_6); +x_21 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_21, 0, x_19); +lean_ctor_set(x_21, 1, x_20); +return x_21; } } } } -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7___closed__1() { +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7___closed__1() { _start: { lean_object* x_1; @@ -12104,877 +15400,256 @@ x_1 = lean_mk_string("unfoldLeftRight"); return x_1; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_9, 4); -lean_inc(x_10); -x_11 = lean_ctor_get_uint8(x_10, sizeof(void*)*1); -lean_dec(x_10); -if (x_11 == 0) +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_8, 4); +lean_inc(x_9); +x_10 = lean_ctor_get_uint8(x_9, sizeof(void*)*1); +lean_dec(x_9); +if (x_10 == 0) { -lean_object* x_12; -lean_dec(x_6); +lean_object* x_11; lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_12 = lean_apply_4(x_1, x_2, x_7, x_8, x_9); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_unbox(x_14); -lean_dec(x_14); -x_16 = l_Bool_toLBool(x_15); -x_17 = lean_box(x_16); -lean_ctor_set(x_12, 0, x_17); -return x_12; -} -else -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_12); -x_20 = lean_unbox(x_18); -lean_dec(x_18); -x_21 = l_Bool_toLBool(x_20); -x_22 = lean_box(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); -return x_23; -} -} -else -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) -{ -return x_12; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_28 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7___closed__1; -x_29 = lean_name_mk_string(x_3, x_28); -x_30 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_29); -x_31 = l_Lean_Name_append___main(x_30, x_29); -x_32 = l_Lean_Meta_tracer; -x_33 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_4, x_32, x_31); -lean_inc(x_8); -x_34 = lean_apply_2(x_33, x_8, x_9); -if (lean_obj_tag(x_34) == 0) -{ -lean_object* x_35; uint8_t x_36; -x_35 = lean_ctor_get(x_34, 0); -lean_inc(x_35); -x_36 = lean_unbox(x_35); -lean_dec(x_35); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; -lean_dec(x_29); -lean_dec(x_6); -lean_dec(x_5); -x_37 = lean_ctor_get(x_34, 1); -lean_inc(x_37); -lean_dec(x_34); -x_38 = lean_apply_4(x_1, x_2, x_7, x_8, x_37); -if (lean_obj_tag(x_38) == 0) -{ -uint8_t x_39; -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; uint8_t x_42; lean_object* x_43; -x_40 = lean_ctor_get(x_38, 0); -x_41 = lean_unbox(x_40); -lean_dec(x_40); -x_42 = l_Bool_toLBool(x_41); -x_43 = lean_box(x_42); -lean_ctor_set(x_38, 0, x_43); -return x_38; -} -else -{ -lean_object* x_44; lean_object* x_45; uint8_t x_46; uint8_t x_47; lean_object* x_48; lean_object* x_49; -x_44 = lean_ctor_get(x_38, 0); -x_45 = lean_ctor_get(x_38, 1); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_38); -x_46 = lean_unbox(x_44); -lean_dec(x_44); -x_47 = l_Bool_toLBool(x_46); -x_48 = lean_box(x_47); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_45); -return x_49; -} -} -else -{ -uint8_t x_50; -x_50 = !lean_is_exclusive(x_38); -if (x_50 == 0) -{ -return x_38; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_38, 0); -x_52 = lean_ctor_get(x_38, 1); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_38); -x_53 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_53, 0, x_51); -lean_ctor_set(x_53, 1, x_52); -return x_53; -} -} -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_54 = lean_ctor_get(x_34, 1); -lean_inc(x_54); -lean_dec(x_34); -x_55 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_55, 0, x_5); -x_56 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_29, x_55); -lean_inc(x_8); -x_57 = lean_apply_2(x_56, x_8, x_54); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_57, 1); -lean_inc(x_58); -lean_dec(x_57); -x_59 = lean_apply_4(x_1, x_2, x_7, x_8, x_58); -if (lean_obj_tag(x_59) == 0) -{ -uint8_t x_60; -x_60 = !lean_is_exclusive(x_59); -if (x_60 == 0) -{ -lean_object* x_61; uint8_t x_62; uint8_t x_63; lean_object* x_64; -x_61 = lean_ctor_get(x_59, 0); -x_62 = lean_unbox(x_61); -lean_dec(x_61); -x_63 = l_Bool_toLBool(x_62); -x_64 = lean_box(x_63); -lean_ctor_set(x_59, 0, x_64); -return x_59; -} -else -{ -lean_object* x_65; lean_object* x_66; uint8_t x_67; uint8_t x_68; lean_object* x_69; lean_object* x_70; -x_65 = lean_ctor_get(x_59, 0); -x_66 = lean_ctor_get(x_59, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_59); -x_67 = lean_unbox(x_65); -lean_dec(x_65); -x_68 = l_Bool_toLBool(x_67); -x_69 = lean_box(x_68); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_69); -lean_ctor_set(x_70, 1, x_66); -return x_70; -} -} -else -{ -uint8_t x_71; -x_71 = !lean_is_exclusive(x_59); -if (x_71 == 0) -{ -return x_59; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_59, 0); -x_73 = lean_ctor_get(x_59, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_59); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_8); -lean_dec(x_7); lean_dec(x_2); -lean_dec(x_1); -x_75 = !lean_is_exclusive(x_57); -if (x_75 == 0) -{ -return x_57; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_57, 0); -x_77 = lean_ctor_get(x_57, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_57); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -} -else -{ -uint8_t x_79; -lean_dec(x_29); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_79 = !lean_is_exclusive(x_34); -if (x_79 == 0) -{ -return x_34; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_34, 0); -x_81 = lean_ctor_get(x_34, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_34); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { -_start: -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_14 = l_Lean_ConstantInfo_name(x_1); -x_15 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1; -lean_inc(x_2); -x_16 = lean_name_mk_string(x_2, x_15); -lean_inc(x_3); -lean_inc(x_16); -x_17 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__4___boxed), 5, 2); -lean_closure_set(x_17, 0, x_16); -lean_closure_set(x_17, 1, x_3); -x_18 = l_Lean_Meta_tracer___closed__3; -lean_inc(x_4); -x_19 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_19, 0, x_4); -lean_closure_set(x_19, 1, lean_box(0)); -lean_closure_set(x_19, 2, lean_box(0)); -lean_closure_set(x_19, 3, x_18); -lean_closure_set(x_19, 4, x_17); -lean_inc(x_5); -lean_inc(x_14); -x_20 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__5___boxed), 6, 3); -lean_closure_set(x_20, 0, x_14); -lean_closure_set(x_20, 1, x_5); -lean_closure_set(x_20, 2, x_16); -lean_inc(x_4); -x_21 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_21, 0, x_4); -lean_closure_set(x_21, 1, lean_box(0)); -lean_closure_set(x_21, 2, lean_box(0)); -lean_closure_set(x_21, 3, x_19); -lean_closure_set(x_21, 4, x_20); -lean_inc(x_7); -lean_inc(x_11); -lean_inc(x_6); -x_22 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__6___boxed), 6, 3); -lean_closure_set(x_22, 0, x_6); -lean_closure_set(x_22, 1, x_11); -lean_closure_set(x_22, 2, x_7); -x_23 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_23, 0, x_4); -lean_closure_set(x_23, 1, lean_box(0)); -lean_closure_set(x_23, 2, lean_box(0)); -lean_closure_set(x_23, 3, x_21); -lean_closure_set(x_23, 4, x_22); -lean_inc(x_6); -x_24 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7), 9, 6); -lean_closure_set(x_24, 0, x_6); -lean_closure_set(x_24, 1, x_11); -lean_closure_set(x_24, 2, x_2); -lean_closure_set(x_24, 3, x_3); -lean_closure_set(x_24, 4, x_14); -lean_closure_set(x_24, 5, x_5); -x_25 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_8, x_9, x_6, x_10, x_7, x_23, x_24, x_12, x_13); -return x_25; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_9, 4); -lean_inc(x_10); -x_11 = lean_ctor_get_uint8(x_10, sizeof(void*)*1); -lean_dec(x_10); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -x_12 = lean_apply_4(x_1, x_2, x_7, x_8, x_9); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_unbox(x_14); -lean_dec(x_14); -x_16 = l_Bool_toLBool(x_15); -x_17 = lean_box(x_16); -lean_ctor_set(x_12, 0, x_17); -return x_12; -} -else -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_12); -x_20 = lean_unbox(x_18); -lean_dec(x_18); -x_21 = l_Bool_toLBool(x_20); -x_22 = lean_box(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); -return x_23; -} -} -else -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) -{ -return x_12; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_28 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1; -x_29 = lean_name_mk_string(x_3, x_28); -x_30 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_29); -x_31 = l_Lean_Name_append___main(x_30, x_29); -x_32 = l_Lean_Meta_tracer; -x_33 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_4, x_32, x_31); -lean_inc(x_8); -x_34 = lean_apply_2(x_33, x_8, x_9); -if (lean_obj_tag(x_34) == 0) -{ -lean_object* x_35; uint8_t x_36; -x_35 = lean_ctor_get(x_34, 0); -lean_inc(x_35); -x_36 = lean_unbox(x_35); -lean_dec(x_35); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; -lean_dec(x_29); -lean_dec(x_6); -lean_dec(x_5); -x_37 = lean_ctor_get(x_34, 1); -lean_inc(x_37); -lean_dec(x_34); -x_38 = lean_apply_4(x_1, x_2, x_7, x_8, x_37); -if (lean_obj_tag(x_38) == 0) -{ -uint8_t x_39; -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; uint8_t x_42; lean_object* x_43; -x_40 = lean_ctor_get(x_38, 0); -x_41 = lean_unbox(x_40); -lean_dec(x_40); -x_42 = l_Bool_toLBool(x_41); -x_43 = lean_box(x_42); -lean_ctor_set(x_38, 0, x_43); -return x_38; -} -else -{ -lean_object* x_44; lean_object* x_45; uint8_t x_46; uint8_t x_47; lean_object* x_48; lean_object* x_49; -x_44 = lean_ctor_get(x_38, 0); -x_45 = lean_ctor_get(x_38, 1); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_38); -x_46 = lean_unbox(x_44); -lean_dec(x_44); -x_47 = l_Bool_toLBool(x_46); -x_48 = lean_box(x_47); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_45); -return x_49; -} -} -else -{ -uint8_t x_50; -x_50 = !lean_is_exclusive(x_38); -if (x_50 == 0) -{ -return x_38; -} -else -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_38, 0); -x_52 = lean_ctor_get(x_38, 1); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_38); -x_53 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_53, 0, x_51); -lean_ctor_set(x_53, 1, x_52); -return x_53; -} -} -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_54 = lean_ctor_get(x_34, 1); -lean_inc(x_54); -lean_dec(x_34); -x_55 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_55, 0, x_5); -x_56 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_29, x_55); -lean_inc(x_8); -x_57 = lean_apply_2(x_56, x_8, x_54); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_57, 1); -lean_inc(x_58); -lean_dec(x_57); -x_59 = lean_apply_4(x_1, x_2, x_7, x_8, x_58); -if (lean_obj_tag(x_59) == 0) -{ -uint8_t x_60; -x_60 = !lean_is_exclusive(x_59); -if (x_60 == 0) -{ -lean_object* x_61; uint8_t x_62; uint8_t x_63; lean_object* x_64; -x_61 = lean_ctor_get(x_59, 0); -x_62 = lean_unbox(x_61); -lean_dec(x_61); -x_63 = l_Bool_toLBool(x_62); -x_64 = lean_box(x_63); -lean_ctor_set(x_59, 0, x_64); -return x_59; -} -else -{ -lean_object* x_65; lean_object* x_66; uint8_t x_67; uint8_t x_68; lean_object* x_69; lean_object* x_70; -x_65 = lean_ctor_get(x_59, 0); -x_66 = lean_ctor_get(x_59, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_59); -x_67 = lean_unbox(x_65); -lean_dec(x_65); -x_68 = l_Bool_toLBool(x_67); -x_69 = lean_box(x_68); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_69); -lean_ctor_set(x_70, 1, x_66); -return x_70; -} -} -else -{ -uint8_t x_71; -x_71 = !lean_is_exclusive(x_59); -if (x_71 == 0) -{ -return x_59; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_59, 0); -x_73 = lean_ctor_get(x_59, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_59); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_2); -lean_dec(x_1); -x_75 = !lean_is_exclusive(x_57); -if (x_75 == 0) -{ -return x_57; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_57, 0); -x_77 = lean_ctor_get(x_57, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_57); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -} -else -{ -uint8_t x_79; -lean_dec(x_29); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_79 = !lean_is_exclusive(x_34); -if (x_79 == 0) -{ -return x_34; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_34, 0); -x_81 = lean_ctor_get(x_34, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_34); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__10(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { -_start: +x_11 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_8); +if (lean_obj_tag(x_11) == 0) { uint8_t x_12; -x_12 = l___private_Init_Lean_Meta_ExprDefEq_18__sameHeadSymbol(x_1, x_9); +x_12 = !lean_is_exclusive(x_11); if (x_12 == 0) { -lean_object* x_13; uint8_t x_14; -lean_dec(x_8); -lean_dec(x_1); -x_13 = lean_ctor_get(x_11, 4); -lean_inc(x_13); -x_14 = lean_ctor_get_uint8(x_13, sizeof(void*)*1); +lean_object* x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); +x_14 = lean_unbox(x_13); lean_dec(x_13); -if (x_14 == 0) -{ -lean_object* x_15; -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_15 = lean_apply_4(x_2, x_3, x_9, x_10, x_11); -if (lean_obj_tag(x_15) == 0) -{ -uint8_t x_16; -x_16 = !lean_is_exclusive(x_15); -if (x_16 == 0) -{ -lean_object* x_17; uint8_t x_18; uint8_t x_19; lean_object* x_20; -x_17 = lean_ctor_get(x_15, 0); -x_18 = lean_unbox(x_17); -lean_dec(x_17); -x_19 = l_Bool_toLBool(x_18); -x_20 = lean_box(x_19); -lean_ctor_set(x_15, 0, x_20); -return x_15; +x_15 = l_Bool_toLBool(x_14); +x_16 = lean_box(x_15); +lean_ctor_set(x_11, 0, x_16); +return x_11; } else { -lean_object* x_21; lean_object* x_22; uint8_t x_23; uint8_t x_24; lean_object* x_25; lean_object* x_26; -x_21 = lean_ctor_get(x_15, 0); -x_22 = lean_ctor_get(x_15, 1); -lean_inc(x_22); -lean_inc(x_21); -lean_dec(x_15); -x_23 = lean_unbox(x_21); -lean_dec(x_21); -x_24 = l_Bool_toLBool(x_23); -x_25 = lean_box(x_24); -x_26 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_26, 0, x_25); -lean_ctor_set(x_26, 1, x_22); +lean_object* x_17; lean_object* x_18; uint8_t x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_11); +x_19 = lean_unbox(x_17); +lean_dec(x_17); +x_20 = l_Bool_toLBool(x_19); +x_21 = lean_box(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; +} +} +else +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_11); +if (x_23 == 0) +{ +return x_11; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); return x_26; } } -else -{ -uint8_t x_27; -x_27 = !lean_is_exclusive(x_15); -if (x_27 == 0) -{ -return x_15; } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_15, 0); -x_29 = lean_ctor_get(x_15, 1); -lean_inc(x_29); +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_27 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7___closed__1; +x_28 = lean_name_mk_string(x_2, x_27); +x_29 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; lean_inc(x_28); -lean_dec(x_15); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; -} -} -} -else +x_30 = l_Lean_Name_append___main(x_29, x_28); +x_31 = l_Lean_Meta_tracer; +x_32 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_3, x_31, x_30); +lean_inc(x_7); +x_33 = lean_apply_2(x_32, x_7, x_8); +if (lean_obj_tag(x_33) == 0) { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_31 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7___closed__1; -x_32 = lean_name_mk_string(x_4, x_31); -x_33 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_32); -x_34 = l_Lean_Name_append___main(x_33, x_32); -x_35 = l_Lean_Meta_tracer; -x_36 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_5, x_35, x_34); -lean_inc(x_10); -x_37 = lean_apply_2(x_36, x_10, x_11); +lean_object* x_34; uint8_t x_35; +x_34 = lean_ctor_get(x_33, 0); +lean_inc(x_34); +x_35 = lean_unbox(x_34); +lean_dec(x_34); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; +lean_dec(x_28); +lean_dec(x_5); +lean_dec(x_4); +x_36 = lean_ctor_get(x_33, 1); +lean_inc(x_36); +lean_dec(x_33); +x_37 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_36); if (lean_obj_tag(x_37) == 0) { -lean_object* x_38; uint8_t x_39; -x_38 = lean_ctor_get(x_37, 0); -lean_inc(x_38); -x_39 = lean_unbox(x_38); -lean_dec(x_38); -if (x_39 == 0) +uint8_t x_38; +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) { -lean_object* x_40; lean_object* x_41; -lean_dec(x_32); -lean_dec(x_7); -lean_dec(x_6); -x_40 = lean_ctor_get(x_37, 1); -lean_inc(x_40); -lean_dec(x_37); -x_41 = lean_apply_4(x_2, x_3, x_9, x_10, x_40); -if (lean_obj_tag(x_41) == 0) -{ -uint8_t x_42; -x_42 = !lean_is_exclusive(x_41); -if (x_42 == 0) -{ -lean_object* x_43; uint8_t x_44; uint8_t x_45; lean_object* x_46; -x_43 = lean_ctor_get(x_41, 0); -x_44 = lean_unbox(x_43); -lean_dec(x_43); -x_45 = l_Bool_toLBool(x_44); -x_46 = lean_box(x_45); -lean_ctor_set(x_41, 0, x_46); -return x_41; +lean_object* x_39; uint8_t x_40; uint8_t x_41; lean_object* x_42; +x_39 = lean_ctor_get(x_37, 0); +x_40 = lean_unbox(x_39); +lean_dec(x_39); +x_41 = l_Bool_toLBool(x_40); +x_42 = lean_box(x_41); +lean_ctor_set(x_37, 0, x_42); +return x_37; } else { -lean_object* x_47; lean_object* x_48; uint8_t x_49; uint8_t x_50; lean_object* x_51; lean_object* x_52; -x_47 = lean_ctor_get(x_41, 0); -x_48 = lean_ctor_get(x_41, 1); -lean_inc(x_48); -lean_inc(x_47); -lean_dec(x_41); -x_49 = lean_unbox(x_47); -lean_dec(x_47); -x_50 = l_Bool_toLBool(x_49); -x_51 = lean_box(x_50); -x_52 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_48); +lean_object* x_43; lean_object* x_44; uint8_t x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_37, 0); +x_44 = lean_ctor_get(x_37, 1); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_37); +x_45 = lean_unbox(x_43); +lean_dec(x_43); +x_46 = l_Bool_toLBool(x_45); +x_47 = lean_box(x_46); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_47); +lean_ctor_set(x_48, 1, x_44); +return x_48; +} +} +else +{ +uint8_t x_49; +x_49 = !lean_is_exclusive(x_37); +if (x_49 == 0) +{ +return x_37; +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_50 = lean_ctor_get(x_37, 0); +x_51 = lean_ctor_get(x_37, 1); +lean_inc(x_51); +lean_inc(x_50); +lean_dec(x_37); +x_52 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_52, 0, x_50); +lean_ctor_set(x_52, 1, x_51); return x_52; } } -else -{ -uint8_t x_53; -x_53 = !lean_is_exclusive(x_41); -if (x_53 == 0) -{ -return x_41; } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_41, 0); -x_55 = lean_ctor_get(x_41, 1); -lean_inc(x_55); -lean_inc(x_54); -lean_dec(x_41); -x_56 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_56, 0, x_54); -lean_ctor_set(x_56, 1, x_55); -return x_56; -} -} -} -else +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_53 = lean_ctor_get(x_33, 1); +lean_inc(x_53); +lean_dec(x_33); +x_54 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_54, 0, x_4); +x_55 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_5, x_28, x_54); +lean_inc(x_7); +x_56 = lean_apply_2(x_55, x_7, x_53); +if (lean_obj_tag(x_56) == 0) { -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_57 = lean_ctor_get(x_37, 1); +lean_object* x_57; lean_object* x_58; +x_57 = lean_ctor_get(x_56, 1); lean_inc(x_57); -lean_dec(x_37); -x_58 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_58, 0, x_6); -x_59 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_7, x_32, x_58); -lean_inc(x_10); -x_60 = lean_apply_2(x_59, x_10, x_57); -if (lean_obj_tag(x_60) == 0) +lean_dec(x_56); +x_58 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_57); +if (lean_obj_tag(x_58) == 0) { -lean_object* x_61; lean_object* x_62; -x_61 = lean_ctor_get(x_60, 1); -lean_inc(x_61); +uint8_t x_59; +x_59 = !lean_is_exclusive(x_58); +if (x_59 == 0) +{ +lean_object* x_60; uint8_t x_61; uint8_t x_62; lean_object* x_63; +x_60 = lean_ctor_get(x_58, 0); +x_61 = lean_unbox(x_60); lean_dec(x_60); -x_62 = lean_apply_4(x_2, x_3, x_9, x_10, x_61); -if (lean_obj_tag(x_62) == 0) -{ -uint8_t x_63; -x_63 = !lean_is_exclusive(x_62); -if (x_63 == 0) -{ -lean_object* x_64; uint8_t x_65; uint8_t x_66; lean_object* x_67; -x_64 = lean_ctor_get(x_62, 0); -x_65 = lean_unbox(x_64); -lean_dec(x_64); -x_66 = l_Bool_toLBool(x_65); -x_67 = lean_box(x_66); -lean_ctor_set(x_62, 0, x_67); -return x_62; +x_62 = l_Bool_toLBool(x_61); +x_63 = lean_box(x_62); +lean_ctor_set(x_58, 0, x_63); +return x_58; } else { -lean_object* x_68; lean_object* x_69; uint8_t x_70; uint8_t x_71; lean_object* x_72; lean_object* x_73; -x_68 = lean_ctor_get(x_62, 0); -x_69 = lean_ctor_get(x_62, 1); -lean_inc(x_69); -lean_inc(x_68); -lean_dec(x_62); -x_70 = lean_unbox(x_68); -lean_dec(x_68); -x_71 = l_Bool_toLBool(x_70); -x_72 = lean_box(x_71); -x_73 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_73, 0, x_72); -lean_ctor_set(x_73, 1, x_69); +lean_object* x_64; lean_object* x_65; uint8_t x_66; uint8_t x_67; lean_object* x_68; lean_object* x_69; +x_64 = lean_ctor_get(x_58, 0); +x_65 = lean_ctor_get(x_58, 1); +lean_inc(x_65); +lean_inc(x_64); +lean_dec(x_58); +x_66 = lean_unbox(x_64); +lean_dec(x_64); +x_67 = l_Bool_toLBool(x_66); +x_68 = lean_box(x_67); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_65); +return x_69; +} +} +else +{ +uint8_t x_70; +x_70 = !lean_is_exclusive(x_58); +if (x_70 == 0) +{ +return x_58; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_58, 0); +x_72 = lean_ctor_get(x_58, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_58); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_71); +lean_ctor_set(x_73, 1, x_72); return x_73; } } +} else { uint8_t x_74; -x_74 = !lean_is_exclusive(x_62); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_56); if (x_74 == 0) { -return x_62; +return x_56; } else { lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_62, 0); -x_76 = lean_ctor_get(x_62, 1); +x_75 = lean_ctor_get(x_56, 0); +x_76 = lean_ctor_get(x_56, 1); lean_inc(x_76); lean_inc(x_75); -lean_dec(x_62); +lean_dec(x_56); x_77 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_77, 0, x_75); lean_ctor_set(x_77, 1, x_76); @@ -12982,26 +15657,29 @@ return x_77; } } } +} else { uint8_t x_78; -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_78 = !lean_is_exclusive(x_60); +lean_dec(x_28); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_33); if (x_78 == 0) { -return x_60; +return x_33; } else { lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_60, 0); -x_80 = lean_ctor_get(x_60, 1); +x_79 = lean_ctor_get(x_33, 0); +x_80 = lean_ctor_get(x_33, 1); lean_inc(x_80); lean_inc(x_79); -lean_dec(x_60); +lean_dec(x_33); x_81 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_81, 0, x_79); lean_ctor_set(x_81, 1, x_80); @@ -13010,54 +15688,7038 @@ return x_81; } } } -else +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: { -uint8_t x_82; -lean_dec(x_32); -lean_dec(x_10); +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +x_10 = l_Lean_ConstantInfo_name(x_1); +x_11 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1; +lean_inc(x_2); +x_12 = lean_name_mk_string(x_2, x_11); +lean_inc(x_3); +lean_inc(x_12); +x_13 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__4___boxed), 5, 2); +lean_closure_set(x_13, 0, x_12); +lean_closure_set(x_13, 1, x_3); +x_14 = l_Lean_Meta_tracer___closed__3; +lean_inc(x_4); +x_15 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_15, 0, x_4); +lean_closure_set(x_15, 1, lean_box(0)); +lean_closure_set(x_15, 2, lean_box(0)); +lean_closure_set(x_15, 3, x_14); +lean_closure_set(x_15, 4, x_13); +lean_inc(x_5); +lean_inc(x_10); +x_16 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__5___boxed), 6, 3); +lean_closure_set(x_16, 0, x_10); +lean_closure_set(x_16, 1, x_5); +lean_closure_set(x_16, 2, x_12); +lean_inc(x_4); +x_17 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_17, 0, x_4); +lean_closure_set(x_17, 1, lean_box(0)); +lean_closure_set(x_17, 2, lean_box(0)); +lean_closure_set(x_17, 3, x_15); +lean_closure_set(x_17, 4, x_16); +lean_inc(x_6); +lean_inc(x_7); +x_18 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__6___boxed), 5, 2); +lean_closure_set(x_18, 0, x_7); +lean_closure_set(x_18, 1, x_6); +x_19 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_19, 0, x_4); +lean_closure_set(x_19, 1, lean_box(0)); +lean_closure_set(x_19, 2, lean_box(0)); +lean_closure_set(x_19, 3, x_17); +lean_closure_set(x_19, 4, x_18); +x_20 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7), 8, 5); +lean_closure_set(x_20, 0, x_7); +lean_closure_set(x_20, 1, x_2); +lean_closure_set(x_20, 2, x_3); +lean_closure_set(x_20, 3, x_10); +lean_closure_set(x_20, 4, x_5); +x_21 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_6, x_19, x_20, x_8, x_9); +return x_21; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_8, 4); +lean_inc(x_9); +x_10 = lean_ctor_get_uint8(x_9, sizeof(void*)*1); lean_dec(x_9); -lean_dec(x_7); -lean_dec(x_6); +if (x_10 == 0) +{ +lean_object* x_11; +lean_dec(x_5); +lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_82 = !lean_is_exclusive(x_37); -if (x_82 == 0) +x_11 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_8); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); +x_14 = lean_unbox(x_13); +lean_dec(x_13); +x_15 = l_Bool_toLBool(x_14); +x_16 = lean_box(x_15); +lean_ctor_set(x_11, 0, x_16); +return x_11; +} +else +{ +lean_object* x_17; lean_object* x_18; uint8_t x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_11); +x_19 = lean_unbox(x_17); +lean_dec(x_17); +x_20 = l_Bool_toLBool(x_19); +x_21 = lean_box(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; +} +} +else +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_11); +if (x_23 == 0) +{ +return x_11; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_27 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1; +x_28 = lean_name_mk_string(x_2, x_27); +x_29 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +lean_inc(x_28); +x_30 = l_Lean_Name_append___main(x_29, x_28); +x_31 = l_Lean_Meta_tracer; +x_32 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_3, x_31, x_30); +lean_inc(x_7); +x_33 = lean_apply_2(x_32, x_7, x_8); +if (lean_obj_tag(x_33) == 0) +{ +lean_object* x_34; uint8_t x_35; +x_34 = lean_ctor_get(x_33, 0); +lean_inc(x_34); +x_35 = lean_unbox(x_34); +lean_dec(x_34); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; +lean_dec(x_28); +lean_dec(x_5); +lean_dec(x_4); +x_36 = lean_ctor_get(x_33, 1); +lean_inc(x_36); +lean_dec(x_33); +x_37 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_36); +if (lean_obj_tag(x_37) == 0) +{ +uint8_t x_38; +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; uint8_t x_41; lean_object* x_42; +x_39 = lean_ctor_get(x_37, 0); +x_40 = lean_unbox(x_39); +lean_dec(x_39); +x_41 = l_Bool_toLBool(x_40); +x_42 = lean_box(x_41); +lean_ctor_set(x_37, 0, x_42); +return x_37; +} +else +{ +lean_object* x_43; lean_object* x_44; uint8_t x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_37, 0); +x_44 = lean_ctor_get(x_37, 1); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_37); +x_45 = lean_unbox(x_43); +lean_dec(x_43); +x_46 = l_Bool_toLBool(x_45); +x_47 = lean_box(x_46); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_47); +lean_ctor_set(x_48, 1, x_44); +return x_48; +} +} +else +{ +uint8_t x_49; +x_49 = !lean_is_exclusive(x_37); +if (x_49 == 0) { return x_37; } else { -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_37, 0); -x_84 = lean_ctor_get(x_37, 1); -lean_inc(x_84); -lean_inc(x_83); +lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_50 = lean_ctor_get(x_37, 0); +x_51 = lean_ctor_get(x_37, 1); +lean_inc(x_51); +lean_inc(x_50); lean_dec(x_37); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; +x_52 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_52, 0, x_50); +lean_ctor_set(x_52, 1, x_51); +return x_52; +} +} +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_53 = lean_ctor_get(x_33, 1); +lean_inc(x_53); +lean_dec(x_33); +x_54 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_54, 0, x_4); +x_55 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_5, x_28, x_54); +lean_inc(x_7); +x_56 = lean_apply_2(x_55, x_7, x_53); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; lean_object* x_58; +x_57 = lean_ctor_get(x_56, 1); +lean_inc(x_57); +lean_dec(x_56); +x_58 = l_Lean_Meta_isExprDefEqAux(x_1, x_6, x_7, x_57); +if (lean_obj_tag(x_58) == 0) +{ +uint8_t x_59; +x_59 = !lean_is_exclusive(x_58); +if (x_59 == 0) +{ +lean_object* x_60; uint8_t x_61; uint8_t x_62; lean_object* x_63; +x_60 = lean_ctor_get(x_58, 0); +x_61 = lean_unbox(x_60); +lean_dec(x_60); +x_62 = l_Bool_toLBool(x_61); +x_63 = lean_box(x_62); +lean_ctor_set(x_58, 0, x_63); +return x_58; +} +else +{ +lean_object* x_64; lean_object* x_65; uint8_t x_66; uint8_t x_67; lean_object* x_68; lean_object* x_69; +x_64 = lean_ctor_get(x_58, 0); +x_65 = lean_ctor_get(x_58, 1); +lean_inc(x_65); +lean_inc(x_64); +lean_dec(x_58); +x_66 = lean_unbox(x_64); +lean_dec(x_64); +x_67 = l_Bool_toLBool(x_66); +x_68 = lean_box(x_67); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_65); +return x_69; +} +} +else +{ +uint8_t x_70; +x_70 = !lean_is_exclusive(x_58); +if (x_70 == 0) +{ +return x_58; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_58, 0); +x_72 = lean_ctor_get(x_58, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_58); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_71); +lean_ctor_set(x_73, 1, x_72); +return x_73; +} +} +} +else +{ +uint8_t x_74; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_56); +if (x_74 == 0) +{ +return x_56; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_56, 0); +x_76 = lean_ctor_get(x_56, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_56); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; } } } } else { -lean_object* x_86; uint8_t x_87; -lean_dec(x_6); -lean_dec(x_3); -x_86 = lean_ctor_get(x_11, 4); -lean_inc(x_86); -x_87 = lean_ctor_get_uint8(x_86, sizeof(void*)*1); -lean_dec(x_86); -if (x_87 == 0) -{ -lean_object* x_88; -lean_dec(x_8); +uint8_t x_78; +lean_dec(x_28); lean_dec(x_7); +lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); -x_88 = lean_apply_4(x_2, x_1, x_9, x_10, x_11); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_33); +if (x_78 == 0) +{ +return x_33; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_33, 0); +x_80 = lean_ctor_get(x_33, 1); +lean_inc(x_80); +lean_inc(x_79); +lean_dec(x_33); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_79); +lean_ctor_set(x_81, 1, x_80); +return x_81; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__10(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +_start: +{ +uint8_t x_11; +x_11 = l___private_Init_Lean_Meta_ExprDefEq_20__sameHeadSymbol(x_1, x_8); +if (x_11 == 0) +{ +lean_object* x_12; uint8_t x_13; +lean_dec(x_7); +lean_dec(x_1); +x_12 = lean_ctor_get(x_10, 4); +lean_inc(x_12); +x_13 = lean_ctor_get_uint8(x_12, sizeof(void*)*1); +lean_dec(x_12); +if (x_13 == 0) +{ +lean_object* x_14; +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +x_14 = l_Lean_Meta_isExprDefEqAux(x_2, x_8, x_9, x_10); +if (lean_obj_tag(x_14) == 0) +{ +uint8_t x_15; +x_15 = !lean_is_exclusive(x_14); +if (x_15 == 0) +{ +lean_object* x_16; uint8_t x_17; uint8_t x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_14, 0); +x_17 = lean_unbox(x_16); +lean_dec(x_16); +x_18 = l_Bool_toLBool(x_17); +x_19 = lean_box(x_18); +lean_ctor_set(x_14, 0, x_19); +return x_14; +} +else +{ +lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; lean_object* x_24; lean_object* x_25; +x_20 = lean_ctor_get(x_14, 0); +x_21 = lean_ctor_get(x_14, 1); +lean_inc(x_21); +lean_inc(x_20); +lean_dec(x_14); +x_22 = lean_unbox(x_20); +lean_dec(x_20); +x_23 = l_Bool_toLBool(x_22); +x_24 = lean_box(x_23); +x_25 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_25, 0, x_24); +lean_ctor_set(x_25, 1, x_21); +return x_25; +} +} +else +{ +uint8_t x_26; +x_26 = !lean_is_exclusive(x_14); +if (x_26 == 0) +{ +return x_14; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_14, 0); +x_28 = lean_ctor_get(x_14, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_14); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; +} +} +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_30 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7___closed__1; +x_31 = lean_name_mk_string(x_3, x_30); +x_32 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +lean_inc(x_31); +x_33 = l_Lean_Name_append___main(x_32, x_31); +x_34 = l_Lean_Meta_tracer; +x_35 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_4, x_34, x_33); +lean_inc(x_9); +x_36 = lean_apply_2(x_35, x_9, x_10); +if (lean_obj_tag(x_36) == 0) +{ +lean_object* x_37; uint8_t x_38; +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +x_38 = lean_unbox(x_37); +lean_dec(x_37); +if (x_38 == 0) +{ +lean_object* x_39; lean_object* x_40; +lean_dec(x_31); +lean_dec(x_6); +lean_dec(x_5); +x_39 = lean_ctor_get(x_36, 1); +lean_inc(x_39); +lean_dec(x_36); +x_40 = l_Lean_Meta_isExprDefEqAux(x_2, x_8, x_9, x_39); +if (lean_obj_tag(x_40) == 0) +{ +uint8_t x_41; +x_41 = !lean_is_exclusive(x_40); +if (x_41 == 0) +{ +lean_object* x_42; uint8_t x_43; uint8_t x_44; lean_object* x_45; +x_42 = lean_ctor_get(x_40, 0); +x_43 = lean_unbox(x_42); +lean_dec(x_42); +x_44 = l_Bool_toLBool(x_43); +x_45 = lean_box(x_44); +lean_ctor_set(x_40, 0, x_45); +return x_40; +} +else +{ +lean_object* x_46; lean_object* x_47; uint8_t x_48; uint8_t x_49; lean_object* x_50; lean_object* x_51; +x_46 = lean_ctor_get(x_40, 0); +x_47 = lean_ctor_get(x_40, 1); +lean_inc(x_47); +lean_inc(x_46); +lean_dec(x_40); +x_48 = lean_unbox(x_46); +lean_dec(x_46); +x_49 = l_Bool_toLBool(x_48); +x_50 = lean_box(x_49); +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_50); +lean_ctor_set(x_51, 1, x_47); +return x_51; +} +} +else +{ +uint8_t x_52; +x_52 = !lean_is_exclusive(x_40); +if (x_52 == 0) +{ +return x_40; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_53 = lean_ctor_get(x_40, 0); +x_54 = lean_ctor_get(x_40, 1); +lean_inc(x_54); +lean_inc(x_53); +lean_dec(x_40); +x_55 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_55, 0, x_53); +lean_ctor_set(x_55, 1, x_54); +return x_55; +} +} +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_56 = lean_ctor_get(x_36, 1); +lean_inc(x_56); +lean_dec(x_36); +x_57 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_57, 0, x_5); +x_58 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_31, x_57); +lean_inc(x_9); +x_59 = lean_apply_2(x_58, x_9, x_56); +if (lean_obj_tag(x_59) == 0) +{ +lean_object* x_60; lean_object* x_61; +x_60 = lean_ctor_get(x_59, 1); +lean_inc(x_60); +lean_dec(x_59); +x_61 = l_Lean_Meta_isExprDefEqAux(x_2, x_8, x_9, x_60); +if (lean_obj_tag(x_61) == 0) +{ +uint8_t x_62; +x_62 = !lean_is_exclusive(x_61); +if (x_62 == 0) +{ +lean_object* x_63; uint8_t x_64; uint8_t x_65; lean_object* x_66; +x_63 = lean_ctor_get(x_61, 0); +x_64 = lean_unbox(x_63); +lean_dec(x_63); +x_65 = l_Bool_toLBool(x_64); +x_66 = lean_box(x_65); +lean_ctor_set(x_61, 0, x_66); +return x_61; +} +else +{ +lean_object* x_67; lean_object* x_68; uint8_t x_69; uint8_t x_70; lean_object* x_71; lean_object* x_72; +x_67 = lean_ctor_get(x_61, 0); +x_68 = lean_ctor_get(x_61, 1); +lean_inc(x_68); +lean_inc(x_67); +lean_dec(x_61); +x_69 = lean_unbox(x_67); +lean_dec(x_67); +x_70 = l_Bool_toLBool(x_69); +x_71 = lean_box(x_70); +x_72 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_72, 0, x_71); +lean_ctor_set(x_72, 1, x_68); +return x_72; +} +} +else +{ +uint8_t x_73; +x_73 = !lean_is_exclusive(x_61); +if (x_73 == 0) +{ +return x_61; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_61, 0); +x_75 = lean_ctor_get(x_61, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_61); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_59); +if (x_77 == 0) +{ +return x_59; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_59, 0); +x_79 = lean_ctor_get(x_59, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_59); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_31); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_81 = !lean_is_exclusive(x_36); +if (x_81 == 0) +{ +return x_36; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_36, 0); +x_83 = lean_ctor_get(x_36, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_36); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +} +else +{ +lean_object* x_85; uint8_t x_86; +lean_dec(x_5); +lean_dec(x_2); +x_85 = lean_ctor_get(x_10, 4); +lean_inc(x_85); +x_86 = lean_ctor_get_uint8(x_85, sizeof(void*)*1); +lean_dec(x_85); +if (x_86 == 0) +{ +lean_object* x_87; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +x_87 = l_Lean_Meta_isExprDefEqAux(x_1, x_8, x_9, x_10); +if (lean_obj_tag(x_87) == 0) +{ +uint8_t x_88; +x_88 = !lean_is_exclusive(x_87); +if (x_88 == 0) +{ +lean_object* x_89; uint8_t x_90; uint8_t x_91; lean_object* x_92; +x_89 = lean_ctor_get(x_87, 0); +x_90 = lean_unbox(x_89); +lean_dec(x_89); +x_91 = l_Bool_toLBool(x_90); +x_92 = lean_box(x_91); +lean_ctor_set(x_87, 0, x_92); +return x_87; +} +else +{ +lean_object* x_93; lean_object* x_94; uint8_t x_95; uint8_t x_96; lean_object* x_97; lean_object* x_98; +x_93 = lean_ctor_get(x_87, 0); +x_94 = lean_ctor_get(x_87, 1); +lean_inc(x_94); +lean_inc(x_93); +lean_dec(x_87); +x_95 = lean_unbox(x_93); +lean_dec(x_93); +x_96 = l_Bool_toLBool(x_95); +x_97 = lean_box(x_96); +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_97); +lean_ctor_set(x_98, 1, x_94); +return x_98; +} +} +else +{ +uint8_t x_99; +x_99 = !lean_is_exclusive(x_87); +if (x_99 == 0) +{ +return x_87; +} +else +{ +lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_100 = lean_ctor_get(x_87, 0); +x_101 = lean_ctor_get(x_87, 1); +lean_inc(x_101); +lean_inc(x_100); +lean_dec(x_87); +x_102 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_102, 0, x_100); +lean_ctor_set(x_102, 1, x_101); +return x_102; +} +} +} +else +{ +lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; +x_103 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1; +x_104 = lean_name_mk_string(x_3, x_103); +x_105 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +lean_inc(x_104); +x_106 = l_Lean_Name_append___main(x_105, x_104); +x_107 = l_Lean_Meta_tracer; +x_108 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_4, x_107, x_106); +lean_inc(x_9); +x_109 = lean_apply_2(x_108, x_9, x_10); +if (lean_obj_tag(x_109) == 0) +{ +lean_object* x_110; uint8_t x_111; +x_110 = lean_ctor_get(x_109, 0); +lean_inc(x_110); +x_111 = lean_unbox(x_110); +lean_dec(x_110); +if (x_111 == 0) +{ +lean_object* x_112; lean_object* x_113; +lean_dec(x_104); +lean_dec(x_7); +lean_dec(x_6); +x_112 = lean_ctor_get(x_109, 1); +lean_inc(x_112); +lean_dec(x_109); +x_113 = l_Lean_Meta_isExprDefEqAux(x_1, x_8, x_9, x_112); +if (lean_obj_tag(x_113) == 0) +{ +uint8_t x_114; +x_114 = !lean_is_exclusive(x_113); +if (x_114 == 0) +{ +lean_object* x_115; uint8_t x_116; uint8_t x_117; lean_object* x_118; +x_115 = lean_ctor_get(x_113, 0); +x_116 = lean_unbox(x_115); +lean_dec(x_115); +x_117 = l_Bool_toLBool(x_116); +x_118 = lean_box(x_117); +lean_ctor_set(x_113, 0, x_118); +return x_113; +} +else +{ +lean_object* x_119; lean_object* x_120; uint8_t x_121; uint8_t x_122; lean_object* x_123; lean_object* x_124; +x_119 = lean_ctor_get(x_113, 0); +x_120 = lean_ctor_get(x_113, 1); +lean_inc(x_120); +lean_inc(x_119); +lean_dec(x_113); +x_121 = lean_unbox(x_119); +lean_dec(x_119); +x_122 = l_Bool_toLBool(x_121); +x_123 = lean_box(x_122); +x_124 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_124, 0, x_123); +lean_ctor_set(x_124, 1, x_120); +return x_124; +} +} +else +{ +uint8_t x_125; +x_125 = !lean_is_exclusive(x_113); +if (x_125 == 0) +{ +return x_113; +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_113, 0); +x_127 = lean_ctor_get(x_113, 1); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_113); +x_128 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_128, 0, x_126); +lean_ctor_set(x_128, 1, x_127); +return x_128; +} +} +} +else +{ +lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; +x_129 = lean_ctor_get(x_109, 1); +lean_inc(x_129); +lean_dec(x_109); +x_130 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_130, 0, x_7); +x_131 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_104, x_130); +lean_inc(x_9); +x_132 = lean_apply_2(x_131, x_9, x_129); +if (lean_obj_tag(x_132) == 0) +{ +lean_object* x_133; lean_object* x_134; +x_133 = lean_ctor_get(x_132, 1); +lean_inc(x_133); +lean_dec(x_132); +x_134 = l_Lean_Meta_isExprDefEqAux(x_1, x_8, x_9, x_133); +if (lean_obj_tag(x_134) == 0) +{ +uint8_t x_135; +x_135 = !lean_is_exclusive(x_134); +if (x_135 == 0) +{ +lean_object* x_136; uint8_t x_137; uint8_t x_138; lean_object* x_139; +x_136 = lean_ctor_get(x_134, 0); +x_137 = lean_unbox(x_136); +lean_dec(x_136); +x_138 = l_Bool_toLBool(x_137); +x_139 = lean_box(x_138); +lean_ctor_set(x_134, 0, x_139); +return x_134; +} +else +{ +lean_object* x_140; lean_object* x_141; uint8_t x_142; uint8_t x_143; lean_object* x_144; lean_object* x_145; +x_140 = lean_ctor_get(x_134, 0); +x_141 = lean_ctor_get(x_134, 1); +lean_inc(x_141); +lean_inc(x_140); +lean_dec(x_134); +x_142 = lean_unbox(x_140); +lean_dec(x_140); +x_143 = l_Bool_toLBool(x_142); +x_144 = lean_box(x_143); +x_145 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_145, 0, x_144); +lean_ctor_set(x_145, 1, x_141); +return x_145; +} +} +else +{ +uint8_t x_146; +x_146 = !lean_is_exclusive(x_134); +if (x_146 == 0) +{ +return x_134; +} +else +{ +lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_147 = lean_ctor_get(x_134, 0); +x_148 = lean_ctor_get(x_134, 1); +lean_inc(x_148); +lean_inc(x_147); +lean_dec(x_134); +x_149 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_149, 0, x_147); +lean_ctor_set(x_149, 1, x_148); +return x_149; +} +} +} +else +{ +uint8_t x_150; +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_1); +x_150 = !lean_is_exclusive(x_132); +if (x_150 == 0) +{ +return x_132; +} +else +{ +lean_object* x_151; lean_object* x_152; lean_object* x_153; +x_151 = lean_ctor_get(x_132, 0); +x_152 = lean_ctor_get(x_132, 1); +lean_inc(x_152); +lean_inc(x_151); +lean_dec(x_132); +x_153 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_153, 0, x_151); +lean_ctor_set(x_153, 1, x_152); +return x_153; +} +} +} +} +else +{ +uint8_t x_154; +lean_dec(x_104); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_1); +x_154 = !lean_is_exclusive(x_109); +if (x_154 == 0) +{ +return x_109; +} +else +{ +lean_object* x_155; lean_object* x_156; lean_object* x_157; +x_155 = lean_ctor_get(x_109, 0); +x_156 = lean_ctor_get(x_109, 1); +lean_inc(x_156); +lean_inc(x_155); +lean_dec(x_109); +x_157 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_157, 0, x_155); +lean_ctor_set(x_157, 1, x_156); +return x_157; +} +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11) { +_start: +{ +uint8_t x_12; +x_12 = l___private_Init_Lean_Meta_ExprDefEq_20__sameHeadSymbol(x_9, x_1); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_13 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1; +lean_inc(x_2); +x_14 = lean_name_mk_string(x_2, x_13); +lean_inc(x_3); +lean_inc(x_14); +x_15 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__4___boxed), 5, 2); +lean_closure_set(x_15, 0, x_14); +lean_closure_set(x_15, 1, x_3); +x_16 = l_Lean_Meta_tracer___closed__3; +lean_inc(x_4); +x_17 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_17, 0, x_4); +lean_closure_set(x_17, 1, lean_box(0)); +lean_closure_set(x_17, 2, lean_box(0)); +lean_closure_set(x_17, 3, x_16); +lean_closure_set(x_17, 4, x_15); +lean_inc(x_6); +lean_inc(x_5); +x_18 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__5___boxed), 6, 3); +lean_closure_set(x_18, 0, x_5); +lean_closure_set(x_18, 1, x_6); +lean_closure_set(x_18, 2, x_14); +lean_inc(x_4); +x_19 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_19, 0, x_4); +lean_closure_set(x_19, 1, lean_box(0)); +lean_closure_set(x_19, 2, lean_box(0)); +lean_closure_set(x_19, 3, x_17); +lean_closure_set(x_19, 4, x_18); +lean_inc(x_1); +lean_inc(x_9); +x_20 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__6___boxed), 5, 2); +lean_closure_set(x_20, 0, x_9); +lean_closure_set(x_20, 1, x_1); +x_21 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_21, 0, x_4); +lean_closure_set(x_21, 1, lean_box(0)); +lean_closure_set(x_21, 2, lean_box(0)); +lean_closure_set(x_21, 3, x_19); +lean_closure_set(x_21, 4, x_20); +x_22 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__10), 10, 7); +lean_closure_set(x_22, 0, x_7); +lean_closure_set(x_22, 1, x_9); +lean_closure_set(x_22, 2, x_2); +lean_closure_set(x_22, 3, x_3); +lean_closure_set(x_22, 4, x_5); +lean_closure_set(x_22, 5, x_6); +lean_closure_set(x_22, 6, x_8); +x_23 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_21, x_22, x_10, x_11); +return x_23; +} +else +{ +lean_object* x_24; uint8_t x_25; +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +x_24 = lean_ctor_get(x_11, 4); +lean_inc(x_24); +x_25 = lean_ctor_get_uint8(x_24, sizeof(void*)*1); +lean_dec(x_24); +if (x_25 == 0) +{ +lean_object* x_26; +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_26 = l_Lean_Meta_isExprDefEqAux(x_9, x_1, x_10, x_11); +if (lean_obj_tag(x_26) == 0) +{ +uint8_t x_27; +x_27 = !lean_is_exclusive(x_26); +if (x_27 == 0) +{ +lean_object* x_28; uint8_t x_29; uint8_t x_30; lean_object* x_31; +x_28 = lean_ctor_get(x_26, 0); +x_29 = lean_unbox(x_28); +lean_dec(x_28); +x_30 = l_Bool_toLBool(x_29); +x_31 = lean_box(x_30); +lean_ctor_set(x_26, 0, x_31); +return x_26; +} +else +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; uint8_t x_35; lean_object* x_36; lean_object* x_37; +x_32 = lean_ctor_get(x_26, 0); +x_33 = lean_ctor_get(x_26, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_26); +x_34 = lean_unbox(x_32); +lean_dec(x_32); +x_35 = l_Bool_toLBool(x_34); +x_36 = lean_box(x_35); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_36); +lean_ctor_set(x_37, 1, x_33); +return x_37; +} +} +else +{ +uint8_t x_38; +x_38 = !lean_is_exclusive(x_26); +if (x_38 == 0) +{ +return x_26; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_26, 0); +x_40 = lean_ctor_get(x_26, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_26); +x_41 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_41, 0, x_39); +lean_ctor_set(x_41, 1, x_40); +return x_41; +} +} +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_42 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1; +x_43 = lean_name_mk_string(x_2, x_42); +x_44 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +lean_inc(x_43); +x_45 = l_Lean_Name_append___main(x_44, x_43); +x_46 = l_Lean_Meta_tracer; +x_47 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_3, x_46, x_45); +lean_inc(x_10); +x_48 = lean_apply_2(x_47, x_10, x_11); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; uint8_t x_50; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +x_50 = lean_unbox(x_49); +lean_dec(x_49); +if (x_50 == 0) +{ +lean_object* x_51; lean_object* x_52; +lean_dec(x_43); +lean_dec(x_6); +lean_dec(x_5); +x_51 = lean_ctor_get(x_48, 1); +lean_inc(x_51); +lean_dec(x_48); +x_52 = l_Lean_Meta_isExprDefEqAux(x_9, x_1, x_10, x_51); +if (lean_obj_tag(x_52) == 0) +{ +uint8_t x_53; +x_53 = !lean_is_exclusive(x_52); +if (x_53 == 0) +{ +lean_object* x_54; uint8_t x_55; uint8_t x_56; lean_object* x_57; +x_54 = lean_ctor_get(x_52, 0); +x_55 = lean_unbox(x_54); +lean_dec(x_54); +x_56 = l_Bool_toLBool(x_55); +x_57 = lean_box(x_56); +lean_ctor_set(x_52, 0, x_57); +return x_52; +} +else +{ +lean_object* x_58; lean_object* x_59; uint8_t x_60; uint8_t x_61; lean_object* x_62; lean_object* x_63; +x_58 = lean_ctor_get(x_52, 0); +x_59 = lean_ctor_get(x_52, 1); +lean_inc(x_59); +lean_inc(x_58); +lean_dec(x_52); +x_60 = lean_unbox(x_58); +lean_dec(x_58); +x_61 = l_Bool_toLBool(x_60); +x_62 = lean_box(x_61); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_59); +return x_63; +} +} +else +{ +uint8_t x_64; +x_64 = !lean_is_exclusive(x_52); +if (x_64 == 0) +{ +return x_52; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_52, 0); +x_66 = lean_ctor_get(x_52, 1); +lean_inc(x_66); +lean_inc(x_65); +lean_dec(x_52); +x_67 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_67, 0, x_65); +lean_ctor_set(x_67, 1, x_66); +return x_67; +} +} +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_68 = lean_ctor_get(x_48, 1); +lean_inc(x_68); +lean_dec(x_48); +x_69 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_69, 0, x_5); +x_70 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_43, x_69); +lean_inc(x_10); +x_71 = lean_apply_2(x_70, x_10, x_68); +if (lean_obj_tag(x_71) == 0) +{ +lean_object* x_72; lean_object* x_73; +x_72 = lean_ctor_get(x_71, 1); +lean_inc(x_72); +lean_dec(x_71); +x_73 = l_Lean_Meta_isExprDefEqAux(x_9, x_1, x_10, x_72); +if (lean_obj_tag(x_73) == 0) +{ +uint8_t x_74; +x_74 = !lean_is_exclusive(x_73); +if (x_74 == 0) +{ +lean_object* x_75; uint8_t x_76; uint8_t x_77; lean_object* x_78; +x_75 = lean_ctor_get(x_73, 0); +x_76 = lean_unbox(x_75); +lean_dec(x_75); +x_77 = l_Bool_toLBool(x_76); +x_78 = lean_box(x_77); +lean_ctor_set(x_73, 0, x_78); +return x_73; +} +else +{ +lean_object* x_79; lean_object* x_80; uint8_t x_81; uint8_t x_82; lean_object* x_83; lean_object* x_84; +x_79 = lean_ctor_get(x_73, 0); +x_80 = lean_ctor_get(x_73, 1); +lean_inc(x_80); +lean_inc(x_79); +lean_dec(x_73); +x_81 = lean_unbox(x_79); +lean_dec(x_79); +x_82 = l_Bool_toLBool(x_81); +x_83 = lean_box(x_82); +x_84 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_80); +return x_84; +} +} +else +{ +uint8_t x_85; +x_85 = !lean_is_exclusive(x_73); +if (x_85 == 0) +{ +return x_73; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_73, 0); +x_87 = lean_ctor_get(x_73, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_73); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +else +{ +uint8_t x_89; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_1); +x_89 = !lean_is_exclusive(x_71); +if (x_89 == 0) +{ +return x_71; +} +else +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_90 = lean_ctor_get(x_71, 0); +x_91 = lean_ctor_get(x_71, 1); +lean_inc(x_91); +lean_inc(x_90); +lean_dec(x_71); +x_92 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_92, 0, x_90); +lean_ctor_set(x_92, 1, x_91); +return x_92; +} +} +} +} +else +{ +uint8_t x_93; +lean_dec(x_43); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_1); +x_93 = !lean_is_exclusive(x_48); +if (x_93 == 0) +{ +return x_48; +} +else +{ +lean_object* x_94; lean_object* x_95; lean_object* x_96; +x_94 = lean_ctor_get(x_48, 0); +x_95 = lean_ctor_get(x_48, 1); +lean_inc(x_95); +lean_inc(x_94); +lean_dec(x_48); +x_96 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_96, 0, x_94); +lean_ctor_set(x_96, 1, x_95); +return x_96; +} +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_8, 4); +lean_inc(x_9); +x_10 = lean_ctor_get_uint8(x_9, sizeof(void*)*1); +lean_dec(x_9); +if (x_10 == 0) +{ +lean_object* x_11; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_11 = l_Lean_Meta_isExprDefEqAux(x_6, x_1, x_7, x_8); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); +x_14 = lean_unbox(x_13); +lean_dec(x_13); +x_15 = l_Bool_toLBool(x_14); +x_16 = lean_box(x_15); +lean_ctor_set(x_11, 0, x_16); +return x_11; +} +else +{ +lean_object* x_17; lean_object* x_18; uint8_t x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_11); +x_19 = lean_unbox(x_17); +lean_dec(x_17); +x_20 = l_Bool_toLBool(x_19); +x_21 = lean_box(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; +} +} +else +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_11); +if (x_23 == 0) +{ +return x_11; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_27 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1; +x_28 = lean_name_mk_string(x_2, x_27); +x_29 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +lean_inc(x_28); +x_30 = l_Lean_Name_append___main(x_29, x_28); +x_31 = l_Lean_Meta_tracer; +x_32 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_3, x_31, x_30); +lean_inc(x_7); +x_33 = lean_apply_2(x_32, x_7, x_8); +if (lean_obj_tag(x_33) == 0) +{ +lean_object* x_34; uint8_t x_35; +x_34 = lean_ctor_get(x_33, 0); +lean_inc(x_34); +x_35 = lean_unbox(x_34); +lean_dec(x_34); +if (x_35 == 0) +{ +lean_object* x_36; lean_object* x_37; +lean_dec(x_28); +lean_dec(x_5); +lean_dec(x_4); +x_36 = lean_ctor_get(x_33, 1); +lean_inc(x_36); +lean_dec(x_33); +x_37 = l_Lean_Meta_isExprDefEqAux(x_6, x_1, x_7, x_36); +if (lean_obj_tag(x_37) == 0) +{ +uint8_t x_38; +x_38 = !lean_is_exclusive(x_37); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; uint8_t x_41; lean_object* x_42; +x_39 = lean_ctor_get(x_37, 0); +x_40 = lean_unbox(x_39); +lean_dec(x_39); +x_41 = l_Bool_toLBool(x_40); +x_42 = lean_box(x_41); +lean_ctor_set(x_37, 0, x_42); +return x_37; +} +else +{ +lean_object* x_43; lean_object* x_44; uint8_t x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; +x_43 = lean_ctor_get(x_37, 0); +x_44 = lean_ctor_get(x_37, 1); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_37); +x_45 = lean_unbox(x_43); +lean_dec(x_43); +x_46 = l_Bool_toLBool(x_45); +x_47 = lean_box(x_46); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_47); +lean_ctor_set(x_48, 1, x_44); +return x_48; +} +} +else +{ +uint8_t x_49; +x_49 = !lean_is_exclusive(x_37); +if (x_49 == 0) +{ +return x_37; +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_50 = lean_ctor_get(x_37, 0); +x_51 = lean_ctor_get(x_37, 1); +lean_inc(x_51); +lean_inc(x_50); +lean_dec(x_37); +x_52 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_52, 0, x_50); +lean_ctor_set(x_52, 1, x_51); +return x_52; +} +} +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_53 = lean_ctor_get(x_33, 1); +lean_inc(x_53); +lean_dec(x_33); +x_54 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_54, 0, x_4); +x_55 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_5, x_28, x_54); +lean_inc(x_7); +x_56 = lean_apply_2(x_55, x_7, x_53); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; lean_object* x_58; +x_57 = lean_ctor_get(x_56, 1); +lean_inc(x_57); +lean_dec(x_56); +x_58 = l_Lean_Meta_isExprDefEqAux(x_6, x_1, x_7, x_57); +if (lean_obj_tag(x_58) == 0) +{ +uint8_t x_59; +x_59 = !lean_is_exclusive(x_58); +if (x_59 == 0) +{ +lean_object* x_60; uint8_t x_61; uint8_t x_62; lean_object* x_63; +x_60 = lean_ctor_get(x_58, 0); +x_61 = lean_unbox(x_60); +lean_dec(x_60); +x_62 = l_Bool_toLBool(x_61); +x_63 = lean_box(x_62); +lean_ctor_set(x_58, 0, x_63); +return x_58; +} +else +{ +lean_object* x_64; lean_object* x_65; uint8_t x_66; uint8_t x_67; lean_object* x_68; lean_object* x_69; +x_64 = lean_ctor_get(x_58, 0); +x_65 = lean_ctor_get(x_58, 1); +lean_inc(x_65); +lean_inc(x_64); +lean_dec(x_58); +x_66 = lean_unbox(x_64); +lean_dec(x_64); +x_67 = l_Bool_toLBool(x_66); +x_68 = lean_box(x_67); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_65); +return x_69; +} +} +else +{ +uint8_t x_70; +x_70 = !lean_is_exclusive(x_58); +if (x_70 == 0) +{ +return x_58; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_58, 0); +x_72 = lean_ctor_get(x_58, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_58); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_71); +lean_ctor_set(x_73, 1, x_72); +return x_73; +} +} +} +else +{ +uint8_t x_74; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_56); +if (x_74 == 0) +{ +return x_56; +} +else +{ +lean_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_56, 0); +x_76 = lean_ctor_get(x_56, 1); +lean_inc(x_76); +lean_inc(x_75); +lean_dec(x_56); +x_77 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +return x_77; +} +} +} +} +else +{ +uint8_t x_78; +lean_dec(x_28); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_33); +if (x_78 == 0) +{ +return x_33; +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_33, 0); +x_80 = lean_ctor_get(x_33, 1); +lean_inc(x_80); +lean_inc(x_79); +lean_dec(x_33); +x_81 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_81, 0, x_79); +lean_ctor_set(x_81, 1, x_80); +return x_81; +} +} +} +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Meta_tracer; +x_2 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_3 = l_Lean_simpleMonadTracerAdapter___rarg(x_1, x_2); +return x_3; +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__2() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("delta"); +return x_1; +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__2; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4() { +_start: +{ +lean_object* x_1; uint8_t x_2; lean_object* x_3; lean_object* x_4; +x_1 = l_EIO_Monad___closed__1; +x_2 = 2; +x_3 = lean_box(x_2); +x_4 = lean_alloc_closure((void*)(l_ReaderT_pure___rarg___boxed), 4, 3); +lean_closure_set(x_4, 0, x_1); +lean_closure_set(x_4, 1, lean_box(0)); +lean_closure_set(x_4, 2, x_3); +return x_4; +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__5() { +_start: +{ +lean_object* x_1; uint8_t x_2; lean_object* x_3; lean_object* x_4; +x_1 = l_EIO_Monad___closed__1; +x_2 = 0; +x_3 = lean_box(x_2); +x_4 = lean_alloc_closure((void*)(l_ReaderT_pure___rarg___boxed), 4, 3); +lean_closure_set(x_4, 0, x_1); +lean_closure_set(x_4, 1, lean_box(0)); +lean_closure_set(x_4, 2, x_3); +return x_4; +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__6() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +x_2 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_3 = l_Lean_Name_append___main(x_1, x_2); +return x_3; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_5 = l_Lean_Expr_getAppFn___main(x_1); +x_6 = l_Lean_Expr_getAppFn___main(x_2); +x_7 = lean_unsigned_to_nat(0u); +x_8 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_7); +x_9 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_8); +x_10 = lean_mk_array(x_8, x_9); +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_sub(x_8, x_11); +lean_dec(x_8); +lean_inc(x_1); +x_13 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_10, x_12); +x_14 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_7); +lean_inc(x_14); +x_15 = lean_mk_array(x_14, x_9); +x_16 = lean_nat_sub(x_14, x_11); +lean_dec(x_14); +lean_inc(x_2); +x_17 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_15, x_16); +lean_inc(x_5); +x_18 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs___boxed), 5, 3); +lean_closure_set(x_18, 0, x_5); +lean_closure_set(x_18, 1, x_13); +lean_closure_set(x_18, 2, x_17); +lean_inc(x_6); +lean_inc(x_5); +x_19 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__1___boxed), 5, 2); +lean_closure_set(x_19, 0, x_5); +lean_closure_set(x_19, 1, x_6); +x_20 = l_EIO_Monad___closed__1; +x_21 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); +lean_closure_set(x_21, 0, x_20); +lean_closure_set(x_21, 1, lean_box(0)); +lean_closure_set(x_21, 2, lean_box(0)); +lean_closure_set(x_21, 3, x_18); +lean_closure_set(x_21, 4, x_19); +x_22 = l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate(x_5, x_3, x_4); +lean_dec(x_5); +if (lean_obj_tag(x_22) == 0) +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_22, 0); +x_25 = lean_ctor_get(x_22, 1); +x_26 = l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate(x_6, x_3, x_25); +lean_dec(x_6); +if (lean_obj_tag(x_26) == 0) +{ +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_27; +lean_free_object(x_22); +lean_dec(x_21); +x_27 = lean_ctor_get(x_26, 0); +lean_inc(x_27); +if (lean_obj_tag(x_27) == 0) +{ +uint8_t x_28; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_28 = !lean_is_exclusive(x_26); +if (x_28 == 0) +{ +lean_object* x_29; uint8_t x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_26, 0); +lean_dec(x_29); +x_30 = 2; +x_31 = lean_box(x_30); +lean_ctor_set(x_26, 0, x_31); +return x_26; +} +else +{ +lean_object* x_32; uint8_t x_33; lean_object* x_34; lean_object* x_35; +x_32 = lean_ctor_get(x_26, 1); +lean_inc(x_32); +lean_dec(x_26); +x_33 = 2; +x_34 = lean_box(x_33); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_34); +lean_ctor_set(x_35, 1, x_32); +return x_35; +} +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_36 = lean_ctor_get(x_26, 1); +lean_inc(x_36); +lean_dec(x_26); +x_37 = lean_ctor_get(x_27, 0); +lean_inc(x_37); +lean_dec(x_27); +x_38 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_39 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_40 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +x_41 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___boxed), 8, 5); +lean_closure_set(x_41, 0, x_1); +lean_closure_set(x_41, 1, x_37); +lean_closure_set(x_41, 2, x_38); +lean_closure_set(x_41, 3, x_39); +lean_closure_set(x_41, 4, x_40); +x_42 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +x_43 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_42, x_41, x_3, x_36); +return x_43; +} +} +else +{ +lean_object* x_44; +x_44 = lean_ctor_get(x_26, 0); +lean_inc(x_44); +if (lean_obj_tag(x_44) == 0) +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +lean_free_object(x_22); +lean_dec(x_21); +x_45 = lean_ctor_get(x_26, 1); +lean_inc(x_45); +lean_dec(x_26); +x_46 = lean_ctor_get(x_24, 0); +lean_inc(x_46); +lean_dec(x_24); +x_47 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_48 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_49 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +x_50 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___boxed), 8, 5); +lean_closure_set(x_50, 0, x_2); +lean_closure_set(x_50, 1, x_46); +lean_closure_set(x_50, 2, x_47); +lean_closure_set(x_50, 3, x_48); +lean_closure_set(x_50, 4, x_49); +x_51 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +x_52 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_51, x_50, x_3, x_45); +return x_52; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; lean_object* x_58; uint8_t x_71; lean_object* x_72; lean_object* x_257; lean_object* x_258; uint8_t x_259; +x_53 = lean_ctor_get(x_26, 1); +lean_inc(x_53); +if (lean_is_exclusive(x_26)) { + lean_ctor_release(x_26, 0); + lean_ctor_release(x_26, 1); + x_54 = x_26; +} else { + lean_dec_ref(x_26); + x_54 = lean_box(0); +} +x_55 = lean_ctor_get(x_24, 0); +lean_inc(x_55); +lean_dec(x_24); +x_56 = lean_ctor_get(x_44, 0); +lean_inc(x_56); +lean_dec(x_44); +x_257 = l_Lean_ConstantInfo_name(x_55); +x_258 = l_Lean_ConstantInfo_name(x_56); +x_259 = lean_name_eq(x_257, x_258); +if (x_259 == 0) +{ +lean_object* x_260; uint8_t x_261; uint8_t x_262; uint8_t x_263; lean_object* x_264; +lean_dec(x_54); +lean_free_object(x_22); +lean_dec(x_21); +x_260 = lean_ctor_get(x_3, 0); +lean_inc(x_260); +x_261 = lean_ctor_get_uint8(x_260, sizeof(void*)*1 + 5); +lean_dec(x_260); +x_262 = 2; +x_263 = l_Lean_Meta_TransparencyMode_beq(x_261, x_262); +if (x_263 == 0) +{ +lean_object* x_274; uint8_t x_275; lean_object* x_276; lean_object* x_287; lean_object* x_299; uint8_t x_338; lean_object* x_339; +x_274 = lean_ctor_get(x_53, 0); +lean_inc(x_274); +lean_inc(x_257); +lean_inc(x_274); +x_275 = l_Lean_isReducible(x_274, x_257); +lean_inc(x_258); +x_338 = l_Lean_isReducible(x_274, x_258); +if (x_275 == 0) +{ +lean_object* x_376; +x_376 = lean_box(0); +x_339 = x_376; +goto block_375; +} +else +{ +if (x_338 == 0) +{ +uint8_t x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; +x_377 = l_Lean_Expr_hasExprMVar(x_1); +x_378 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_379 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_380 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_257); +lean_inc(x_2); +x_381 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_381, 0, x_2); +lean_closure_set(x_381, 1, x_378); +lean_closure_set(x_381, 2, x_379); +lean_closure_set(x_381, 3, x_257); +lean_closure_set(x_381, 4, x_380); +if (x_377 == 0) +{ +uint8_t x_390; +x_390 = l_Lean_Expr_hasExprMVar(x_2); +if (x_390 == 0) +{ +lean_object* x_391; lean_object* x_392; uint8_t x_393; +x_391 = l_Lean_ConstantInfo_hints(x_55); +lean_dec(x_55); +x_392 = l_Lean_ConstantInfo_hints(x_56); +lean_dec(x_56); +x_393 = l_Lean_ReducibilityHints_lt(x_391, x_392); +if (x_393 == 0) +{ +uint8_t x_394; +x_394 = l_Lean_ReducibilityHints_lt(x_392, x_391); +lean_dec(x_391); +lean_dec(x_392); +if (x_394 == 0) +{ +lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; lean_object* x_400; +lean_inc(x_258); +lean_inc(x_1); +x_395 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_395, 0, x_1); +lean_closure_set(x_395, 1, x_378); +lean_closure_set(x_395, 2, x_379); +lean_closure_set(x_395, 3, x_258); +lean_closure_set(x_395, 4, x_380); +x_396 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_397 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_397, 0, x_2); +lean_closure_set(x_397, 1, x_396); +lean_closure_set(x_397, 2, x_395); +lean_inc(x_1); +x_398 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_398, 0, x_2); +lean_closure_set(x_398, 1, x_378); +lean_closure_set(x_398, 2, x_379); +lean_closure_set(x_398, 3, x_20); +lean_closure_set(x_398, 4, x_257); +lean_closure_set(x_398, 5, x_380); +lean_closure_set(x_398, 6, x_1); +lean_closure_set(x_398, 7, x_258); +lean_inc(x_1); +x_399 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_399, 0, x_1); +lean_closure_set(x_399, 1, x_397); +lean_closure_set(x_399, 2, x_398); +x_400 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_399, x_381, x_3, x_53); +return x_400; +} +else +{ +lean_object* x_401; lean_object* x_402; lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; +lean_inc(x_258); +lean_inc(x_1); +x_401 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_401, 0, x_1); +lean_closure_set(x_401, 1, x_378); +lean_closure_set(x_401, 2, x_379); +lean_closure_set(x_401, 3, x_258); +lean_closure_set(x_401, 4, x_380); +x_402 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_401); +lean_inc(x_2); +x_403 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_403, 0, x_2); +lean_closure_set(x_403, 1, x_402); +lean_closure_set(x_403, 2, x_401); +lean_inc(x_1); +lean_inc(x_2); +x_404 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_404, 0, x_2); +lean_closure_set(x_404, 1, x_378); +lean_closure_set(x_404, 2, x_379); +lean_closure_set(x_404, 3, x_20); +lean_closure_set(x_404, 4, x_257); +lean_closure_set(x_404, 5, x_380); +lean_closure_set(x_404, 6, x_1); +lean_closure_set(x_404, 7, x_258); +lean_inc(x_1); +x_405 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_405, 0, x_1); +lean_closure_set(x_405, 1, x_403); +lean_closure_set(x_405, 2, x_404); +x_406 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_406, 0, x_2); +lean_closure_set(x_406, 1, x_405); +lean_closure_set(x_406, 2, x_401); +x_407 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_406, x_381, x_3, x_53); +return x_407; +} +} +else +{ +lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; lean_object* x_412; lean_object* x_413; lean_object* x_414; +lean_dec(x_392); +lean_dec(x_391); +lean_inc(x_258); +lean_inc(x_1); +x_408 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_408, 0, x_1); +lean_closure_set(x_408, 1, x_378); +lean_closure_set(x_408, 2, x_379); +lean_closure_set(x_408, 3, x_258); +lean_closure_set(x_408, 4, x_380); +x_409 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_410 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_410, 0, x_2); +lean_closure_set(x_410, 1, x_409); +lean_closure_set(x_410, 2, x_408); +lean_inc(x_1); +x_411 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_411, 0, x_2); +lean_closure_set(x_411, 1, x_378); +lean_closure_set(x_411, 2, x_379); +lean_closure_set(x_411, 3, x_20); +lean_closure_set(x_411, 4, x_257); +lean_closure_set(x_411, 5, x_380); +lean_closure_set(x_411, 6, x_1); +lean_closure_set(x_411, 7, x_258); +lean_inc(x_1); +x_412 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_412, 0, x_1); +lean_closure_set(x_412, 1, x_410); +lean_closure_set(x_412, 2, x_411); +lean_inc(x_381); +lean_inc(x_1); +x_413 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_413, 0, x_1); +lean_closure_set(x_413, 1, x_412); +lean_closure_set(x_413, 2, x_381); +x_414 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_413, x_381, x_3, x_53); +return x_414; +} +} +else +{ +lean_object* x_415; +lean_dec(x_56); +lean_dec(x_55); +x_415 = lean_box(0); +x_382 = x_415; +goto block_389; +} +} +else +{ +lean_object* x_416; +lean_dec(x_56); +lean_dec(x_55); +x_416 = lean_box(0); +x_382 = x_416; +goto block_389; +} +block_389: +{ +lean_object* x_383; lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; +lean_dec(x_382); +lean_inc(x_258); +lean_inc(x_1); +x_383 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_383, 0, x_1); +lean_closure_set(x_383, 1, x_378); +lean_closure_set(x_383, 2, x_379); +lean_closure_set(x_383, 3, x_258); +lean_closure_set(x_383, 4, x_380); +x_384 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_385 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_385, 0, x_2); +lean_closure_set(x_385, 1, x_384); +lean_closure_set(x_385, 2, x_383); +lean_inc(x_1); +x_386 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_386, 0, x_2); +lean_closure_set(x_386, 1, x_378); +lean_closure_set(x_386, 2, x_379); +lean_closure_set(x_386, 3, x_20); +lean_closure_set(x_386, 4, x_257); +lean_closure_set(x_386, 5, x_380); +lean_closure_set(x_386, 6, x_1); +lean_closure_set(x_386, 7, x_258); +lean_inc(x_1); +x_387 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_387, 0, x_1); +lean_closure_set(x_387, 1, x_385); +lean_closure_set(x_387, 2, x_386); +x_388 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_387, x_381, x_3, x_53); +return x_388; +} +} +else +{ +lean_object* x_417; +x_417 = lean_box(0); +x_339 = x_417; +goto block_375; +} +} +block_286: +{ +lean_object* x_277; lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; +lean_dec(x_276); +x_277 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_278 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_279 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_258); +lean_inc(x_1); +x_280 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_280, 0, x_1); +lean_closure_set(x_280, 1, x_277); +lean_closure_set(x_280, 2, x_278); +lean_closure_set(x_280, 3, x_258); +lean_closure_set(x_280, 4, x_279); +x_281 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_280); +lean_inc(x_2); +x_282 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_282, 0, x_2); +lean_closure_set(x_282, 1, x_281); +lean_closure_set(x_282, 2, x_280); +lean_inc(x_1); +lean_inc(x_2); +x_283 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_283, 0, x_2); +lean_closure_set(x_283, 1, x_277); +lean_closure_set(x_283, 2, x_278); +lean_closure_set(x_283, 3, x_20); +lean_closure_set(x_283, 4, x_257); +lean_closure_set(x_283, 5, x_279); +lean_closure_set(x_283, 6, x_1); +lean_closure_set(x_283, 7, x_258); +x_284 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_284, 0, x_1); +lean_closure_set(x_284, 1, x_282); +lean_closure_set(x_284, 2, x_283); +x_285 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_284, x_280, x_3, x_53); +return x_285; +} +block_298: +{ +lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; lean_object* x_297; +lean_dec(x_287); +x_288 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_289 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_290 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_258); +lean_inc(x_1); +x_291 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_291, 0, x_1); +lean_closure_set(x_291, 1, x_288); +lean_closure_set(x_291, 2, x_289); +lean_closure_set(x_291, 3, x_258); +lean_closure_set(x_291, 4, x_290); +x_292 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_293 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_293, 0, x_2); +lean_closure_set(x_293, 1, x_292); +lean_closure_set(x_293, 2, x_291); +lean_inc(x_1); +lean_inc(x_257); +lean_inc(x_2); +x_294 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_294, 0, x_2); +lean_closure_set(x_294, 1, x_288); +lean_closure_set(x_294, 2, x_289); +lean_closure_set(x_294, 3, x_20); +lean_closure_set(x_294, 4, x_257); +lean_closure_set(x_294, 5, x_290); +lean_closure_set(x_294, 6, x_1); +lean_closure_set(x_294, 7, x_258); +lean_inc(x_1); +x_295 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_295, 0, x_1); +lean_closure_set(x_295, 1, x_293); +lean_closure_set(x_295, 2, x_294); +x_296 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_296, 0, x_2); +lean_closure_set(x_296, 1, x_288); +lean_closure_set(x_296, 2, x_289); +lean_closure_set(x_296, 3, x_257); +lean_closure_set(x_296, 4, x_290); +x_297 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_295, x_296, x_3, x_53); +return x_297; +} +block_337: +{ +uint8_t x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; +lean_dec(x_299); +x_300 = l_Lean_Expr_hasExprMVar(x_1); +x_301 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_302 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_303 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_258); +lean_inc(x_1); +x_304 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_304, 0, x_1); +lean_closure_set(x_304, 1, x_301); +lean_closure_set(x_304, 2, x_302); +lean_closure_set(x_304, 3, x_258); +lean_closure_set(x_304, 4, x_303); +if (x_300 == 0) +{ +uint8_t x_312; +x_312 = l_Lean_Expr_hasExprMVar(x_2); +if (x_312 == 0) +{ +lean_object* x_313; lean_object* x_314; uint8_t x_315; +x_313 = l_Lean_ConstantInfo_hints(x_55); +lean_dec(x_55); +x_314 = l_Lean_ConstantInfo_hints(x_56); +lean_dec(x_56); +x_315 = l_Lean_ReducibilityHints_lt(x_313, x_314); +if (x_315 == 0) +{ +uint8_t x_316; +x_316 = l_Lean_ReducibilityHints_lt(x_314, x_313); +lean_dec(x_313); +lean_dec(x_314); +if (x_316 == 0) +{ +lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; lean_object* x_321; +x_317 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_304); +lean_inc(x_2); +x_318 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_318, 0, x_2); +lean_closure_set(x_318, 1, x_317); +lean_closure_set(x_318, 2, x_304); +lean_inc(x_1); +lean_inc(x_2); +x_319 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_319, 0, x_2); +lean_closure_set(x_319, 1, x_301); +lean_closure_set(x_319, 2, x_302); +lean_closure_set(x_319, 3, x_20); +lean_closure_set(x_319, 4, x_257); +lean_closure_set(x_319, 5, x_303); +lean_closure_set(x_319, 6, x_1); +lean_closure_set(x_319, 7, x_258); +x_320 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_320, 0, x_1); +lean_closure_set(x_320, 1, x_318); +lean_closure_set(x_320, 2, x_319); +x_321 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_320, x_304, x_3, x_53); +return x_321; +} +else +{ +lean_object* x_322; lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_object* x_327; +x_322 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_304); +lean_inc(x_2); +x_323 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_323, 0, x_2); +lean_closure_set(x_323, 1, x_322); +lean_closure_set(x_323, 2, x_304); +lean_inc(x_1); +lean_inc(x_2); +x_324 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_324, 0, x_2); +lean_closure_set(x_324, 1, x_301); +lean_closure_set(x_324, 2, x_302); +lean_closure_set(x_324, 3, x_20); +lean_closure_set(x_324, 4, x_257); +lean_closure_set(x_324, 5, x_303); +lean_closure_set(x_324, 6, x_1); +lean_closure_set(x_324, 7, x_258); +x_325 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_325, 0, x_1); +lean_closure_set(x_325, 1, x_323); +lean_closure_set(x_325, 2, x_324); +lean_inc(x_304); +lean_inc(x_2); +x_326 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_326, 0, x_2); +lean_closure_set(x_326, 1, x_325); +lean_closure_set(x_326, 2, x_304); +x_327 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_326, x_304, x_3, x_53); +return x_327; +} +} +else +{ +lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; +lean_dec(x_314); +lean_dec(x_313); +x_328 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_304); +lean_inc(x_2); +x_329 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_329, 0, x_2); +lean_closure_set(x_329, 1, x_328); +lean_closure_set(x_329, 2, x_304); +lean_inc(x_1); +lean_inc(x_257); +lean_inc(x_2); +x_330 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_330, 0, x_2); +lean_closure_set(x_330, 1, x_301); +lean_closure_set(x_330, 2, x_302); +lean_closure_set(x_330, 3, x_20); +lean_closure_set(x_330, 4, x_257); +lean_closure_set(x_330, 5, x_303); +lean_closure_set(x_330, 6, x_1); +lean_closure_set(x_330, 7, x_258); +lean_inc(x_1); +x_331 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_331, 0, x_1); +lean_closure_set(x_331, 1, x_329); +lean_closure_set(x_331, 2, x_330); +lean_inc(x_2); +x_332 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_332, 0, x_2); +lean_closure_set(x_332, 1, x_301); +lean_closure_set(x_332, 2, x_302); +lean_closure_set(x_332, 3, x_257); +lean_closure_set(x_332, 4, x_303); +x_333 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_333, 0, x_1); +lean_closure_set(x_333, 1, x_331); +lean_closure_set(x_333, 2, x_332); +x_334 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_333, x_304, x_3, x_53); +return x_334; +} +} +else +{ +lean_object* x_335; +lean_dec(x_56); +lean_dec(x_55); +x_335 = lean_box(0); +x_305 = x_335; +goto block_311; +} +} +else +{ +lean_object* x_336; +lean_dec(x_56); +lean_dec(x_55); +x_336 = lean_box(0); +x_305 = x_336; +goto block_311; +} +block_311: +{ +lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; +lean_dec(x_305); +x_306 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_304); +lean_inc(x_2); +x_307 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_307, 0, x_2); +lean_closure_set(x_307, 1, x_306); +lean_closure_set(x_307, 2, x_304); +lean_inc(x_1); +lean_inc(x_2); +x_308 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_308, 0, x_2); +lean_closure_set(x_308, 1, x_301); +lean_closure_set(x_308, 2, x_302); +lean_closure_set(x_308, 3, x_20); +lean_closure_set(x_308, 4, x_257); +lean_closure_set(x_308, 5, x_303); +lean_closure_set(x_308, 6, x_1); +lean_closure_set(x_308, 7, x_258); +x_309 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_309, 0, x_1); +lean_closure_set(x_309, 1, x_307); +lean_closure_set(x_309, 2, x_308); +x_310 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_309, x_304, x_3, x_53); +return x_310; +} +} +block_375: +{ +lean_dec(x_339); +if (x_275 == 0) +{ +if (x_338 == 0) +{ +uint8_t x_340; +x_340 = l_Lean_Expr_hasExprMVar(x_1); +if (x_340 == 0) +{ +uint8_t x_341; +x_341 = l_Lean_Expr_hasExprMVar(x_2); +if (x_341 == 0) +{ +lean_object* x_342; lean_object* x_343; uint8_t x_344; +x_342 = l_Lean_ConstantInfo_hints(x_55); +lean_dec(x_55); +x_343 = l_Lean_ConstantInfo_hints(x_56); +lean_dec(x_56); +x_344 = l_Lean_ReducibilityHints_lt(x_342, x_343); +if (x_344 == 0) +{ +uint8_t x_345; +x_345 = l_Lean_ReducibilityHints_lt(x_343, x_342); +lean_dec(x_342); +lean_dec(x_343); +if (x_345 == 0) +{ +lean_object* x_346; +x_346 = lean_box(0); +x_264 = x_346; +goto block_273; +} +else +{ +lean_object* x_347; +x_347 = lean_box(0); +x_276 = x_347; +goto block_286; +} +} +else +{ +lean_object* x_348; +lean_dec(x_343); +lean_dec(x_342); +x_348 = lean_box(0); +x_287 = x_348; +goto block_298; +} +} +else +{ +lean_object* x_349; +lean_dec(x_56); +lean_dec(x_55); +x_349 = lean_box(0); +x_264 = x_349; +goto block_273; +} +} +else +{ +lean_object* x_350; +lean_dec(x_56); +lean_dec(x_55); +x_350 = lean_box(0); +x_264 = x_350; +goto block_273; +} +} +else +{ +lean_object* x_351; +x_351 = lean_box(0); +x_299 = x_351; +goto block_337; +} +} +else +{ +if (x_263 == 0) +{ +uint8_t x_352; +x_352 = l_Lean_Expr_hasExprMVar(x_1); +if (x_352 == 0) +{ +uint8_t x_353; +x_353 = l_Lean_Expr_hasExprMVar(x_2); +if (x_353 == 0) +{ +lean_object* x_354; lean_object* x_355; uint8_t x_356; +x_354 = l_Lean_ConstantInfo_hints(x_55); +lean_dec(x_55); +x_355 = l_Lean_ConstantInfo_hints(x_56); +lean_dec(x_56); +x_356 = l_Lean_ReducibilityHints_lt(x_354, x_355); +if (x_356 == 0) +{ +uint8_t x_357; +x_357 = l_Lean_ReducibilityHints_lt(x_355, x_354); +lean_dec(x_354); +lean_dec(x_355); +if (x_357 == 0) +{ +lean_object* x_358; +x_358 = lean_box(0); +x_264 = x_358; +goto block_273; +} +else +{ +lean_object* x_359; +x_359 = lean_box(0); +x_276 = x_359; +goto block_286; +} +} +else +{ +lean_object* x_360; +lean_dec(x_355); +lean_dec(x_354); +x_360 = lean_box(0); +x_287 = x_360; +goto block_298; +} +} +else +{ +lean_object* x_361; +lean_dec(x_56); +lean_dec(x_55); +x_361 = lean_box(0); +x_264 = x_361; +goto block_273; +} +} +else +{ +lean_object* x_362; +lean_dec(x_56); +lean_dec(x_55); +x_362 = lean_box(0); +x_264 = x_362; +goto block_273; +} +} +else +{ +if (x_338 == 0) +{ +uint8_t x_363; +x_363 = l_Lean_Expr_hasExprMVar(x_1); +if (x_363 == 0) +{ +uint8_t x_364; +x_364 = l_Lean_Expr_hasExprMVar(x_2); +if (x_364 == 0) +{ +lean_object* x_365; lean_object* x_366; uint8_t x_367; +x_365 = l_Lean_ConstantInfo_hints(x_55); +lean_dec(x_55); +x_366 = l_Lean_ConstantInfo_hints(x_56); +lean_dec(x_56); +x_367 = l_Lean_ReducibilityHints_lt(x_365, x_366); +if (x_367 == 0) +{ +uint8_t x_368; +x_368 = l_Lean_ReducibilityHints_lt(x_366, x_365); +lean_dec(x_365); +lean_dec(x_366); +if (x_368 == 0) +{ +lean_object* x_369; +x_369 = lean_box(0); +x_264 = x_369; +goto block_273; +} +else +{ +lean_object* x_370; +x_370 = lean_box(0); +x_276 = x_370; +goto block_286; +} +} +else +{ +lean_object* x_371; +lean_dec(x_366); +lean_dec(x_365); +x_371 = lean_box(0); +x_287 = x_371; +goto block_298; +} +} +else +{ +lean_object* x_372; +lean_dec(x_56); +lean_dec(x_55); +x_372 = lean_box(0); +x_264 = x_372; +goto block_273; +} +} +else +{ +lean_object* x_373; +lean_dec(x_56); +lean_dec(x_55); +x_373 = lean_box(0); +x_264 = x_373; +goto block_273; +} +} +else +{ +lean_object* x_374; +x_374 = lean_box(0); +x_299 = x_374; +goto block_337; +} +} +} +} +} +else +{ +uint8_t x_418; +x_418 = l_Lean_Expr_hasExprMVar(x_1); +if (x_418 == 0) +{ +uint8_t x_419; +x_419 = l_Lean_Expr_hasExprMVar(x_2); +if (x_419 == 0) +{ +lean_object* x_420; lean_object* x_421; uint8_t x_422; +x_420 = l_Lean_ConstantInfo_hints(x_55); +lean_dec(x_55); +x_421 = l_Lean_ConstantInfo_hints(x_56); +lean_dec(x_56); +x_422 = l_Lean_ReducibilityHints_lt(x_420, x_421); +if (x_422 == 0) +{ +uint8_t x_423; +x_423 = l_Lean_ReducibilityHints_lt(x_421, x_420); +lean_dec(x_420); +lean_dec(x_421); +if (x_423 == 0) +{ +lean_object* x_424; lean_object* x_425; lean_object* x_426; lean_object* x_427; lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; +x_424 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_425 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_426 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_258); +lean_inc(x_1); +x_427 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_427, 0, x_1); +lean_closure_set(x_427, 1, x_424); +lean_closure_set(x_427, 2, x_425); +lean_closure_set(x_427, 3, x_258); +lean_closure_set(x_427, 4, x_426); +x_428 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_429 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_429, 0, x_2); +lean_closure_set(x_429, 1, x_428); +lean_closure_set(x_429, 2, x_427); +lean_inc(x_1); +x_430 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_430, 0, x_2); +lean_closure_set(x_430, 1, x_424); +lean_closure_set(x_430, 2, x_425); +lean_closure_set(x_430, 3, x_20); +lean_closure_set(x_430, 4, x_257); +lean_closure_set(x_430, 5, x_426); +lean_closure_set(x_430, 6, x_1); +lean_closure_set(x_430, 7, x_258); +x_431 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_429, x_430, x_3, x_53); +return x_431; +} +else +{ +lean_object* x_432; lean_object* x_433; lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; +x_432 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_433 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_434 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_258); +lean_inc(x_1); +x_435 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_435, 0, x_1); +lean_closure_set(x_435, 1, x_432); +lean_closure_set(x_435, 2, x_433); +lean_closure_set(x_435, 3, x_258); +lean_closure_set(x_435, 4, x_434); +x_436 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_435); +lean_inc(x_2); +x_437 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_437, 0, x_2); +lean_closure_set(x_437, 1, x_436); +lean_closure_set(x_437, 2, x_435); +lean_inc(x_1); +lean_inc(x_2); +x_438 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_438, 0, x_2); +lean_closure_set(x_438, 1, x_432); +lean_closure_set(x_438, 2, x_433); +lean_closure_set(x_438, 3, x_20); +lean_closure_set(x_438, 4, x_257); +lean_closure_set(x_438, 5, x_434); +lean_closure_set(x_438, 6, x_1); +lean_closure_set(x_438, 7, x_258); +x_439 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_439, 0, x_1); +lean_closure_set(x_439, 1, x_437); +lean_closure_set(x_439, 2, x_438); +x_440 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_439, x_435, x_3, x_53); +return x_440; +} +} +else +{ +lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; +lean_dec(x_421); +lean_dec(x_420); +x_441 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_442 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_443 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_258); +lean_inc(x_1); +x_444 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_444, 0, x_1); +lean_closure_set(x_444, 1, x_441); +lean_closure_set(x_444, 2, x_442); +lean_closure_set(x_444, 3, x_258); +lean_closure_set(x_444, 4, x_443); +x_445 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_446 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_446, 0, x_2); +lean_closure_set(x_446, 1, x_445); +lean_closure_set(x_446, 2, x_444); +lean_inc(x_1); +lean_inc(x_257); +lean_inc(x_2); +x_447 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_447, 0, x_2); +lean_closure_set(x_447, 1, x_441); +lean_closure_set(x_447, 2, x_442); +lean_closure_set(x_447, 3, x_20); +lean_closure_set(x_447, 4, x_257); +lean_closure_set(x_447, 5, x_443); +lean_closure_set(x_447, 6, x_1); +lean_closure_set(x_447, 7, x_258); +lean_inc(x_1); +x_448 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_448, 0, x_1); +lean_closure_set(x_448, 1, x_446); +lean_closure_set(x_448, 2, x_447); +x_449 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_449, 0, x_2); +lean_closure_set(x_449, 1, x_441); +lean_closure_set(x_449, 2, x_442); +lean_closure_set(x_449, 3, x_257); +lean_closure_set(x_449, 4, x_443); +x_450 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_448, x_449, x_3, x_53); +return x_450; +} +} +else +{ +lean_object* x_451; +lean_dec(x_56); +lean_dec(x_55); +x_451 = lean_box(0); +x_264 = x_451; +goto block_273; +} +} +else +{ +lean_object* x_452; +lean_dec(x_56); +lean_dec(x_55); +x_452 = lean_box(0); +x_264 = x_452; +goto block_273; +} +} +block_273: +{ +lean_object* x_265; lean_object* x_266; lean_object* x_267; lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; +lean_dec(x_264); +x_265 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_266 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_267 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_258); +lean_inc(x_1); +x_268 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_268, 0, x_1); +lean_closure_set(x_268, 1, x_265); +lean_closure_set(x_268, 2, x_266); +lean_closure_set(x_268, 3, x_258); +lean_closure_set(x_268, 4, x_267); +x_269 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_270 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_270, 0, x_2); +lean_closure_set(x_270, 1, x_269); +lean_closure_set(x_270, 2, x_268); +lean_inc(x_1); +x_271 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_271, 0, x_2); +lean_closure_set(x_271, 1, x_265); +lean_closure_set(x_271, 2, x_266); +lean_closure_set(x_271, 3, x_20); +lean_closure_set(x_271, 4, x_257); +lean_closure_set(x_271, 5, x_267); +lean_closure_set(x_271, 6, x_1); +lean_closure_set(x_271, 7, x_258); +x_272 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_270, x_271, x_3, x_53); +return x_272; +} +} +else +{ +lean_dec(x_258); +lean_dec(x_257); +switch (lean_obj_tag(x_1)) { +case 4: +{ +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_21); +if (lean_obj_tag(x_2) == 4) +{ +lean_object* x_453; lean_object* x_454; lean_object* x_455; +lean_free_object(x_22); +x_453 = lean_ctor_get(x_1, 1); +lean_inc(x_453); +lean_dec(x_1); +x_454 = lean_ctor_get(x_2, 1); +lean_inc(x_454); +lean_dec(x_2); +x_455 = l_Lean_Meta_isListLevelDefEqAux___main(x_453, x_454, x_3, x_53); +lean_dec(x_3); +if (lean_obj_tag(x_455) == 0) +{ +uint8_t x_456; +x_456 = !lean_is_exclusive(x_455); +if (x_456 == 0) +{ +lean_object* x_457; uint8_t x_458; uint8_t x_459; lean_object* x_460; +x_457 = lean_ctor_get(x_455, 0); +x_458 = lean_unbox(x_457); +lean_dec(x_457); +x_459 = l_Bool_toLBool(x_458); +x_460 = lean_box(x_459); +lean_ctor_set(x_455, 0, x_460); +return x_455; +} +else +{ +lean_object* x_461; lean_object* x_462; uint8_t x_463; uint8_t x_464; lean_object* x_465; lean_object* x_466; +x_461 = lean_ctor_get(x_455, 0); +x_462 = lean_ctor_get(x_455, 1); +lean_inc(x_462); +lean_inc(x_461); +lean_dec(x_455); +x_463 = lean_unbox(x_461); +lean_dec(x_461); +x_464 = l_Bool_toLBool(x_463); +x_465 = lean_box(x_464); +x_466 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_466, 0, x_465); +lean_ctor_set(x_466, 1, x_462); +return x_466; +} +} +else +{ +uint8_t x_467; +x_467 = !lean_is_exclusive(x_455); +if (x_467 == 0) +{ +return x_455; +} +else +{ +lean_object* x_468; lean_object* x_469; lean_object* x_470; +x_468 = lean_ctor_get(x_455, 0); +x_469 = lean_ctor_get(x_455, 1); +lean_inc(x_469); +lean_inc(x_468); +lean_dec(x_455); +x_470 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_470, 0, x_468); +lean_ctor_set(x_470, 1, x_469); +return x_470; +} +} +} +else +{ +uint8_t x_471; lean_object* x_472; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_471 = 0; +x_472 = lean_box(x_471); +lean_ctor_set(x_22, 1, x_53); +lean_ctor_set(x_22, 0, x_472); +return x_22; +} +} +case 5: +{ +if (lean_obj_tag(x_2) == 5) +{ +lean_object* x_473; uint8_t x_474; +lean_free_object(x_22); +x_473 = lean_ctor_get(x_53, 4); +lean_inc(x_473); +x_474 = lean_ctor_get_uint8(x_473, sizeof(void*)*1); +lean_dec(x_473); +if (x_474 == 0) +{ +uint8_t x_475; +x_475 = 0; +x_71 = x_475; +x_72 = x_53; +goto block_256; +} +else +{ +lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; +x_476 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_477 = l_Lean_Meta_tracer; +x_478 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__6; +x_479 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_476, x_477, x_478); +lean_inc(x_3); +x_480 = lean_apply_2(x_479, x_3, x_53); +if (lean_obj_tag(x_480) == 0) +{ +lean_object* x_481; lean_object* x_482; uint8_t x_483; +x_481 = lean_ctor_get(x_480, 0); +lean_inc(x_481); +x_482 = lean_ctor_get(x_480, 1); +lean_inc(x_482); +lean_dec(x_480); +x_483 = lean_unbox(x_481); +lean_dec(x_481); +x_71 = x_483; +x_72 = x_482; +goto block_256; +} +else +{ +uint8_t x_484; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_484 = !lean_is_exclusive(x_480); +if (x_484 == 0) +{ +return x_480; +} +else +{ +lean_object* x_485; lean_object* x_486; lean_object* x_487; +x_485 = lean_ctor_get(x_480, 0); +x_486 = lean_ctor_get(x_480, 1); +lean_inc(x_486); +lean_inc(x_485); +lean_dec(x_480); +x_487 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_487, 0, x_485); +lean_ctor_set(x_487, 1, x_486); +return x_487; +} +} +} +} +else +{ +uint8_t x_488; lean_object* x_489; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_488 = 0; +x_489 = lean_box(x_488); +lean_ctor_set(x_22, 1, x_53); +lean_ctor_set(x_22, 0, x_489); +return x_22; +} +} +default: +{ +uint8_t x_490; lean_object* x_491; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_490 = 0; +x_491 = lean_box(x_490); +lean_ctor_set(x_22, 1, x_53); +lean_ctor_set(x_22, 0, x_491); +return x_22; +} +} +} +block_70: +{ +if (x_57 == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +lean_dec(x_54); +x_59 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_60 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_61 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_1); +x_62 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___boxed), 8, 5); +lean_closure_set(x_62, 0, x_1); +lean_closure_set(x_62, 1, x_56); +lean_closure_set(x_62, 2, x_59); +lean_closure_set(x_62, 3, x_60); +lean_closure_set(x_62, 4, x_61); +x_63 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__5; +lean_inc(x_2); +x_64 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_64, 0, x_2); +lean_closure_set(x_64, 1, x_63); +lean_closure_set(x_64, 2, x_62); +x_65 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__8___boxed), 9, 6); +lean_closure_set(x_65, 0, x_55); +lean_closure_set(x_65, 1, x_59); +lean_closure_set(x_65, 2, x_60); +lean_closure_set(x_65, 3, x_20); +lean_closure_set(x_65, 4, x_61); +lean_closure_set(x_65, 5, x_2); +x_66 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_64, x_65, x_3, x_58); +return x_66; +} +else +{ +uint8_t x_67; lean_object* x_68; lean_object* x_69; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_67 = 1; +x_68 = lean_box(x_67); +if (lean_is_scalar(x_54)) { + x_69 = lean_alloc_ctor(0, 2, 0); +} else { + x_69 = x_54; +} +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_58); +return x_69; +} +} +block_256: +{ +if (x_71 == 0) +{ +uint8_t x_73; +x_73 = !lean_is_exclusive(x_72); +if (x_73 == 0) +{ +lean_object* x_74; uint8_t x_75; +x_74 = lean_ctor_get(x_72, 4); +x_75 = !lean_is_exclusive(x_74); +if (x_75 == 0) +{ +uint8_t x_76; lean_object* x_77; +x_76 = 1; +lean_ctor_set_uint8(x_74, sizeof(void*)*1, x_76); +lean_inc(x_3); +x_77 = l_Lean_Meta_try(x_21, x_3, x_72); +if (lean_obj_tag(x_77) == 0) +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; uint8_t x_81; +x_78 = lean_ctor_get(x_77, 1); +lean_inc(x_78); +x_79 = lean_ctor_get(x_78, 4); +lean_inc(x_79); +x_80 = lean_ctor_get(x_77, 0); +lean_inc(x_80); +lean_dec(x_77); +x_81 = !lean_is_exclusive(x_78); +if (x_81 == 0) +{ +lean_object* x_82; uint8_t x_83; +x_82 = lean_ctor_get(x_78, 4); +lean_dec(x_82); +x_83 = !lean_is_exclusive(x_79); +if (x_83 == 0) +{ +uint8_t x_84; uint8_t x_85; +x_84 = 0; +lean_ctor_set_uint8(x_79, sizeof(void*)*1, x_84); +x_85 = lean_unbox(x_80); +lean_dec(x_80); +x_57 = x_85; +x_58 = x_78; +goto block_70; +} +else +{ +lean_object* x_86; uint8_t x_87; lean_object* x_88; uint8_t x_89; +x_86 = lean_ctor_get(x_79, 0); +lean_inc(x_86); +lean_dec(x_79); +x_87 = 0; +x_88 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set_uint8(x_88, sizeof(void*)*1, x_87); +lean_ctor_set(x_78, 4, x_88); +x_89 = lean_unbox(x_80); +lean_dec(x_80); +x_57 = x_89; +x_58 = x_78; +goto block_70; +} +} +else +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; uint8_t x_97; lean_object* x_98; lean_object* x_99; uint8_t x_100; +x_90 = lean_ctor_get(x_78, 0); +x_91 = lean_ctor_get(x_78, 1); +x_92 = lean_ctor_get(x_78, 2); +x_93 = lean_ctor_get(x_78, 3); +x_94 = lean_ctor_get(x_78, 5); +lean_inc(x_94); +lean_inc(x_93); +lean_inc(x_92); +lean_inc(x_91); +lean_inc(x_90); +lean_dec(x_78); +x_95 = lean_ctor_get(x_79, 0); +lean_inc(x_95); +if (lean_is_exclusive(x_79)) { + lean_ctor_release(x_79, 0); + x_96 = x_79; +} else { + lean_dec_ref(x_79); + x_96 = lean_box(0); +} +x_97 = 0; +if (lean_is_scalar(x_96)) { + x_98 = lean_alloc_ctor(0, 1, 1); +} else { + x_98 = x_96; +} +lean_ctor_set(x_98, 0, x_95); +lean_ctor_set_uint8(x_98, sizeof(void*)*1, x_97); +x_99 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_99, 0, x_90); +lean_ctor_set(x_99, 1, x_91); +lean_ctor_set(x_99, 2, x_92); +lean_ctor_set(x_99, 3, x_93); +lean_ctor_set(x_99, 4, x_98); +lean_ctor_set(x_99, 5, x_94); +x_100 = lean_unbox(x_80); +lean_dec(x_80); +x_57 = x_100; +x_58 = x_99; +goto block_70; +} +} +else +{ +lean_object* x_101; lean_object* x_102; uint8_t x_103; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_101 = lean_ctor_get(x_77, 1); +lean_inc(x_101); +x_102 = lean_ctor_get(x_101, 4); +lean_inc(x_102); +x_103 = !lean_is_exclusive(x_77); +if (x_103 == 0) +{ +lean_object* x_104; uint8_t x_105; +x_104 = lean_ctor_get(x_77, 1); +lean_dec(x_104); +x_105 = !lean_is_exclusive(x_101); +if (x_105 == 0) +{ +lean_object* x_106; uint8_t x_107; +x_106 = lean_ctor_get(x_101, 4); +lean_dec(x_106); +x_107 = !lean_is_exclusive(x_102); +if (x_107 == 0) +{ +uint8_t x_108; +x_108 = 0; +lean_ctor_set_uint8(x_102, sizeof(void*)*1, x_108); +return x_77; +} +else +{ +lean_object* x_109; uint8_t x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_102, 0); +lean_inc(x_109); +lean_dec(x_102); +x_110 = 0; +x_111 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_111, 0, x_109); +lean_ctor_set_uint8(x_111, sizeof(void*)*1, x_110); +lean_ctor_set(x_101, 4, x_111); +return x_77; +} +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; uint8_t x_119; lean_object* x_120; lean_object* x_121; +x_112 = lean_ctor_get(x_101, 0); +x_113 = lean_ctor_get(x_101, 1); +x_114 = lean_ctor_get(x_101, 2); +x_115 = lean_ctor_get(x_101, 3); +x_116 = lean_ctor_get(x_101, 5); +lean_inc(x_116); +lean_inc(x_115); +lean_inc(x_114); +lean_inc(x_113); +lean_inc(x_112); +lean_dec(x_101); +x_117 = lean_ctor_get(x_102, 0); +lean_inc(x_117); +if (lean_is_exclusive(x_102)) { + lean_ctor_release(x_102, 0); + x_118 = x_102; +} else { + lean_dec_ref(x_102); + x_118 = lean_box(0); +} +x_119 = 0; +if (lean_is_scalar(x_118)) { + x_120 = lean_alloc_ctor(0, 1, 1); +} else { + x_120 = x_118; +} +lean_ctor_set(x_120, 0, x_117); +lean_ctor_set_uint8(x_120, sizeof(void*)*1, x_119); +x_121 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_121, 0, x_112); +lean_ctor_set(x_121, 1, x_113); +lean_ctor_set(x_121, 2, x_114); +lean_ctor_set(x_121, 3, x_115); +lean_ctor_set(x_121, 4, x_120); +lean_ctor_set(x_121, 5, x_116); +lean_ctor_set(x_77, 1, x_121); +return x_77; +} +} +else +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; uint8_t x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +x_122 = lean_ctor_get(x_77, 0); +lean_inc(x_122); +lean_dec(x_77); +x_123 = lean_ctor_get(x_101, 0); +lean_inc(x_123); +x_124 = lean_ctor_get(x_101, 1); +lean_inc(x_124); +x_125 = lean_ctor_get(x_101, 2); +lean_inc(x_125); +x_126 = lean_ctor_get(x_101, 3); +lean_inc(x_126); +x_127 = lean_ctor_get(x_101, 5); +lean_inc(x_127); +if (lean_is_exclusive(x_101)) { + lean_ctor_release(x_101, 0); + lean_ctor_release(x_101, 1); + lean_ctor_release(x_101, 2); + lean_ctor_release(x_101, 3); + lean_ctor_release(x_101, 4); + lean_ctor_release(x_101, 5); + x_128 = x_101; +} else { + lean_dec_ref(x_101); + x_128 = lean_box(0); +} +x_129 = lean_ctor_get(x_102, 0); +lean_inc(x_129); +if (lean_is_exclusive(x_102)) { + lean_ctor_release(x_102, 0); + x_130 = x_102; +} else { + lean_dec_ref(x_102); + x_130 = lean_box(0); +} +x_131 = 0; +if (lean_is_scalar(x_130)) { + x_132 = lean_alloc_ctor(0, 1, 1); +} else { + x_132 = x_130; +} +lean_ctor_set(x_132, 0, x_129); +lean_ctor_set_uint8(x_132, sizeof(void*)*1, x_131); +if (lean_is_scalar(x_128)) { + x_133 = lean_alloc_ctor(0, 6, 0); +} else { + x_133 = x_128; +} +lean_ctor_set(x_133, 0, x_123); +lean_ctor_set(x_133, 1, x_124); +lean_ctor_set(x_133, 2, x_125); +lean_ctor_set(x_133, 3, x_126); +lean_ctor_set(x_133, 4, x_132); +lean_ctor_set(x_133, 5, x_127); +x_134 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_134, 0, x_122); +lean_ctor_set(x_134, 1, x_133); +return x_134; +} +} +} +else +{ +lean_object* x_135; uint8_t x_136; lean_object* x_137; lean_object* x_138; +x_135 = lean_ctor_get(x_74, 0); +lean_inc(x_135); +lean_dec(x_74); +x_136 = 1; +x_137 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_137, 0, x_135); +lean_ctor_set_uint8(x_137, sizeof(void*)*1, x_136); +lean_ctor_set(x_72, 4, x_137); +lean_inc(x_3); +x_138 = l_Lean_Meta_try(x_21, x_3, x_72); +if (lean_obj_tag(x_138) == 0) +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; uint8_t x_150; lean_object* x_151; lean_object* x_152; uint8_t x_153; +x_139 = lean_ctor_get(x_138, 1); +lean_inc(x_139); +x_140 = lean_ctor_get(x_139, 4); +lean_inc(x_140); +x_141 = lean_ctor_get(x_138, 0); +lean_inc(x_141); +lean_dec(x_138); +x_142 = lean_ctor_get(x_139, 0); +lean_inc(x_142); +x_143 = lean_ctor_get(x_139, 1); +lean_inc(x_143); +x_144 = lean_ctor_get(x_139, 2); +lean_inc(x_144); +x_145 = lean_ctor_get(x_139, 3); +lean_inc(x_145); +x_146 = lean_ctor_get(x_139, 5); +lean_inc(x_146); +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + lean_ctor_release(x_139, 2); + lean_ctor_release(x_139, 3); + lean_ctor_release(x_139, 4); + lean_ctor_release(x_139, 5); + x_147 = x_139; +} else { + lean_dec_ref(x_139); + x_147 = lean_box(0); +} +x_148 = lean_ctor_get(x_140, 0); +lean_inc(x_148); +if (lean_is_exclusive(x_140)) { + lean_ctor_release(x_140, 0); + x_149 = x_140; +} else { + lean_dec_ref(x_140); + x_149 = lean_box(0); +} +x_150 = 0; +if (lean_is_scalar(x_149)) { + x_151 = lean_alloc_ctor(0, 1, 1); +} else { + x_151 = x_149; +} +lean_ctor_set(x_151, 0, x_148); +lean_ctor_set_uint8(x_151, sizeof(void*)*1, x_150); +if (lean_is_scalar(x_147)) { + x_152 = lean_alloc_ctor(0, 6, 0); +} else { + x_152 = x_147; +} +lean_ctor_set(x_152, 0, x_142); +lean_ctor_set(x_152, 1, x_143); +lean_ctor_set(x_152, 2, x_144); +lean_ctor_set(x_152, 3, x_145); +lean_ctor_set(x_152, 4, x_151); +lean_ctor_set(x_152, 5, x_146); +x_153 = lean_unbox(x_141); +lean_dec(x_141); +x_57 = x_153; +x_58 = x_152; +goto block_70; +} +else +{ +lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; uint8_t x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_154 = lean_ctor_get(x_138, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_154, 4); +lean_inc(x_155); +x_156 = lean_ctor_get(x_138, 0); +lean_inc(x_156); +if (lean_is_exclusive(x_138)) { + lean_ctor_release(x_138, 0); + lean_ctor_release(x_138, 1); + x_157 = x_138; +} else { + lean_dec_ref(x_138); + x_157 = lean_box(0); +} +x_158 = lean_ctor_get(x_154, 0); +lean_inc(x_158); +x_159 = lean_ctor_get(x_154, 1); +lean_inc(x_159); +x_160 = lean_ctor_get(x_154, 2); +lean_inc(x_160); +x_161 = lean_ctor_get(x_154, 3); +lean_inc(x_161); +x_162 = lean_ctor_get(x_154, 5); +lean_inc(x_162); +if (lean_is_exclusive(x_154)) { + lean_ctor_release(x_154, 0); + lean_ctor_release(x_154, 1); + lean_ctor_release(x_154, 2); + lean_ctor_release(x_154, 3); + lean_ctor_release(x_154, 4); + lean_ctor_release(x_154, 5); + x_163 = x_154; +} else { + lean_dec_ref(x_154); + x_163 = lean_box(0); +} +x_164 = lean_ctor_get(x_155, 0); +lean_inc(x_164); +if (lean_is_exclusive(x_155)) { + lean_ctor_release(x_155, 0); + x_165 = x_155; +} else { + lean_dec_ref(x_155); + x_165 = lean_box(0); +} +x_166 = 0; +if (lean_is_scalar(x_165)) { + x_167 = lean_alloc_ctor(0, 1, 1); +} else { + x_167 = x_165; +} +lean_ctor_set(x_167, 0, x_164); +lean_ctor_set_uint8(x_167, sizeof(void*)*1, x_166); +if (lean_is_scalar(x_163)) { + x_168 = lean_alloc_ctor(0, 6, 0); +} else { + x_168 = x_163; +} +lean_ctor_set(x_168, 0, x_158); +lean_ctor_set(x_168, 1, x_159); +lean_ctor_set(x_168, 2, x_160); +lean_ctor_set(x_168, 3, x_161); +lean_ctor_set(x_168, 4, x_167); +lean_ctor_set(x_168, 5, x_162); +if (lean_is_scalar(x_157)) { + x_169 = lean_alloc_ctor(1, 2, 0); +} else { + x_169 = x_157; +} +lean_ctor_set(x_169, 0, x_156); +lean_ctor_set(x_169, 1, x_168); +return x_169; +} +} +} +else +{ +lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; uint8_t x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; +x_170 = lean_ctor_get(x_72, 4); +x_171 = lean_ctor_get(x_72, 0); +x_172 = lean_ctor_get(x_72, 1); +x_173 = lean_ctor_get(x_72, 2); +x_174 = lean_ctor_get(x_72, 3); +x_175 = lean_ctor_get(x_72, 5); +lean_inc(x_175); +lean_inc(x_170); +lean_inc(x_174); +lean_inc(x_173); +lean_inc(x_172); +lean_inc(x_171); +lean_dec(x_72); +x_176 = lean_ctor_get(x_170, 0); +lean_inc(x_176); +if (lean_is_exclusive(x_170)) { + lean_ctor_release(x_170, 0); + x_177 = x_170; +} else { + lean_dec_ref(x_170); + x_177 = lean_box(0); +} +x_178 = 1; +if (lean_is_scalar(x_177)) { + x_179 = lean_alloc_ctor(0, 1, 1); +} else { + x_179 = x_177; +} +lean_ctor_set(x_179, 0, x_176); +lean_ctor_set_uint8(x_179, sizeof(void*)*1, x_178); +x_180 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_180, 0, x_171); +lean_ctor_set(x_180, 1, x_172); +lean_ctor_set(x_180, 2, x_173); +lean_ctor_set(x_180, 3, x_174); +lean_ctor_set(x_180, 4, x_179); +lean_ctor_set(x_180, 5, x_175); +lean_inc(x_3); +x_181 = l_Lean_Meta_try(x_21, x_3, x_180); +if (lean_obj_tag(x_181) == 0) +{ +lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; uint8_t x_193; lean_object* x_194; lean_object* x_195; uint8_t x_196; +x_182 = lean_ctor_get(x_181, 1); +lean_inc(x_182); +x_183 = lean_ctor_get(x_182, 4); +lean_inc(x_183); +x_184 = lean_ctor_get(x_181, 0); +lean_inc(x_184); +lean_dec(x_181); +x_185 = lean_ctor_get(x_182, 0); +lean_inc(x_185); +x_186 = lean_ctor_get(x_182, 1); +lean_inc(x_186); +x_187 = lean_ctor_get(x_182, 2); +lean_inc(x_187); +x_188 = lean_ctor_get(x_182, 3); +lean_inc(x_188); +x_189 = lean_ctor_get(x_182, 5); +lean_inc(x_189); +if (lean_is_exclusive(x_182)) { + lean_ctor_release(x_182, 0); + lean_ctor_release(x_182, 1); + lean_ctor_release(x_182, 2); + lean_ctor_release(x_182, 3); + lean_ctor_release(x_182, 4); + lean_ctor_release(x_182, 5); + x_190 = x_182; +} else { + lean_dec_ref(x_182); + x_190 = lean_box(0); +} +x_191 = lean_ctor_get(x_183, 0); +lean_inc(x_191); +if (lean_is_exclusive(x_183)) { + lean_ctor_release(x_183, 0); + x_192 = x_183; +} else { + lean_dec_ref(x_183); + x_192 = lean_box(0); +} +x_193 = 0; +if (lean_is_scalar(x_192)) { + x_194 = lean_alloc_ctor(0, 1, 1); +} else { + x_194 = x_192; +} +lean_ctor_set(x_194, 0, x_191); +lean_ctor_set_uint8(x_194, sizeof(void*)*1, x_193); +if (lean_is_scalar(x_190)) { + x_195 = lean_alloc_ctor(0, 6, 0); +} else { + x_195 = x_190; +} +lean_ctor_set(x_195, 0, x_185); +lean_ctor_set(x_195, 1, x_186); +lean_ctor_set(x_195, 2, x_187); +lean_ctor_set(x_195, 3, x_188); +lean_ctor_set(x_195, 4, x_194); +lean_ctor_set(x_195, 5, x_189); +x_196 = lean_unbox(x_184); +lean_dec(x_184); +x_57 = x_196; +x_58 = x_195; +goto block_70; +} +else +{ +lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; uint8_t x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_197 = lean_ctor_get(x_181, 1); +lean_inc(x_197); +x_198 = lean_ctor_get(x_197, 4); +lean_inc(x_198); +x_199 = lean_ctor_get(x_181, 0); +lean_inc(x_199); +if (lean_is_exclusive(x_181)) { + lean_ctor_release(x_181, 0); + lean_ctor_release(x_181, 1); + x_200 = x_181; +} else { + lean_dec_ref(x_181); + x_200 = lean_box(0); +} +x_201 = lean_ctor_get(x_197, 0); +lean_inc(x_201); +x_202 = lean_ctor_get(x_197, 1); +lean_inc(x_202); +x_203 = lean_ctor_get(x_197, 2); +lean_inc(x_203); +x_204 = lean_ctor_get(x_197, 3); +lean_inc(x_204); +x_205 = lean_ctor_get(x_197, 5); +lean_inc(x_205); +if (lean_is_exclusive(x_197)) { + lean_ctor_release(x_197, 0); + lean_ctor_release(x_197, 1); + lean_ctor_release(x_197, 2); + lean_ctor_release(x_197, 3); + lean_ctor_release(x_197, 4); + lean_ctor_release(x_197, 5); + x_206 = x_197; +} else { + lean_dec_ref(x_197); + x_206 = lean_box(0); +} +x_207 = lean_ctor_get(x_198, 0); +lean_inc(x_207); +if (lean_is_exclusive(x_198)) { + lean_ctor_release(x_198, 0); + x_208 = x_198; +} else { + lean_dec_ref(x_198); + x_208 = lean_box(0); +} +x_209 = 0; +if (lean_is_scalar(x_208)) { + x_210 = lean_alloc_ctor(0, 1, 1); +} else { + x_210 = x_208; +} +lean_ctor_set(x_210, 0, x_207); +lean_ctor_set_uint8(x_210, sizeof(void*)*1, x_209); +if (lean_is_scalar(x_206)) { + x_211 = lean_alloc_ctor(0, 6, 0); +} else { + x_211 = x_206; +} +lean_ctor_set(x_211, 0, x_201); +lean_ctor_set(x_211, 1, x_202); +lean_ctor_set(x_211, 2, x_203); +lean_ctor_set(x_211, 3, x_204); +lean_ctor_set(x_211, 4, x_210); +lean_ctor_set(x_211, 5, x_205); +if (lean_is_scalar(x_200)) { + x_212 = lean_alloc_ctor(1, 2, 0); +} else { + x_212 = x_200; +} +lean_ctor_set(x_212, 0, x_199); +lean_ctor_set(x_212, 1, x_211); +return x_212; +} +} +} +else +{ +lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_213 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_214 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +x_215 = l___private_Init_Lean_Trace_2__getResetTraces___rarg(x_213, x_214); +lean_inc(x_3); +x_216 = lean_apply_2(x_215, x_3, x_72); +if (lean_obj_tag(x_216) == 0) +{ +lean_object* x_217; lean_object* x_218; lean_object* x_219; +x_217 = lean_ctor_get(x_216, 0); +lean_inc(x_217); +x_218 = lean_ctor_get(x_216, 1); +lean_inc(x_218); +lean_dec(x_216); +lean_inc(x_3); +x_219 = l_Lean_Meta_try(x_21, x_3, x_218); +if (lean_obj_tag(x_219) == 0) +{ +lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; +x_220 = lean_ctor_get(x_219, 0); +lean_inc(x_220); +x_221 = lean_ctor_get(x_219, 1); +lean_inc(x_221); +lean_dec(x_219); +x_222 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +lean_inc(x_217); +x_223 = l___private_Init_Lean_Trace_1__addNode___rarg(x_214, x_217, x_222); +lean_inc(x_3); +x_224 = lean_apply_2(x_223, x_3, x_221); +if (lean_obj_tag(x_224) == 0) +{ +lean_object* x_225; uint8_t x_226; +lean_dec(x_217); +x_225 = lean_ctor_get(x_224, 1); +lean_inc(x_225); +lean_dec(x_224); +x_226 = lean_unbox(x_220); +lean_dec(x_220); +x_57 = x_226; +x_58 = x_225; +goto block_70; +} +else +{ +lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; +lean_dec(x_220); +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_2); +lean_dec(x_1); +x_227 = lean_ctor_get(x_224, 0); +lean_inc(x_227); +x_228 = lean_ctor_get(x_224, 1); +lean_inc(x_228); +lean_dec(x_224); +x_229 = l___private_Init_Lean_Trace_1__addNode___rarg(x_214, x_217, x_222); +x_230 = lean_apply_2(x_229, x_3, x_228); +if (lean_obj_tag(x_230) == 0) +{ +uint8_t x_231; +x_231 = !lean_is_exclusive(x_230); +if (x_231 == 0) +{ +lean_object* x_232; +x_232 = lean_ctor_get(x_230, 0); +lean_dec(x_232); +lean_ctor_set_tag(x_230, 1); +lean_ctor_set(x_230, 0, x_227); +return x_230; +} +else +{ +lean_object* x_233; lean_object* x_234; +x_233 = lean_ctor_get(x_230, 1); +lean_inc(x_233); +lean_dec(x_230); +x_234 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_234, 0, x_227); +lean_ctor_set(x_234, 1, x_233); +return x_234; +} +} +else +{ +uint8_t x_235; +lean_dec(x_227); +x_235 = !lean_is_exclusive(x_230); +if (x_235 == 0) +{ +return x_230; +} +else +{ +lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_236 = lean_ctor_get(x_230, 0); +x_237 = lean_ctor_get(x_230, 1); +lean_inc(x_237); +lean_inc(x_236); +lean_dec(x_230); +x_238 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_238, 0, x_236); +lean_ctor_set(x_238, 1, x_237); +return x_238; +} +} +} +} +else +{ +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; lean_object* x_243; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_2); +lean_dec(x_1); +x_239 = lean_ctor_get(x_219, 0); +lean_inc(x_239); +x_240 = lean_ctor_get(x_219, 1); +lean_inc(x_240); +lean_dec(x_219); +x_241 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_242 = l___private_Init_Lean_Trace_1__addNode___rarg(x_214, x_217, x_241); +x_243 = lean_apply_2(x_242, x_3, x_240); +if (lean_obj_tag(x_243) == 0) +{ +uint8_t x_244; +x_244 = !lean_is_exclusive(x_243); +if (x_244 == 0) +{ +lean_object* x_245; +x_245 = lean_ctor_get(x_243, 0); +lean_dec(x_245); +lean_ctor_set_tag(x_243, 1); +lean_ctor_set(x_243, 0, x_239); +return x_243; +} +else +{ +lean_object* x_246; lean_object* x_247; +x_246 = lean_ctor_get(x_243, 1); +lean_inc(x_246); +lean_dec(x_243); +x_247 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_247, 0, x_239); +lean_ctor_set(x_247, 1, x_246); +return x_247; +} +} +else +{ +uint8_t x_248; +lean_dec(x_239); +x_248 = !lean_is_exclusive(x_243); +if (x_248 == 0) +{ +return x_243; +} +else +{ +lean_object* x_249; lean_object* x_250; lean_object* x_251; +x_249 = lean_ctor_get(x_243, 0); +x_250 = lean_ctor_get(x_243, 1); +lean_inc(x_250); +lean_inc(x_249); +lean_dec(x_243); +x_251 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_251, 0, x_249); +lean_ctor_set(x_251, 1, x_250); +return x_251; +} +} +} +} +else +{ +uint8_t x_252; +lean_dec(x_56); +lean_dec(x_55); +lean_dec(x_54); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_252 = !lean_is_exclusive(x_216); +if (x_252 == 0) +{ +return x_216; +} +else +{ +lean_object* x_253; lean_object* x_254; lean_object* x_255; +x_253 = lean_ctor_get(x_216, 0); +x_254 = lean_ctor_get(x_216, 1); +lean_inc(x_254); +lean_inc(x_253); +lean_dec(x_216); +x_255 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_255, 0, x_253); +lean_ctor_set(x_255, 1, x_254); +return x_255; +} +} +} +} +} +} +} +else +{ +uint8_t x_492; +lean_free_object(x_22); +lean_dec(x_24); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_492 = !lean_is_exclusive(x_26); +if (x_492 == 0) +{ +return x_26; +} +else +{ +lean_object* x_493; lean_object* x_494; lean_object* x_495; +x_493 = lean_ctor_get(x_26, 0); +x_494 = lean_ctor_get(x_26, 1); +lean_inc(x_494); +lean_inc(x_493); +lean_dec(x_26); +x_495 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_495, 0, x_493); +lean_ctor_set(x_495, 1, x_494); +return x_495; +} +} +} +else +{ +lean_object* x_496; lean_object* x_497; lean_object* x_498; +x_496 = lean_ctor_get(x_22, 0); +x_497 = lean_ctor_get(x_22, 1); +lean_inc(x_497); +lean_inc(x_496); +lean_dec(x_22); +x_498 = l___private_Init_Lean_Meta_ExprDefEq_19__isDeltaCandidate(x_6, x_3, x_497); +lean_dec(x_6); +if (lean_obj_tag(x_498) == 0) +{ +if (lean_obj_tag(x_496) == 0) +{ +lean_object* x_499; +lean_dec(x_21); +x_499 = lean_ctor_get(x_498, 0); +lean_inc(x_499); +if (lean_obj_tag(x_499) == 0) +{ +lean_object* x_500; lean_object* x_501; uint8_t x_502; lean_object* x_503; lean_object* x_504; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_500 = lean_ctor_get(x_498, 1); +lean_inc(x_500); +if (lean_is_exclusive(x_498)) { + lean_ctor_release(x_498, 0); + lean_ctor_release(x_498, 1); + x_501 = x_498; +} else { + lean_dec_ref(x_498); + x_501 = lean_box(0); +} +x_502 = 2; +x_503 = lean_box(x_502); +if (lean_is_scalar(x_501)) { + x_504 = lean_alloc_ctor(0, 2, 0); +} else { + x_504 = x_501; +} +lean_ctor_set(x_504, 0, x_503); +lean_ctor_set(x_504, 1, x_500); +return x_504; +} +else +{ +lean_object* x_505; lean_object* x_506; lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; lean_object* x_511; lean_object* x_512; +x_505 = lean_ctor_get(x_498, 1); +lean_inc(x_505); +lean_dec(x_498); +x_506 = lean_ctor_get(x_499, 0); +lean_inc(x_506); +lean_dec(x_499); +x_507 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_508 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_509 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +x_510 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___boxed), 8, 5); +lean_closure_set(x_510, 0, x_1); +lean_closure_set(x_510, 1, x_506); +lean_closure_set(x_510, 2, x_507); +lean_closure_set(x_510, 3, x_508); +lean_closure_set(x_510, 4, x_509); +x_511 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +x_512 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_511, x_510, x_3, x_505); +return x_512; +} +} +else +{ +lean_object* x_513; +x_513 = lean_ctor_get(x_498, 0); +lean_inc(x_513); +if (lean_obj_tag(x_513) == 0) +{ +lean_object* x_514; lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_object* x_519; lean_object* x_520; lean_object* x_521; +lean_dec(x_21); +x_514 = lean_ctor_get(x_498, 1); +lean_inc(x_514); +lean_dec(x_498); +x_515 = lean_ctor_get(x_496, 0); +lean_inc(x_515); +lean_dec(x_496); +x_516 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_517 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_518 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +x_519 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___boxed), 8, 5); +lean_closure_set(x_519, 0, x_2); +lean_closure_set(x_519, 1, x_515); +lean_closure_set(x_519, 2, x_516); +lean_closure_set(x_519, 3, x_517); +lean_closure_set(x_519, 4, x_518); +x_520 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +x_521 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_520, x_519, x_3, x_514); +return x_521; +} +else +{ +lean_object* x_522; lean_object* x_523; lean_object* x_524; lean_object* x_525; uint8_t x_526; lean_object* x_527; uint8_t x_540; lean_object* x_541; lean_object* x_628; lean_object* x_629; uint8_t x_630; +x_522 = lean_ctor_get(x_498, 1); +lean_inc(x_522); +if (lean_is_exclusive(x_498)) { + lean_ctor_release(x_498, 0); + lean_ctor_release(x_498, 1); + x_523 = x_498; +} else { + lean_dec_ref(x_498); + x_523 = lean_box(0); +} +x_524 = lean_ctor_get(x_496, 0); +lean_inc(x_524); +lean_dec(x_496); +x_525 = lean_ctor_get(x_513, 0); +lean_inc(x_525); +lean_dec(x_513); +x_628 = l_Lean_ConstantInfo_name(x_524); +x_629 = l_Lean_ConstantInfo_name(x_525); +x_630 = lean_name_eq(x_628, x_629); +if (x_630 == 0) +{ +lean_object* x_631; uint8_t x_632; uint8_t x_633; uint8_t x_634; lean_object* x_635; +lean_dec(x_523); +lean_dec(x_21); +x_631 = lean_ctor_get(x_3, 0); +lean_inc(x_631); +x_632 = lean_ctor_get_uint8(x_631, sizeof(void*)*1 + 5); +lean_dec(x_631); +x_633 = 2; +x_634 = l_Lean_Meta_TransparencyMode_beq(x_632, x_633); +if (x_634 == 0) +{ +lean_object* x_645; uint8_t x_646; lean_object* x_647; lean_object* x_658; lean_object* x_670; uint8_t x_709; lean_object* x_710; +x_645 = lean_ctor_get(x_522, 0); +lean_inc(x_645); +lean_inc(x_628); +lean_inc(x_645); +x_646 = l_Lean_isReducible(x_645, x_628); +lean_inc(x_629); +x_709 = l_Lean_isReducible(x_645, x_629); +if (x_646 == 0) +{ +lean_object* x_747; +x_747 = lean_box(0); +x_710 = x_747; +goto block_746; +} +else +{ +if (x_709 == 0) +{ +uint8_t x_748; lean_object* x_749; lean_object* x_750; lean_object* x_751; lean_object* x_752; lean_object* x_753; +x_748 = l_Lean_Expr_hasExprMVar(x_1); +x_749 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_750 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_751 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_628); +lean_inc(x_2); +x_752 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_752, 0, x_2); +lean_closure_set(x_752, 1, x_749); +lean_closure_set(x_752, 2, x_750); +lean_closure_set(x_752, 3, x_628); +lean_closure_set(x_752, 4, x_751); +if (x_748 == 0) +{ +uint8_t x_761; +x_761 = l_Lean_Expr_hasExprMVar(x_2); +if (x_761 == 0) +{ +lean_object* x_762; lean_object* x_763; uint8_t x_764; +x_762 = l_Lean_ConstantInfo_hints(x_524); +lean_dec(x_524); +x_763 = l_Lean_ConstantInfo_hints(x_525); +lean_dec(x_525); +x_764 = l_Lean_ReducibilityHints_lt(x_762, x_763); +if (x_764 == 0) +{ +uint8_t x_765; +x_765 = l_Lean_ReducibilityHints_lt(x_763, x_762); +lean_dec(x_762); +lean_dec(x_763); +if (x_765 == 0) +{ +lean_object* x_766; lean_object* x_767; lean_object* x_768; lean_object* x_769; lean_object* x_770; lean_object* x_771; +lean_inc(x_629); +lean_inc(x_1); +x_766 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_766, 0, x_1); +lean_closure_set(x_766, 1, x_749); +lean_closure_set(x_766, 2, x_750); +lean_closure_set(x_766, 3, x_629); +lean_closure_set(x_766, 4, x_751); +x_767 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_768 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_768, 0, x_2); +lean_closure_set(x_768, 1, x_767); +lean_closure_set(x_768, 2, x_766); +lean_inc(x_1); +x_769 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_769, 0, x_2); +lean_closure_set(x_769, 1, x_749); +lean_closure_set(x_769, 2, x_750); +lean_closure_set(x_769, 3, x_20); +lean_closure_set(x_769, 4, x_628); +lean_closure_set(x_769, 5, x_751); +lean_closure_set(x_769, 6, x_1); +lean_closure_set(x_769, 7, x_629); +lean_inc(x_1); +x_770 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_770, 0, x_1); +lean_closure_set(x_770, 1, x_768); +lean_closure_set(x_770, 2, x_769); +x_771 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_770, x_752, x_3, x_522); +return x_771; +} +else +{ +lean_object* x_772; lean_object* x_773; lean_object* x_774; lean_object* x_775; lean_object* x_776; lean_object* x_777; lean_object* x_778; +lean_inc(x_629); +lean_inc(x_1); +x_772 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_772, 0, x_1); +lean_closure_set(x_772, 1, x_749); +lean_closure_set(x_772, 2, x_750); +lean_closure_set(x_772, 3, x_629); +lean_closure_set(x_772, 4, x_751); +x_773 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_772); +lean_inc(x_2); +x_774 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_774, 0, x_2); +lean_closure_set(x_774, 1, x_773); +lean_closure_set(x_774, 2, x_772); +lean_inc(x_1); +lean_inc(x_2); +x_775 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_775, 0, x_2); +lean_closure_set(x_775, 1, x_749); +lean_closure_set(x_775, 2, x_750); +lean_closure_set(x_775, 3, x_20); +lean_closure_set(x_775, 4, x_628); +lean_closure_set(x_775, 5, x_751); +lean_closure_set(x_775, 6, x_1); +lean_closure_set(x_775, 7, x_629); +lean_inc(x_1); +x_776 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_776, 0, x_1); +lean_closure_set(x_776, 1, x_774); +lean_closure_set(x_776, 2, x_775); +x_777 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_777, 0, x_2); +lean_closure_set(x_777, 1, x_776); +lean_closure_set(x_777, 2, x_772); +x_778 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_777, x_752, x_3, x_522); +return x_778; +} +} +else +{ +lean_object* x_779; lean_object* x_780; lean_object* x_781; lean_object* x_782; lean_object* x_783; lean_object* x_784; lean_object* x_785; +lean_dec(x_763); +lean_dec(x_762); +lean_inc(x_629); +lean_inc(x_1); +x_779 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_779, 0, x_1); +lean_closure_set(x_779, 1, x_749); +lean_closure_set(x_779, 2, x_750); +lean_closure_set(x_779, 3, x_629); +lean_closure_set(x_779, 4, x_751); +x_780 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_781 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_781, 0, x_2); +lean_closure_set(x_781, 1, x_780); +lean_closure_set(x_781, 2, x_779); +lean_inc(x_1); +x_782 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_782, 0, x_2); +lean_closure_set(x_782, 1, x_749); +lean_closure_set(x_782, 2, x_750); +lean_closure_set(x_782, 3, x_20); +lean_closure_set(x_782, 4, x_628); +lean_closure_set(x_782, 5, x_751); +lean_closure_set(x_782, 6, x_1); +lean_closure_set(x_782, 7, x_629); +lean_inc(x_1); +x_783 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_783, 0, x_1); +lean_closure_set(x_783, 1, x_781); +lean_closure_set(x_783, 2, x_782); +lean_inc(x_752); +lean_inc(x_1); +x_784 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_784, 0, x_1); +lean_closure_set(x_784, 1, x_783); +lean_closure_set(x_784, 2, x_752); +x_785 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_784, x_752, x_3, x_522); +return x_785; +} +} +else +{ +lean_object* x_786; +lean_dec(x_525); +lean_dec(x_524); +x_786 = lean_box(0); +x_753 = x_786; +goto block_760; +} +} +else +{ +lean_object* x_787; +lean_dec(x_525); +lean_dec(x_524); +x_787 = lean_box(0); +x_753 = x_787; +goto block_760; +} +block_760: +{ +lean_object* x_754; lean_object* x_755; lean_object* x_756; lean_object* x_757; lean_object* x_758; lean_object* x_759; +lean_dec(x_753); +lean_inc(x_629); +lean_inc(x_1); +x_754 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_754, 0, x_1); +lean_closure_set(x_754, 1, x_749); +lean_closure_set(x_754, 2, x_750); +lean_closure_set(x_754, 3, x_629); +lean_closure_set(x_754, 4, x_751); +x_755 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_756 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_756, 0, x_2); +lean_closure_set(x_756, 1, x_755); +lean_closure_set(x_756, 2, x_754); +lean_inc(x_1); +x_757 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_757, 0, x_2); +lean_closure_set(x_757, 1, x_749); +lean_closure_set(x_757, 2, x_750); +lean_closure_set(x_757, 3, x_20); +lean_closure_set(x_757, 4, x_628); +lean_closure_set(x_757, 5, x_751); +lean_closure_set(x_757, 6, x_1); +lean_closure_set(x_757, 7, x_629); +lean_inc(x_1); +x_758 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_758, 0, x_1); +lean_closure_set(x_758, 1, x_756); +lean_closure_set(x_758, 2, x_757); +x_759 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_758, x_752, x_3, x_522); +return x_759; +} +} +else +{ +lean_object* x_788; +x_788 = lean_box(0); +x_710 = x_788; +goto block_746; +} +} +block_657: +{ +lean_object* x_648; lean_object* x_649; lean_object* x_650; lean_object* x_651; lean_object* x_652; lean_object* x_653; lean_object* x_654; lean_object* x_655; lean_object* x_656; +lean_dec(x_647); +x_648 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_649 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_650 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_629); +lean_inc(x_1); +x_651 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_651, 0, x_1); +lean_closure_set(x_651, 1, x_648); +lean_closure_set(x_651, 2, x_649); +lean_closure_set(x_651, 3, x_629); +lean_closure_set(x_651, 4, x_650); +x_652 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_651); +lean_inc(x_2); +x_653 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_653, 0, x_2); +lean_closure_set(x_653, 1, x_652); +lean_closure_set(x_653, 2, x_651); +lean_inc(x_1); +lean_inc(x_2); +x_654 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_654, 0, x_2); +lean_closure_set(x_654, 1, x_648); +lean_closure_set(x_654, 2, x_649); +lean_closure_set(x_654, 3, x_20); +lean_closure_set(x_654, 4, x_628); +lean_closure_set(x_654, 5, x_650); +lean_closure_set(x_654, 6, x_1); +lean_closure_set(x_654, 7, x_629); +x_655 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_655, 0, x_1); +lean_closure_set(x_655, 1, x_653); +lean_closure_set(x_655, 2, x_654); +x_656 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_655, x_651, x_3, x_522); +return x_656; +} +block_669: +{ +lean_object* x_659; lean_object* x_660; lean_object* x_661; lean_object* x_662; lean_object* x_663; lean_object* x_664; lean_object* x_665; lean_object* x_666; lean_object* x_667; lean_object* x_668; +lean_dec(x_658); +x_659 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_660 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_661 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_629); +lean_inc(x_1); +x_662 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_662, 0, x_1); +lean_closure_set(x_662, 1, x_659); +lean_closure_set(x_662, 2, x_660); +lean_closure_set(x_662, 3, x_629); +lean_closure_set(x_662, 4, x_661); +x_663 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_664 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_664, 0, x_2); +lean_closure_set(x_664, 1, x_663); +lean_closure_set(x_664, 2, x_662); +lean_inc(x_1); +lean_inc(x_628); +lean_inc(x_2); +x_665 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_665, 0, x_2); +lean_closure_set(x_665, 1, x_659); +lean_closure_set(x_665, 2, x_660); +lean_closure_set(x_665, 3, x_20); +lean_closure_set(x_665, 4, x_628); +lean_closure_set(x_665, 5, x_661); +lean_closure_set(x_665, 6, x_1); +lean_closure_set(x_665, 7, x_629); +lean_inc(x_1); +x_666 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_666, 0, x_1); +lean_closure_set(x_666, 1, x_664); +lean_closure_set(x_666, 2, x_665); +x_667 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_667, 0, x_2); +lean_closure_set(x_667, 1, x_659); +lean_closure_set(x_667, 2, x_660); +lean_closure_set(x_667, 3, x_628); +lean_closure_set(x_667, 4, x_661); +x_668 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_666, x_667, x_3, x_522); +return x_668; +} +block_708: +{ +uint8_t x_671; lean_object* x_672; lean_object* x_673; lean_object* x_674; lean_object* x_675; lean_object* x_676; +lean_dec(x_670); +x_671 = l_Lean_Expr_hasExprMVar(x_1); +x_672 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_673 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_674 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_629); +lean_inc(x_1); +x_675 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_675, 0, x_1); +lean_closure_set(x_675, 1, x_672); +lean_closure_set(x_675, 2, x_673); +lean_closure_set(x_675, 3, x_629); +lean_closure_set(x_675, 4, x_674); +if (x_671 == 0) +{ +uint8_t x_683; +x_683 = l_Lean_Expr_hasExprMVar(x_2); +if (x_683 == 0) +{ +lean_object* x_684; lean_object* x_685; uint8_t x_686; +x_684 = l_Lean_ConstantInfo_hints(x_524); +lean_dec(x_524); +x_685 = l_Lean_ConstantInfo_hints(x_525); +lean_dec(x_525); +x_686 = l_Lean_ReducibilityHints_lt(x_684, x_685); +if (x_686 == 0) +{ +uint8_t x_687; +x_687 = l_Lean_ReducibilityHints_lt(x_685, x_684); +lean_dec(x_684); +lean_dec(x_685); +if (x_687 == 0) +{ +lean_object* x_688; lean_object* x_689; lean_object* x_690; lean_object* x_691; lean_object* x_692; +x_688 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_675); +lean_inc(x_2); +x_689 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_689, 0, x_2); +lean_closure_set(x_689, 1, x_688); +lean_closure_set(x_689, 2, x_675); +lean_inc(x_1); +lean_inc(x_2); +x_690 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_690, 0, x_2); +lean_closure_set(x_690, 1, x_672); +lean_closure_set(x_690, 2, x_673); +lean_closure_set(x_690, 3, x_20); +lean_closure_set(x_690, 4, x_628); +lean_closure_set(x_690, 5, x_674); +lean_closure_set(x_690, 6, x_1); +lean_closure_set(x_690, 7, x_629); +x_691 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_691, 0, x_1); +lean_closure_set(x_691, 1, x_689); +lean_closure_set(x_691, 2, x_690); +x_692 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_691, x_675, x_3, x_522); +return x_692; +} +else +{ +lean_object* x_693; lean_object* x_694; lean_object* x_695; lean_object* x_696; lean_object* x_697; lean_object* x_698; +x_693 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_675); +lean_inc(x_2); +x_694 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_694, 0, x_2); +lean_closure_set(x_694, 1, x_693); +lean_closure_set(x_694, 2, x_675); +lean_inc(x_1); +lean_inc(x_2); +x_695 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_695, 0, x_2); +lean_closure_set(x_695, 1, x_672); +lean_closure_set(x_695, 2, x_673); +lean_closure_set(x_695, 3, x_20); +lean_closure_set(x_695, 4, x_628); +lean_closure_set(x_695, 5, x_674); +lean_closure_set(x_695, 6, x_1); +lean_closure_set(x_695, 7, x_629); +x_696 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_696, 0, x_1); +lean_closure_set(x_696, 1, x_694); +lean_closure_set(x_696, 2, x_695); +lean_inc(x_675); +lean_inc(x_2); +x_697 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_697, 0, x_2); +lean_closure_set(x_697, 1, x_696); +lean_closure_set(x_697, 2, x_675); +x_698 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_697, x_675, x_3, x_522); +return x_698; +} +} +else +{ +lean_object* x_699; lean_object* x_700; lean_object* x_701; lean_object* x_702; lean_object* x_703; lean_object* x_704; lean_object* x_705; +lean_dec(x_685); +lean_dec(x_684); +x_699 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_675); +lean_inc(x_2); +x_700 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_700, 0, x_2); +lean_closure_set(x_700, 1, x_699); +lean_closure_set(x_700, 2, x_675); +lean_inc(x_1); +lean_inc(x_628); +lean_inc(x_2); +x_701 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_701, 0, x_2); +lean_closure_set(x_701, 1, x_672); +lean_closure_set(x_701, 2, x_673); +lean_closure_set(x_701, 3, x_20); +lean_closure_set(x_701, 4, x_628); +lean_closure_set(x_701, 5, x_674); +lean_closure_set(x_701, 6, x_1); +lean_closure_set(x_701, 7, x_629); +lean_inc(x_1); +x_702 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_702, 0, x_1); +lean_closure_set(x_702, 1, x_700); +lean_closure_set(x_702, 2, x_701); +lean_inc(x_2); +x_703 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_703, 0, x_2); +lean_closure_set(x_703, 1, x_672); +lean_closure_set(x_703, 2, x_673); +lean_closure_set(x_703, 3, x_628); +lean_closure_set(x_703, 4, x_674); +x_704 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_704, 0, x_1); +lean_closure_set(x_704, 1, x_702); +lean_closure_set(x_704, 2, x_703); +x_705 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_704, x_675, x_3, x_522); +return x_705; +} +} +else +{ +lean_object* x_706; +lean_dec(x_525); +lean_dec(x_524); +x_706 = lean_box(0); +x_676 = x_706; +goto block_682; +} +} +else +{ +lean_object* x_707; +lean_dec(x_525); +lean_dec(x_524); +x_707 = lean_box(0); +x_676 = x_707; +goto block_682; +} +block_682: +{ +lean_object* x_677; lean_object* x_678; lean_object* x_679; lean_object* x_680; lean_object* x_681; +lean_dec(x_676); +x_677 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_675); +lean_inc(x_2); +x_678 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_678, 0, x_2); +lean_closure_set(x_678, 1, x_677); +lean_closure_set(x_678, 2, x_675); +lean_inc(x_1); +lean_inc(x_2); +x_679 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_679, 0, x_2); +lean_closure_set(x_679, 1, x_672); +lean_closure_set(x_679, 2, x_673); +lean_closure_set(x_679, 3, x_20); +lean_closure_set(x_679, 4, x_628); +lean_closure_set(x_679, 5, x_674); +lean_closure_set(x_679, 6, x_1); +lean_closure_set(x_679, 7, x_629); +x_680 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_680, 0, x_1); +lean_closure_set(x_680, 1, x_678); +lean_closure_set(x_680, 2, x_679); +x_681 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_680, x_675, x_3, x_522); +return x_681; +} +} +block_746: +{ +lean_dec(x_710); +if (x_646 == 0) +{ +if (x_709 == 0) +{ +uint8_t x_711; +x_711 = l_Lean_Expr_hasExprMVar(x_1); +if (x_711 == 0) +{ +uint8_t x_712; +x_712 = l_Lean_Expr_hasExprMVar(x_2); +if (x_712 == 0) +{ +lean_object* x_713; lean_object* x_714; uint8_t x_715; +x_713 = l_Lean_ConstantInfo_hints(x_524); +lean_dec(x_524); +x_714 = l_Lean_ConstantInfo_hints(x_525); +lean_dec(x_525); +x_715 = l_Lean_ReducibilityHints_lt(x_713, x_714); +if (x_715 == 0) +{ +uint8_t x_716; +x_716 = l_Lean_ReducibilityHints_lt(x_714, x_713); +lean_dec(x_713); +lean_dec(x_714); +if (x_716 == 0) +{ +lean_object* x_717; +x_717 = lean_box(0); +x_635 = x_717; +goto block_644; +} +else +{ +lean_object* x_718; +x_718 = lean_box(0); +x_647 = x_718; +goto block_657; +} +} +else +{ +lean_object* x_719; +lean_dec(x_714); +lean_dec(x_713); +x_719 = lean_box(0); +x_658 = x_719; +goto block_669; +} +} +else +{ +lean_object* x_720; +lean_dec(x_525); +lean_dec(x_524); +x_720 = lean_box(0); +x_635 = x_720; +goto block_644; +} +} +else +{ +lean_object* x_721; +lean_dec(x_525); +lean_dec(x_524); +x_721 = lean_box(0); +x_635 = x_721; +goto block_644; +} +} +else +{ +lean_object* x_722; +x_722 = lean_box(0); +x_670 = x_722; +goto block_708; +} +} +else +{ +if (x_634 == 0) +{ +uint8_t x_723; +x_723 = l_Lean_Expr_hasExprMVar(x_1); +if (x_723 == 0) +{ +uint8_t x_724; +x_724 = l_Lean_Expr_hasExprMVar(x_2); +if (x_724 == 0) +{ +lean_object* x_725; lean_object* x_726; uint8_t x_727; +x_725 = l_Lean_ConstantInfo_hints(x_524); +lean_dec(x_524); +x_726 = l_Lean_ConstantInfo_hints(x_525); +lean_dec(x_525); +x_727 = l_Lean_ReducibilityHints_lt(x_725, x_726); +if (x_727 == 0) +{ +uint8_t x_728; +x_728 = l_Lean_ReducibilityHints_lt(x_726, x_725); +lean_dec(x_725); +lean_dec(x_726); +if (x_728 == 0) +{ +lean_object* x_729; +x_729 = lean_box(0); +x_635 = x_729; +goto block_644; +} +else +{ +lean_object* x_730; +x_730 = lean_box(0); +x_647 = x_730; +goto block_657; +} +} +else +{ +lean_object* x_731; +lean_dec(x_726); +lean_dec(x_725); +x_731 = lean_box(0); +x_658 = x_731; +goto block_669; +} +} +else +{ +lean_object* x_732; +lean_dec(x_525); +lean_dec(x_524); +x_732 = lean_box(0); +x_635 = x_732; +goto block_644; +} +} +else +{ +lean_object* x_733; +lean_dec(x_525); +lean_dec(x_524); +x_733 = lean_box(0); +x_635 = x_733; +goto block_644; +} +} +else +{ +if (x_709 == 0) +{ +uint8_t x_734; +x_734 = l_Lean_Expr_hasExprMVar(x_1); +if (x_734 == 0) +{ +uint8_t x_735; +x_735 = l_Lean_Expr_hasExprMVar(x_2); +if (x_735 == 0) +{ +lean_object* x_736; lean_object* x_737; uint8_t x_738; +x_736 = l_Lean_ConstantInfo_hints(x_524); +lean_dec(x_524); +x_737 = l_Lean_ConstantInfo_hints(x_525); +lean_dec(x_525); +x_738 = l_Lean_ReducibilityHints_lt(x_736, x_737); +if (x_738 == 0) +{ +uint8_t x_739; +x_739 = l_Lean_ReducibilityHints_lt(x_737, x_736); +lean_dec(x_736); +lean_dec(x_737); +if (x_739 == 0) +{ +lean_object* x_740; +x_740 = lean_box(0); +x_635 = x_740; +goto block_644; +} +else +{ +lean_object* x_741; +x_741 = lean_box(0); +x_647 = x_741; +goto block_657; +} +} +else +{ +lean_object* x_742; +lean_dec(x_737); +lean_dec(x_736); +x_742 = lean_box(0); +x_658 = x_742; +goto block_669; +} +} +else +{ +lean_object* x_743; +lean_dec(x_525); +lean_dec(x_524); +x_743 = lean_box(0); +x_635 = x_743; +goto block_644; +} +} +else +{ +lean_object* x_744; +lean_dec(x_525); +lean_dec(x_524); +x_744 = lean_box(0); +x_635 = x_744; +goto block_644; +} +} +else +{ +lean_object* x_745; +x_745 = lean_box(0); +x_670 = x_745; +goto block_708; +} +} +} +} +} +else +{ +uint8_t x_789; +x_789 = l_Lean_Expr_hasExprMVar(x_1); +if (x_789 == 0) +{ +uint8_t x_790; +x_790 = l_Lean_Expr_hasExprMVar(x_2); +if (x_790 == 0) +{ +lean_object* x_791; lean_object* x_792; uint8_t x_793; +x_791 = l_Lean_ConstantInfo_hints(x_524); +lean_dec(x_524); +x_792 = l_Lean_ConstantInfo_hints(x_525); +lean_dec(x_525); +x_793 = l_Lean_ReducibilityHints_lt(x_791, x_792); +if (x_793 == 0) +{ +uint8_t x_794; +x_794 = l_Lean_ReducibilityHints_lt(x_792, x_791); +lean_dec(x_791); +lean_dec(x_792); +if (x_794 == 0) +{ +lean_object* x_795; lean_object* x_796; lean_object* x_797; lean_object* x_798; lean_object* x_799; lean_object* x_800; lean_object* x_801; lean_object* x_802; +x_795 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_796 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_797 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_629); +lean_inc(x_1); +x_798 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_798, 0, x_1); +lean_closure_set(x_798, 1, x_795); +lean_closure_set(x_798, 2, x_796); +lean_closure_set(x_798, 3, x_629); +lean_closure_set(x_798, 4, x_797); +x_799 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_800 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_800, 0, x_2); +lean_closure_set(x_800, 1, x_799); +lean_closure_set(x_800, 2, x_798); +lean_inc(x_1); +x_801 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_801, 0, x_2); +lean_closure_set(x_801, 1, x_795); +lean_closure_set(x_801, 2, x_796); +lean_closure_set(x_801, 3, x_20); +lean_closure_set(x_801, 4, x_628); +lean_closure_set(x_801, 5, x_797); +lean_closure_set(x_801, 6, x_1); +lean_closure_set(x_801, 7, x_629); +x_802 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_800, x_801, x_3, x_522); +return x_802; +} +else +{ +lean_object* x_803; lean_object* x_804; lean_object* x_805; lean_object* x_806; lean_object* x_807; lean_object* x_808; lean_object* x_809; lean_object* x_810; lean_object* x_811; +x_803 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_804 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_805 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_629); +lean_inc(x_1); +x_806 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_806, 0, x_1); +lean_closure_set(x_806, 1, x_803); +lean_closure_set(x_806, 2, x_804); +lean_closure_set(x_806, 3, x_629); +lean_closure_set(x_806, 4, x_805); +x_807 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_806); +lean_inc(x_2); +x_808 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_808, 0, x_2); +lean_closure_set(x_808, 1, x_807); +lean_closure_set(x_808, 2, x_806); +lean_inc(x_1); +lean_inc(x_2); +x_809 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_809, 0, x_2); +lean_closure_set(x_809, 1, x_803); +lean_closure_set(x_809, 2, x_804); +lean_closure_set(x_809, 3, x_20); +lean_closure_set(x_809, 4, x_628); +lean_closure_set(x_809, 5, x_805); +lean_closure_set(x_809, 6, x_1); +lean_closure_set(x_809, 7, x_629); +x_810 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_810, 0, x_1); +lean_closure_set(x_810, 1, x_808); +lean_closure_set(x_810, 2, x_809); +x_811 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_2, x_810, x_806, x_3, x_522); +return x_811; +} +} +else +{ +lean_object* x_812; lean_object* x_813; lean_object* x_814; lean_object* x_815; lean_object* x_816; lean_object* x_817; lean_object* x_818; lean_object* x_819; lean_object* x_820; lean_object* x_821; +lean_dec(x_792); +lean_dec(x_791); +x_812 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_813 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_814 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_629); +lean_inc(x_1); +x_815 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_815, 0, x_1); +lean_closure_set(x_815, 1, x_812); +lean_closure_set(x_815, 2, x_813); +lean_closure_set(x_815, 3, x_629); +lean_closure_set(x_815, 4, x_814); +x_816 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_817 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_817, 0, x_2); +lean_closure_set(x_817, 1, x_816); +lean_closure_set(x_817, 2, x_815); +lean_inc(x_1); +lean_inc(x_628); +lean_inc(x_2); +x_818 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_818, 0, x_2); +lean_closure_set(x_818, 1, x_812); +lean_closure_set(x_818, 2, x_813); +lean_closure_set(x_818, 3, x_20); +lean_closure_set(x_818, 4, x_628); +lean_closure_set(x_818, 5, x_814); +lean_closure_set(x_818, 6, x_1); +lean_closure_set(x_818, 7, x_629); +lean_inc(x_1); +x_819 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_819, 0, x_1); +lean_closure_set(x_819, 1, x_817); +lean_closure_set(x_819, 2, x_818); +x_820 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__12), 8, 5); +lean_closure_set(x_820, 0, x_2); +lean_closure_set(x_820, 1, x_812); +lean_closure_set(x_820, 2, x_813); +lean_closure_set(x_820, 3, x_628); +lean_closure_set(x_820, 4, x_814); +x_821 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_819, x_820, x_3, x_522); +return x_821; +} +} +else +{ +lean_object* x_822; +lean_dec(x_525); +lean_dec(x_524); +x_822 = lean_box(0); +x_635 = x_822; +goto block_644; +} +} +else +{ +lean_object* x_823; +lean_dec(x_525); +lean_dec(x_524); +x_823 = lean_box(0); +x_635 = x_823; +goto block_644; +} +} +block_644: +{ +lean_object* x_636; lean_object* x_637; lean_object* x_638; lean_object* x_639; lean_object* x_640; lean_object* x_641; lean_object* x_642; lean_object* x_643; +lean_dec(x_635); +x_636 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_637 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_638 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_629); +lean_inc(x_1); +x_639 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__9), 8, 5); +lean_closure_set(x_639, 0, x_1); +lean_closure_set(x_639, 1, x_636); +lean_closure_set(x_639, 2, x_637); +lean_closure_set(x_639, 3, x_629); +lean_closure_set(x_639, 4, x_638); +x_640 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4; +lean_inc(x_2); +x_641 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_641, 0, x_2); +lean_closure_set(x_641, 1, x_640); +lean_closure_set(x_641, 2, x_639); +lean_inc(x_1); +x_642 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__11), 11, 8); +lean_closure_set(x_642, 0, x_2); +lean_closure_set(x_642, 1, x_636); +lean_closure_set(x_642, 2, x_637); +lean_closure_set(x_642, 3, x_20); +lean_closure_set(x_642, 4, x_628); +lean_closure_set(x_642, 5, x_638); +lean_closure_set(x_642, 6, x_1); +lean_closure_set(x_642, 7, x_629); +x_643 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_641, x_642, x_3, x_522); +return x_643; +} +} +else +{ +lean_dec(x_629); +lean_dec(x_628); +switch (lean_obj_tag(x_1)) { +case 4: +{ +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_21); +if (lean_obj_tag(x_2) == 4) +{ +lean_object* x_824; lean_object* x_825; lean_object* x_826; +x_824 = lean_ctor_get(x_1, 1); +lean_inc(x_824); +lean_dec(x_1); +x_825 = lean_ctor_get(x_2, 1); +lean_inc(x_825); +lean_dec(x_2); +x_826 = l_Lean_Meta_isListLevelDefEqAux___main(x_824, x_825, x_3, x_522); +lean_dec(x_3); +if (lean_obj_tag(x_826) == 0) +{ +lean_object* x_827; lean_object* x_828; lean_object* x_829; uint8_t x_830; uint8_t x_831; lean_object* x_832; lean_object* x_833; +x_827 = lean_ctor_get(x_826, 0); +lean_inc(x_827); +x_828 = lean_ctor_get(x_826, 1); +lean_inc(x_828); +if (lean_is_exclusive(x_826)) { + lean_ctor_release(x_826, 0); + lean_ctor_release(x_826, 1); + x_829 = x_826; +} else { + lean_dec_ref(x_826); + x_829 = lean_box(0); +} +x_830 = lean_unbox(x_827); +lean_dec(x_827); +x_831 = l_Bool_toLBool(x_830); +x_832 = lean_box(x_831); +if (lean_is_scalar(x_829)) { + x_833 = lean_alloc_ctor(0, 2, 0); +} else { + x_833 = x_829; +} +lean_ctor_set(x_833, 0, x_832); +lean_ctor_set(x_833, 1, x_828); +return x_833; +} +else +{ +lean_object* x_834; lean_object* x_835; lean_object* x_836; lean_object* x_837; +x_834 = lean_ctor_get(x_826, 0); +lean_inc(x_834); +x_835 = lean_ctor_get(x_826, 1); +lean_inc(x_835); +if (lean_is_exclusive(x_826)) { + lean_ctor_release(x_826, 0); + lean_ctor_release(x_826, 1); + x_836 = x_826; +} else { + lean_dec_ref(x_826); + x_836 = lean_box(0); +} +if (lean_is_scalar(x_836)) { + x_837 = lean_alloc_ctor(1, 2, 0); +} else { + x_837 = x_836; +} +lean_ctor_set(x_837, 0, x_834); +lean_ctor_set(x_837, 1, x_835); +return x_837; +} +} +else +{ +uint8_t x_838; lean_object* x_839; lean_object* x_840; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_838 = 0; +x_839 = lean_box(x_838); +x_840 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_840, 0, x_839); +lean_ctor_set(x_840, 1, x_522); +return x_840; +} +} +case 5: +{ +if (lean_obj_tag(x_2) == 5) +{ +lean_object* x_841; uint8_t x_842; +x_841 = lean_ctor_get(x_522, 4); +lean_inc(x_841); +x_842 = lean_ctor_get_uint8(x_841, sizeof(void*)*1); +lean_dec(x_841); +if (x_842 == 0) +{ +uint8_t x_843; +x_843 = 0; +x_540 = x_843; +x_541 = x_522; +goto block_627; +} +else +{ +lean_object* x_844; lean_object* x_845; lean_object* x_846; lean_object* x_847; lean_object* x_848; +x_844 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_845 = l_Lean_Meta_tracer; +x_846 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__6; +x_847 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_844, x_845, x_846); +lean_inc(x_3); +x_848 = lean_apply_2(x_847, x_3, x_522); +if (lean_obj_tag(x_848) == 0) +{ +lean_object* x_849; lean_object* x_850; uint8_t x_851; +x_849 = lean_ctor_get(x_848, 0); +lean_inc(x_849); +x_850 = lean_ctor_get(x_848, 1); +lean_inc(x_850); +lean_dec(x_848); +x_851 = lean_unbox(x_849); +lean_dec(x_849); +x_540 = x_851; +x_541 = x_850; +goto block_627; +} +else +{ +lean_object* x_852; lean_object* x_853; lean_object* x_854; lean_object* x_855; +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_852 = lean_ctor_get(x_848, 0); +lean_inc(x_852); +x_853 = lean_ctor_get(x_848, 1); +lean_inc(x_853); +if (lean_is_exclusive(x_848)) { + lean_ctor_release(x_848, 0); + lean_ctor_release(x_848, 1); + x_854 = x_848; +} else { + lean_dec_ref(x_848); + x_854 = lean_box(0); +} +if (lean_is_scalar(x_854)) { + x_855 = lean_alloc_ctor(1, 2, 0); +} else { + x_855 = x_854; +} +lean_ctor_set(x_855, 0, x_852); +lean_ctor_set(x_855, 1, x_853); +return x_855; +} +} +} +else +{ +uint8_t x_856; lean_object* x_857; lean_object* x_858; +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_856 = 0; +x_857 = lean_box(x_856); +x_858 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_858, 0, x_857); +lean_ctor_set(x_858, 1, x_522); +return x_858; +} +} +default: +{ +uint8_t x_859; lean_object* x_860; lean_object* x_861; +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_859 = 0; +x_860 = lean_box(x_859); +x_861 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_861, 0, x_860); +lean_ctor_set(x_861, 1, x_522); +return x_861; +} +} +} +block_539: +{ +if (x_526 == 0) +{ +lean_object* x_528; lean_object* x_529; lean_object* x_530; lean_object* x_531; lean_object* x_532; lean_object* x_533; lean_object* x_534; lean_object* x_535; +lean_dec(x_523); +x_528 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_529 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_530 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +lean_inc(x_1); +x_531 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___boxed), 8, 5); +lean_closure_set(x_531, 0, x_1); +lean_closure_set(x_531, 1, x_525); +lean_closure_set(x_531, 2, x_528); +lean_closure_set(x_531, 3, x_529); +lean_closure_set(x_531, 4, x_530); +x_532 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__5; +lean_inc(x_2); +x_533 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 3); +lean_closure_set(x_533, 0, x_2); +lean_closure_set(x_533, 1, x_532); +lean_closure_set(x_533, 2, x_531); +x_534 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__8___boxed), 9, 6); +lean_closure_set(x_534, 0, x_524); +lean_closure_set(x_534, 1, x_528); +lean_closure_set(x_534, 2, x_529); +lean_closure_set(x_534, 3, x_20); +lean_closure_set(x_534, 4, x_530); +lean_closure_set(x_534, 5, x_2); +x_535 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_533, x_534, x_3, x_527); +return x_535; +} +else +{ +uint8_t x_536; lean_object* x_537; lean_object* x_538; +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_536 = 1; +x_537 = lean_box(x_536); +if (lean_is_scalar(x_523)) { + x_538 = lean_alloc_ctor(0, 2, 0); +} else { + x_538 = x_523; +} +lean_ctor_set(x_538, 0, x_537); +lean_ctor_set(x_538, 1, x_527); +return x_538; +} +} +block_627: +{ +if (x_540 == 0) +{ +lean_object* x_542; lean_object* x_543; lean_object* x_544; lean_object* x_545; lean_object* x_546; lean_object* x_547; lean_object* x_548; lean_object* x_549; lean_object* x_550; uint8_t x_551; lean_object* x_552; lean_object* x_553; lean_object* x_554; +x_542 = lean_ctor_get(x_541, 4); +lean_inc(x_542); +x_543 = lean_ctor_get(x_541, 0); +lean_inc(x_543); +x_544 = lean_ctor_get(x_541, 1); +lean_inc(x_544); +x_545 = lean_ctor_get(x_541, 2); +lean_inc(x_545); +x_546 = lean_ctor_get(x_541, 3); +lean_inc(x_546); +x_547 = lean_ctor_get(x_541, 5); +lean_inc(x_547); +if (lean_is_exclusive(x_541)) { + lean_ctor_release(x_541, 0); + lean_ctor_release(x_541, 1); + lean_ctor_release(x_541, 2); + lean_ctor_release(x_541, 3); + lean_ctor_release(x_541, 4); + lean_ctor_release(x_541, 5); + x_548 = x_541; +} else { + lean_dec_ref(x_541); + x_548 = lean_box(0); +} +x_549 = lean_ctor_get(x_542, 0); +lean_inc(x_549); +if (lean_is_exclusive(x_542)) { + lean_ctor_release(x_542, 0); + x_550 = x_542; +} else { + lean_dec_ref(x_542); + x_550 = lean_box(0); +} +x_551 = 1; +if (lean_is_scalar(x_550)) { + x_552 = lean_alloc_ctor(0, 1, 1); +} else { + x_552 = x_550; +} +lean_ctor_set(x_552, 0, x_549); +lean_ctor_set_uint8(x_552, sizeof(void*)*1, x_551); +if (lean_is_scalar(x_548)) { + x_553 = lean_alloc_ctor(0, 6, 0); +} else { + x_553 = x_548; +} +lean_ctor_set(x_553, 0, x_543); +lean_ctor_set(x_553, 1, x_544); +lean_ctor_set(x_553, 2, x_545); +lean_ctor_set(x_553, 3, x_546); +lean_ctor_set(x_553, 4, x_552); +lean_ctor_set(x_553, 5, x_547); +lean_inc(x_3); +x_554 = l_Lean_Meta_try(x_21, x_3, x_553); +if (lean_obj_tag(x_554) == 0) +{ +lean_object* x_555; lean_object* x_556; lean_object* x_557; lean_object* x_558; lean_object* x_559; lean_object* x_560; lean_object* x_561; lean_object* x_562; lean_object* x_563; lean_object* x_564; lean_object* x_565; uint8_t x_566; lean_object* x_567; lean_object* x_568; uint8_t x_569; +x_555 = lean_ctor_get(x_554, 1); +lean_inc(x_555); +x_556 = lean_ctor_get(x_555, 4); +lean_inc(x_556); +x_557 = lean_ctor_get(x_554, 0); +lean_inc(x_557); +lean_dec(x_554); +x_558 = lean_ctor_get(x_555, 0); +lean_inc(x_558); +x_559 = lean_ctor_get(x_555, 1); +lean_inc(x_559); +x_560 = lean_ctor_get(x_555, 2); +lean_inc(x_560); +x_561 = lean_ctor_get(x_555, 3); +lean_inc(x_561); +x_562 = lean_ctor_get(x_555, 5); +lean_inc(x_562); +if (lean_is_exclusive(x_555)) { + lean_ctor_release(x_555, 0); + lean_ctor_release(x_555, 1); + lean_ctor_release(x_555, 2); + lean_ctor_release(x_555, 3); + lean_ctor_release(x_555, 4); + lean_ctor_release(x_555, 5); + x_563 = x_555; +} else { + lean_dec_ref(x_555); + x_563 = lean_box(0); +} +x_564 = lean_ctor_get(x_556, 0); +lean_inc(x_564); +if (lean_is_exclusive(x_556)) { + lean_ctor_release(x_556, 0); + x_565 = x_556; +} else { + lean_dec_ref(x_556); + x_565 = lean_box(0); +} +x_566 = 0; +if (lean_is_scalar(x_565)) { + x_567 = lean_alloc_ctor(0, 1, 1); +} else { + x_567 = x_565; +} +lean_ctor_set(x_567, 0, x_564); +lean_ctor_set_uint8(x_567, sizeof(void*)*1, x_566); +if (lean_is_scalar(x_563)) { + x_568 = lean_alloc_ctor(0, 6, 0); +} else { + x_568 = x_563; +} +lean_ctor_set(x_568, 0, x_558); +lean_ctor_set(x_568, 1, x_559); +lean_ctor_set(x_568, 2, x_560); +lean_ctor_set(x_568, 3, x_561); +lean_ctor_set(x_568, 4, x_567); +lean_ctor_set(x_568, 5, x_562); +x_569 = lean_unbox(x_557); +lean_dec(x_557); +x_526 = x_569; +x_527 = x_568; +goto block_539; +} +else +{ +lean_object* x_570; lean_object* x_571; lean_object* x_572; lean_object* x_573; lean_object* x_574; lean_object* x_575; lean_object* x_576; lean_object* x_577; lean_object* x_578; lean_object* x_579; lean_object* x_580; lean_object* x_581; uint8_t x_582; lean_object* x_583; lean_object* x_584; lean_object* x_585; +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_570 = lean_ctor_get(x_554, 1); +lean_inc(x_570); +x_571 = lean_ctor_get(x_570, 4); +lean_inc(x_571); +x_572 = lean_ctor_get(x_554, 0); +lean_inc(x_572); +if (lean_is_exclusive(x_554)) { + lean_ctor_release(x_554, 0); + lean_ctor_release(x_554, 1); + x_573 = x_554; +} else { + lean_dec_ref(x_554); + x_573 = lean_box(0); +} +x_574 = lean_ctor_get(x_570, 0); +lean_inc(x_574); +x_575 = lean_ctor_get(x_570, 1); +lean_inc(x_575); +x_576 = lean_ctor_get(x_570, 2); +lean_inc(x_576); +x_577 = lean_ctor_get(x_570, 3); +lean_inc(x_577); +x_578 = lean_ctor_get(x_570, 5); +lean_inc(x_578); +if (lean_is_exclusive(x_570)) { + lean_ctor_release(x_570, 0); + lean_ctor_release(x_570, 1); + lean_ctor_release(x_570, 2); + lean_ctor_release(x_570, 3); + lean_ctor_release(x_570, 4); + lean_ctor_release(x_570, 5); + x_579 = x_570; +} else { + lean_dec_ref(x_570); + x_579 = lean_box(0); +} +x_580 = lean_ctor_get(x_571, 0); +lean_inc(x_580); +if (lean_is_exclusive(x_571)) { + lean_ctor_release(x_571, 0); + x_581 = x_571; +} else { + lean_dec_ref(x_571); + x_581 = lean_box(0); +} +x_582 = 0; +if (lean_is_scalar(x_581)) { + x_583 = lean_alloc_ctor(0, 1, 1); +} else { + x_583 = x_581; +} +lean_ctor_set(x_583, 0, x_580); +lean_ctor_set_uint8(x_583, sizeof(void*)*1, x_582); +if (lean_is_scalar(x_579)) { + x_584 = lean_alloc_ctor(0, 6, 0); +} else { + x_584 = x_579; +} +lean_ctor_set(x_584, 0, x_574); +lean_ctor_set(x_584, 1, x_575); +lean_ctor_set(x_584, 2, x_576); +lean_ctor_set(x_584, 3, x_577); +lean_ctor_set(x_584, 4, x_583); +lean_ctor_set(x_584, 5, x_578); +if (lean_is_scalar(x_573)) { + x_585 = lean_alloc_ctor(1, 2, 0); +} else { + x_585 = x_573; +} +lean_ctor_set(x_585, 0, x_572); +lean_ctor_set(x_585, 1, x_584); +return x_585; +} +} +else +{ +lean_object* x_586; lean_object* x_587; lean_object* x_588; lean_object* x_589; +x_586 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_587 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1; +x_588 = l___private_Init_Lean_Trace_2__getResetTraces___rarg(x_586, x_587); +lean_inc(x_3); +x_589 = lean_apply_2(x_588, x_3, x_541); +if (lean_obj_tag(x_589) == 0) +{ +lean_object* x_590; lean_object* x_591; lean_object* x_592; +x_590 = lean_ctor_get(x_589, 0); +lean_inc(x_590); +x_591 = lean_ctor_get(x_589, 1); +lean_inc(x_591); +lean_dec(x_589); +lean_inc(x_3); +x_592 = l_Lean_Meta_try(x_21, x_3, x_591); +if (lean_obj_tag(x_592) == 0) +{ +lean_object* x_593; lean_object* x_594; lean_object* x_595; lean_object* x_596; lean_object* x_597; +x_593 = lean_ctor_get(x_592, 0); +lean_inc(x_593); +x_594 = lean_ctor_get(x_592, 1); +lean_inc(x_594); +lean_dec(x_592); +x_595 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +lean_inc(x_590); +x_596 = l___private_Init_Lean_Trace_1__addNode___rarg(x_587, x_590, x_595); +lean_inc(x_3); +x_597 = lean_apply_2(x_596, x_3, x_594); +if (lean_obj_tag(x_597) == 0) +{ +lean_object* x_598; uint8_t x_599; +lean_dec(x_590); +x_598 = lean_ctor_get(x_597, 1); +lean_inc(x_598); +lean_dec(x_597); +x_599 = lean_unbox(x_593); +lean_dec(x_593); +x_526 = x_599; +x_527 = x_598; +goto block_539; +} +else +{ +lean_object* x_600; lean_object* x_601; lean_object* x_602; lean_object* x_603; +lean_dec(x_593); +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_2); +lean_dec(x_1); +x_600 = lean_ctor_get(x_597, 0); +lean_inc(x_600); +x_601 = lean_ctor_get(x_597, 1); +lean_inc(x_601); +lean_dec(x_597); +x_602 = l___private_Init_Lean_Trace_1__addNode___rarg(x_587, x_590, x_595); +x_603 = lean_apply_2(x_602, x_3, x_601); +if (lean_obj_tag(x_603) == 0) +{ +lean_object* x_604; lean_object* x_605; lean_object* x_606; +x_604 = lean_ctor_get(x_603, 1); +lean_inc(x_604); +if (lean_is_exclusive(x_603)) { + lean_ctor_release(x_603, 0); + lean_ctor_release(x_603, 1); + x_605 = x_603; +} else { + lean_dec_ref(x_603); + x_605 = lean_box(0); +} +if (lean_is_scalar(x_605)) { + x_606 = lean_alloc_ctor(1, 2, 0); +} else { + x_606 = x_605; + lean_ctor_set_tag(x_606, 1); +} +lean_ctor_set(x_606, 0, x_600); +lean_ctor_set(x_606, 1, x_604); +return x_606; +} +else +{ +lean_object* x_607; lean_object* x_608; lean_object* x_609; lean_object* x_610; +lean_dec(x_600); +x_607 = lean_ctor_get(x_603, 0); +lean_inc(x_607); +x_608 = lean_ctor_get(x_603, 1); +lean_inc(x_608); +if (lean_is_exclusive(x_603)) { + lean_ctor_release(x_603, 0); + lean_ctor_release(x_603, 1); + x_609 = x_603; +} else { + lean_dec_ref(x_603); + x_609 = lean_box(0); +} +if (lean_is_scalar(x_609)) { + x_610 = lean_alloc_ctor(1, 2, 0); +} else { + x_610 = x_609; +} +lean_ctor_set(x_610, 0, x_607); +lean_ctor_set(x_610, 1, x_608); +return x_610; +} +} +} +else +{ +lean_object* x_611; lean_object* x_612; lean_object* x_613; lean_object* x_614; lean_object* x_615; +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_2); +lean_dec(x_1); +x_611 = lean_ctor_get(x_592, 0); +lean_inc(x_611); +x_612 = lean_ctor_get(x_592, 1); +lean_inc(x_612); +lean_dec(x_592); +x_613 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3; +x_614 = l___private_Init_Lean_Trace_1__addNode___rarg(x_587, x_590, x_613); +x_615 = lean_apply_2(x_614, x_3, x_612); +if (lean_obj_tag(x_615) == 0) +{ +lean_object* x_616; lean_object* x_617; lean_object* x_618; +x_616 = lean_ctor_get(x_615, 1); +lean_inc(x_616); +if (lean_is_exclusive(x_615)) { + lean_ctor_release(x_615, 0); + lean_ctor_release(x_615, 1); + x_617 = x_615; +} else { + lean_dec_ref(x_615); + x_617 = lean_box(0); +} +if (lean_is_scalar(x_617)) { + x_618 = lean_alloc_ctor(1, 2, 0); +} else { + x_618 = x_617; + lean_ctor_set_tag(x_618, 1); +} +lean_ctor_set(x_618, 0, x_611); +lean_ctor_set(x_618, 1, x_616); +return x_618; +} +else +{ +lean_object* x_619; lean_object* x_620; lean_object* x_621; lean_object* x_622; +lean_dec(x_611); +x_619 = lean_ctor_get(x_615, 0); +lean_inc(x_619); +x_620 = lean_ctor_get(x_615, 1); +lean_inc(x_620); +if (lean_is_exclusive(x_615)) { + lean_ctor_release(x_615, 0); + lean_ctor_release(x_615, 1); + x_621 = x_615; +} else { + lean_dec_ref(x_615); + x_621 = lean_box(0); +} +if (lean_is_scalar(x_621)) { + x_622 = lean_alloc_ctor(1, 2, 0); +} else { + x_622 = x_621; +} +lean_ctor_set(x_622, 0, x_619); +lean_ctor_set(x_622, 1, x_620); +return x_622; +} +} +} +else +{ +lean_object* x_623; lean_object* x_624; lean_object* x_625; lean_object* x_626; +lean_dec(x_525); +lean_dec(x_524); +lean_dec(x_523); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_623 = lean_ctor_get(x_589, 0); +lean_inc(x_623); +x_624 = lean_ctor_get(x_589, 1); +lean_inc(x_624); +if (lean_is_exclusive(x_589)) { + lean_ctor_release(x_589, 0); + lean_ctor_release(x_589, 1); + x_625 = x_589; +} else { + lean_dec_ref(x_589); + x_625 = lean_box(0); +} +if (lean_is_scalar(x_625)) { + x_626 = lean_alloc_ctor(1, 2, 0); +} else { + x_626 = x_625; +} +lean_ctor_set(x_626, 0, x_623); +lean_ctor_set(x_626, 1, x_624); +return x_626; +} +} +} +} +} +} +else +{ +lean_object* x_862; lean_object* x_863; lean_object* x_864; lean_object* x_865; +lean_dec(x_496); +lean_dec(x_21); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_862 = lean_ctor_get(x_498, 0); +lean_inc(x_862); +x_863 = lean_ctor_get(x_498, 1); +lean_inc(x_863); +if (lean_is_exclusive(x_498)) { + lean_ctor_release(x_498, 0); + lean_ctor_release(x_498, 1); + x_864 = x_498; +} else { + lean_dec_ref(x_498); + x_864 = lean_box(0); +} +if (lean_is_scalar(x_864)) { + x_865 = lean_alloc_ctor(1, 2, 0); +} else { + x_865 = x_864; +} +lean_ctor_set(x_865, 0, x_862); +lean_ctor_set(x_865, 1, x_863); +return x_865; +} +} +} +else +{ +uint8_t x_866; +lean_dec(x_21); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_866 = !lean_is_exclusive(x_22); +if (x_866 == 0) +{ +return x_22; +} +else +{ +lean_object* x_867; lean_object* x_868; lean_object* x_869; +x_867 = lean_ctor_get(x_22, 0); +x_868 = lean_ctor_get(x_22, 1); +lean_inc(x_868); +lean_inc(x_867); +lean_dec(x_22); +x_869 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_869, 0, x_867); +lean_ctor_set(x_869, 1, x_868); +return x_869; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = lean_unbox(x_3); +lean_dec(x_3); +x_7 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__1(x_1, x_2, x_6, x_4, x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +return x_7; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_9; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_2); +return x_9; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__4(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +uint8_t x_7; lean_object* x_8; +x_7 = lean_unbox(x_4); +lean_dec(x_4); +x_8 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__5(x_1, x_2, x_3, x_7, x_5, x_6); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__6(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +return x_6; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +lean_object* x_10; +x_10 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__8(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_1); +return x_10; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_22__isAssigned(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +if (lean_obj_tag(x_1) == 2) +{ +lean_object* x_4; lean_object* x_5; uint8_t x_6; lean_object* x_7; lean_object* x_8; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +lean_dec(x_1); +x_5 = lean_ctor_get(x_3, 1); +lean_inc(x_5); +x_6 = lean_metavar_ctx_is_expr_assigned(x_5, x_4); +x_7 = lean_box(x_6); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_3); +return x_8; +} +else +{ +uint8_t x_9; lean_object* x_10; lean_object* x_11; +lean_dec(x_1); +x_9 = 0; +x_10 = lean_box(x_9); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_3); +return x_11; +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_22__isAssigned___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Init_Lean_Meta_ExprDefEq_22__isAssigned(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_23__isSynthetic(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +if (lean_obj_tag(x_1) == 2) +{ +lean_object* x_4; lean_object* x_5; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +lean_dec(x_1); +x_5 = l_Lean_Meta_isSyntheticExprMVar(x_4, x_2, x_3); +return x_5; +} +else +{ +uint8_t x_6; lean_object* x_7; lean_object* x_8; +lean_dec(x_1); +x_6 = 0; +x_7 = lean_box(x_6); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_3); +return x_8; +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_23__isSynthetic___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Init_Lean_Meta_ExprDefEq_23__isSynthetic(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_24__isAssignable(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +if (lean_obj_tag(x_1) == 2) +{ +lean_object* x_4; lean_object* x_5; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +lean_dec(x_1); +x_5 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_4, x_2, x_3); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_unbox(x_6); +lean_dec(x_6); +if (x_7 == 0) +{ +uint8_t x_8; +x_8 = !lean_is_exclusive(x_5); +if (x_8 == 0) +{ +lean_object* x_9; uint8_t x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_5, 0); +lean_dec(x_9); +x_10 = 1; +x_11 = lean_box(x_10); +lean_ctor_set(x_5, 0, x_11); +return x_5; +} +else +{ +lean_object* x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; +x_12 = lean_ctor_get(x_5, 1); +lean_inc(x_12); +lean_dec(x_5); +x_13 = 1; +x_14 = lean_box(x_13); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_12); +return x_15; +} +} +else +{ +uint8_t x_16; +x_16 = !lean_is_exclusive(x_5); +if (x_16 == 0) +{ +lean_object* x_17; uint8_t x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_5, 0); +lean_dec(x_17); +x_18 = 0; +x_19 = lean_box(x_18); +lean_ctor_set(x_5, 0, x_19); +return x_5; +} +else +{ +lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_5, 1); +lean_inc(x_20); +lean_dec(x_5); +x_21 = 0; +x_22 = lean_box(x_21); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_20); +return x_23; +} +} +} +else +{ +uint8_t x_24; +x_24 = !lean_is_exclusive(x_5); +if (x_24 == 0) +{ +return x_5; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_5, 0); +x_26 = lean_ctor_get(x_5, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_5); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +else +{ +uint8_t x_28; lean_object* x_29; lean_object* x_30; +lean_dec(x_1); +x_28 = 0; +x_29 = lean_box(x_28); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_3); +return x_30; +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_24__isAssignable___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l___private_Init_Lean_Meta_ExprDefEq_24__isAssignable(x_1, x_2, x_3); +lean_dec(x_2); +return x_4; +} +} +uint8_t l___private_Init_Lean_Meta_ExprDefEq_25__etaEq(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; +x_3 = lean_unsigned_to_nat(0u); +x_4 = l___private_Init_Lean_Expr_9__etaExpandedAux___main(x_1, x_3); +if (lean_obj_tag(x_4) == 0) +{ +uint8_t x_5; +x_5 = 0; +return x_5; +} +else +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_4, 0); +lean_inc(x_6); +lean_dec(x_4); +x_7 = lean_expr_eqv(x_6, x_2); +lean_dec(x_6); +return x_7; +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_25__etaEq___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +uint8_t x_3; lean_object* x_4; +x_3 = l___private_Init_Lean_Meta_ExprDefEq_25__etaEq(x_1, x_2); +lean_dec(x_2); +x_4 = lean_box(x_3); +return x_4; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_26__isLetFVar(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_getLocalDecl(x_1, x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +uint8_t x_5; +x_5 = !lean_is_exclusive(x_4); +if (x_5 == 0) +{ +lean_object* x_6; uint8_t x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_4, 0); +x_7 = l_Lean_LocalDecl_isLet(x_6); +lean_dec(x_6); +x_8 = lean_box(x_7); +lean_ctor_set(x_4, 0, x_8); +return x_4; +} +else +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; lean_object* x_13; +x_9 = lean_ctor_get(x_4, 0); +x_10 = lean_ctor_get(x_4, 1); +lean_inc(x_10); +lean_inc(x_9); +lean_dec(x_4); +x_11 = l_Lean_LocalDecl_isLet(x_9); +lean_dec(x_9); +x_12 = lean_box(x_11); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_10); +return x_13; +} +} +else +{ +uint8_t x_14; +x_14 = !lean_is_exclusive(x_4); +if (x_14 == 0) +{ +return x_4; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_4, 0); +x_16 = lean_ctor_get(x_4, 1); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_4); +x_17 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_17, 0, x_15); +lean_ctor_set(x_17, 1, x_16); +return x_17; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_407; +switch (lean_obj_tag(x_1)) { +case 1: +{ +switch (lean_obj_tag(x_2)) { +case 1: +{ +lean_object* x_427; lean_object* x_428; lean_object* x_429; +x_427 = lean_ctor_get(x_1, 0); +lean_inc(x_427); +lean_dec(x_1); +x_428 = lean_ctor_get(x_2, 0); +lean_inc(x_428); +lean_dec(x_2); +lean_inc(x_3); +lean_inc(x_427); +x_429 = l___private_Init_Lean_Meta_ExprDefEq_26__isLetFVar(x_427, x_3, x_4); +if (lean_obj_tag(x_429) == 0) +{ +lean_object* x_430; uint8_t x_431; +x_430 = lean_ctor_get(x_429, 0); +lean_inc(x_430); +x_431 = lean_unbox(x_430); +lean_dec(x_430); +if (x_431 == 0) +{ +lean_object* x_432; lean_object* x_433; +x_432 = lean_ctor_get(x_429, 1); +lean_inc(x_432); +lean_dec(x_429); +lean_inc(x_428); +x_433 = l___private_Init_Lean_Meta_ExprDefEq_26__isLetFVar(x_428, x_3, x_432); +if (lean_obj_tag(x_433) == 0) +{ +lean_object* x_434; uint8_t x_435; +x_434 = lean_ctor_get(x_433, 0); +lean_inc(x_434); +x_435 = lean_unbox(x_434); +lean_dec(x_434); +if (x_435 == 0) +{ +uint8_t x_436; +x_436 = !lean_is_exclusive(x_433); +if (x_436 == 0) +{ +lean_object* x_437; uint8_t x_438; uint8_t x_439; lean_object* x_440; +x_437 = lean_ctor_get(x_433, 0); +lean_dec(x_437); +x_438 = lean_name_eq(x_427, x_428); +lean_dec(x_428); +lean_dec(x_427); +x_439 = l_Bool_toLBool(x_438); +x_440 = lean_box(x_439); +lean_ctor_set(x_433, 0, x_440); +return x_433; +} +else +{ +lean_object* x_441; uint8_t x_442; uint8_t x_443; lean_object* x_444; lean_object* x_445; +x_441 = lean_ctor_get(x_433, 1); +lean_inc(x_441); +lean_dec(x_433); +x_442 = lean_name_eq(x_427, x_428); +lean_dec(x_428); +lean_dec(x_427); +x_443 = l_Bool_toLBool(x_442); +x_444 = lean_box(x_443); +x_445 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_445, 0, x_444); +lean_ctor_set(x_445, 1, x_441); +return x_445; +} +} +else +{ +uint8_t x_446; +lean_dec(x_428); +lean_dec(x_427); +x_446 = !lean_is_exclusive(x_433); +if (x_446 == 0) +{ +lean_object* x_447; uint8_t x_448; lean_object* x_449; +x_447 = lean_ctor_get(x_433, 0); +lean_dec(x_447); +x_448 = 2; +x_449 = lean_box(x_448); +lean_ctor_set(x_433, 0, x_449); +return x_433; +} +else +{ +lean_object* x_450; uint8_t x_451; lean_object* x_452; lean_object* x_453; +x_450 = lean_ctor_get(x_433, 1); +lean_inc(x_450); +lean_dec(x_433); +x_451 = 2; +x_452 = lean_box(x_451); +x_453 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_453, 0, x_452); +lean_ctor_set(x_453, 1, x_450); +return x_453; +} +} +} +else +{ +uint8_t x_454; +lean_dec(x_428); +lean_dec(x_427); +x_454 = !lean_is_exclusive(x_433); +if (x_454 == 0) +{ +return x_433; +} +else +{ +lean_object* x_455; lean_object* x_456; lean_object* x_457; +x_455 = lean_ctor_get(x_433, 0); +x_456 = lean_ctor_get(x_433, 1); +lean_inc(x_456); +lean_inc(x_455); +lean_dec(x_433); +x_457 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_457, 0, x_455); +lean_ctor_set(x_457, 1, x_456); +return x_457; +} +} +} +else +{ +uint8_t x_458; +lean_dec(x_428); +lean_dec(x_427); +lean_dec(x_3); +x_458 = !lean_is_exclusive(x_429); +if (x_458 == 0) +{ +lean_object* x_459; uint8_t x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_429, 0); +lean_dec(x_459); +x_460 = 2; +x_461 = lean_box(x_460); +lean_ctor_set(x_429, 0, x_461); +return x_429; +} +else +{ +lean_object* x_462; uint8_t x_463; lean_object* x_464; lean_object* x_465; +x_462 = lean_ctor_get(x_429, 1); +lean_inc(x_462); +lean_dec(x_429); +x_463 = 2; +x_464 = lean_box(x_463); +x_465 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_465, 0, x_464); +lean_ctor_set(x_465, 1, x_462); +return x_465; +} +} +} +else +{ +uint8_t x_466; +lean_dec(x_428); +lean_dec(x_427); +lean_dec(x_3); +x_466 = !lean_is_exclusive(x_429); +if (x_466 == 0) +{ +return x_429; +} +else +{ +lean_object* x_467; lean_object* x_468; lean_object* x_469; +x_467 = lean_ctor_get(x_429, 0); +x_468 = lean_ctor_get(x_429, 1); +lean_inc(x_468); +lean_inc(x_467); +lean_dec(x_429); +x_469 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_469, 0, x_467); +lean_ctor_set(x_469, 1, x_468); +return x_469; +} +} +} +case 10: +{ +lean_object* x_470; +x_470 = lean_ctor_get(x_2, 1); +lean_inc(x_470); +lean_dec(x_2); +x_2 = x_470; +goto _start; +} +default: +{ +lean_object* x_472; +x_472 = lean_box(0); +x_5 = x_472; +goto block_406; +} +} +} +case 3: +{ +switch (lean_obj_tag(x_2)) { +case 3: +{ +lean_object* x_473; lean_object* x_474; lean_object* x_475; +x_473 = lean_ctor_get(x_1, 0); +lean_inc(x_473); +lean_dec(x_1); +x_474 = lean_ctor_get(x_2, 0); +lean_inc(x_474); +lean_dec(x_2); +x_475 = l_Lean_Meta_isLevelDefEqAux___main(x_473, x_474, x_3, x_4); +lean_dec(x_3); +if (lean_obj_tag(x_475) == 0) +{ +uint8_t x_476; +x_476 = !lean_is_exclusive(x_475); +if (x_476 == 0) +{ +lean_object* x_477; uint8_t x_478; uint8_t x_479; lean_object* x_480; +x_477 = lean_ctor_get(x_475, 0); +x_478 = lean_unbox(x_477); +lean_dec(x_477); +x_479 = l_Bool_toLBool(x_478); +x_480 = lean_box(x_479); +lean_ctor_set(x_475, 0, x_480); +return x_475; +} +else +{ +lean_object* x_481; lean_object* x_482; uint8_t x_483; uint8_t x_484; lean_object* x_485; lean_object* x_486; +x_481 = lean_ctor_get(x_475, 0); +x_482 = lean_ctor_get(x_475, 1); +lean_inc(x_482); +lean_inc(x_481); +lean_dec(x_475); +x_483 = lean_unbox(x_481); +lean_dec(x_481); +x_484 = l_Bool_toLBool(x_483); +x_485 = lean_box(x_484); +x_486 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_486, 0, x_485); +lean_ctor_set(x_486, 1, x_482); +return x_486; +} +} +else +{ +uint8_t x_487; +x_487 = !lean_is_exclusive(x_475); +if (x_487 == 0) +{ +return x_475; +} +else +{ +lean_object* x_488; lean_object* x_489; lean_object* x_490; +x_488 = lean_ctor_get(x_475, 0); +x_489 = lean_ctor_get(x_475, 1); +lean_inc(x_489); +lean_inc(x_488); +lean_dec(x_475); +x_490 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_490, 0, x_488); +lean_ctor_set(x_490, 1, x_489); +return x_490; +} +} +} +case 10: +{ +lean_object* x_491; +x_491 = lean_ctor_get(x_2, 1); +lean_inc(x_491); +lean_dec(x_2); +x_2 = x_491; +goto _start; +} +default: +{ +lean_object* x_493; +x_493 = lean_box(0); +x_5 = x_493; +goto block_406; +} +} +} +case 6: +{ +switch (lean_obj_tag(x_2)) { +case 6: +{ +lean_object* x_494; +x_494 = lean_box(0); +x_407 = x_494; +goto block_426; +} +case 10: +{ +lean_object* x_495; +x_495 = lean_ctor_get(x_2, 1); +lean_inc(x_495); +lean_dec(x_2); +x_2 = x_495; +goto _start; +} +default: +{ +lean_object* x_497; +x_497 = lean_box(0); +x_5 = x_497; +goto block_406; +} +} +} +case 7: +{ +switch (lean_obj_tag(x_2)) { +case 7: +{ +lean_object* x_498; +x_498 = lean_box(0); +x_407 = x_498; +goto block_426; +} +case 10: +{ +lean_object* x_499; +x_499 = lean_ctor_get(x_2, 1); +lean_inc(x_499); +lean_dec(x_2); +x_2 = x_499; +goto _start; +} +default: +{ +lean_object* x_501; +x_501 = lean_box(0); +x_5 = x_501; +goto block_406; +} +} +} +case 9: +{ +switch (lean_obj_tag(x_2)) { +case 9: +{ +lean_object* x_502; lean_object* x_503; uint8_t x_504; uint8_t x_505; lean_object* x_506; lean_object* x_507; +lean_dec(x_3); +x_502 = lean_ctor_get(x_1, 0); +lean_inc(x_502); +lean_dec(x_1); +x_503 = lean_ctor_get(x_2, 0); +lean_inc(x_503); +lean_dec(x_2); +x_504 = l_Lean_Literal_beq(x_502, x_503); +lean_dec(x_503); +lean_dec(x_502); +x_505 = l_Bool_toLBool(x_504); +x_506 = lean_box(x_505); +x_507 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_507, 0, x_506); +lean_ctor_set(x_507, 1, x_4); +return x_507; +} +case 10: +{ +lean_object* x_508; +x_508 = lean_ctor_get(x_2, 1); +lean_inc(x_508); +lean_dec(x_2); +x_2 = x_508; +goto _start; +} +default: +{ +lean_object* x_510; +x_510 = lean_box(0); +x_5 = x_510; +goto block_406; +} +} +} +case 10: +{ +lean_object* x_511; +x_511 = lean_ctor_get(x_1, 1); +lean_inc(x_511); +lean_dec(x_1); +x_1 = x_511; +goto _start; +} +default: +{ +if (lean_obj_tag(x_2) == 10) +{ +lean_object* x_513; +x_513 = lean_ctor_get(x_2, 1); +lean_inc(x_513); +lean_dec(x_2); +x_2 = x_513; +goto _start; +} +else +{ +lean_object* x_515; +x_515 = lean_box(0); +x_5 = x_515; +goto block_406; +} +} +} +block_406: +{ +uint8_t x_6; +lean_dec(x_5); +x_6 = lean_expr_eqv(x_1, x_2); +if (x_6 == 0) +{ +uint8_t x_7; +lean_inc(x_1); +x_7 = l___private_Init_Lean_Meta_ExprDefEq_25__etaEq(x_1, x_2); +if (x_7 == 0) +{ +uint8_t x_8; +lean_inc(x_2); +x_8 = l___private_Init_Lean_Meta_ExprDefEq_25__etaEq(x_2, x_1); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; +x_9 = l_Lean_Expr_getAppFn___main(x_1); +x_10 = l_Lean_Expr_getAppFn___main(x_2); +x_11 = l_Lean_Expr_isMVar(x_9); +if (x_11 == 0) +{ +uint8_t x_391; +x_391 = l_Lean_Expr_isMVar(x_10); +if (x_391 == 0) +{ +uint8_t x_392; lean_object* x_393; lean_object* x_394; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_392 = 2; +x_393 = lean_box(x_392); +x_394 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_394, 0, x_393); +lean_ctor_set(x_394, 1, x_4); +return x_394; +} +else +{ +lean_object* x_395; +x_395 = lean_box(0); +x_12 = x_395; +goto block_390; +} +} +else +{ +lean_object* x_396; +x_396 = lean_box(0); +x_12 = x_396; +goto block_390; +} +block_390: +{ +lean_object* x_13; lean_object* x_14; uint8_t x_15; +lean_dec(x_12); +lean_inc(x_9); +x_13 = l___private_Init_Lean_Meta_ExprDefEq_22__isAssigned(x_9, x_3, x_4); +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_unbox(x_14); +lean_dec(x_14); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; uint8_t x_20; lean_object* x_21; uint8_t x_362; +x_16 = lean_ctor_get(x_13, 1); +lean_inc(x_16); +lean_dec(x_13); +lean_inc(x_10); +x_17 = l___private_Init_Lean_Meta_ExprDefEq_22__isAssigned(x_10, x_3, x_16); +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +lean_dec(x_17); +x_362 = lean_unbox(x_18); +lean_dec(x_18); +if (x_362 == 0) +{ +lean_object* x_363; +lean_inc(x_9); +x_363 = l___private_Init_Lean_Meta_ExprDefEq_23__isSynthetic(x_9, x_3, x_19); +if (lean_obj_tag(x_363) == 0) +{ +lean_object* x_364; uint8_t x_365; +x_364 = lean_ctor_get(x_363, 0); +lean_inc(x_364); +x_365 = lean_unbox(x_364); +if (x_365 == 0) +{ +lean_object* x_366; uint8_t x_367; +x_366 = lean_ctor_get(x_363, 1); +lean_inc(x_366); +lean_dec(x_363); +x_367 = lean_unbox(x_364); +lean_dec(x_364); +x_20 = x_367; +x_21 = x_366; +goto block_361; +} +else +{ +lean_object* x_368; lean_object* x_369; +lean_dec(x_364); +x_368 = lean_ctor_get(x_363, 1); +lean_inc(x_368); +lean_dec(x_363); +lean_inc(x_3); +lean_inc(x_9); +x_369 = l_Lean_Meta_synthPending(x_9, x_3, x_368); +if (lean_obj_tag(x_369) == 0) +{ +lean_object* x_370; lean_object* x_371; uint8_t x_372; +x_370 = lean_ctor_get(x_369, 0); +lean_inc(x_370); +x_371 = lean_ctor_get(x_369, 1); +lean_inc(x_371); +lean_dec(x_369); +x_372 = lean_unbox(x_370); +lean_dec(x_370); +x_20 = x_372; +x_21 = x_371; +goto block_361; +} +else +{ +uint8_t x_373; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_373 = !lean_is_exclusive(x_369); +if (x_373 == 0) +{ +return x_369; +} +else +{ +lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_374 = lean_ctor_get(x_369, 0); +x_375 = lean_ctor_get(x_369, 1); +lean_inc(x_375); +lean_inc(x_374); +lean_dec(x_369); +x_376 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_376, 0, x_374); +lean_ctor_set(x_376, 1, x_375); +return x_376; +} +} +} +} +else +{ +uint8_t x_377; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_377 = !lean_is_exclusive(x_363); +if (x_377 == 0) +{ +return x_363; +} +else +{ +lean_object* x_378; lean_object* x_379; lean_object* x_380; +x_378 = lean_ctor_get(x_363, 0); +x_379 = lean_ctor_get(x_363, 1); +lean_inc(x_379); +lean_inc(x_378); +lean_dec(x_363); +x_380 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_380, 0, x_378); +lean_ctor_set(x_380, 1, x_379); +return x_380; +} +} +} +else +{ +lean_object* x_381; lean_object* x_382; lean_object* x_383; +lean_dec(x_10); +lean_dec(x_9); +x_381 = l_Lean_Meta_instantiateMVars(x_2, x_3, x_19); +x_382 = lean_ctor_get(x_381, 0); +lean_inc(x_382); +x_383 = lean_ctor_get(x_381, 1); +lean_inc(x_383); +lean_dec(x_381); +x_2 = x_382; +x_4 = x_383; +goto _start; +} +block_361: +{ +uint8_t x_22; lean_object* x_23; +if (x_20 == 0) +{ +lean_object* x_339; +lean_inc(x_10); +x_339 = l___private_Init_Lean_Meta_ExprDefEq_23__isSynthetic(x_10, x_3, x_21); +if (lean_obj_tag(x_339) == 0) +{ +lean_object* x_340; uint8_t x_341; +x_340 = lean_ctor_get(x_339, 0); +lean_inc(x_340); +x_341 = lean_unbox(x_340); +if (x_341 == 0) +{ +lean_object* x_342; uint8_t x_343; +x_342 = lean_ctor_get(x_339, 1); +lean_inc(x_342); +lean_dec(x_339); +x_343 = lean_unbox(x_340); +lean_dec(x_340); +x_22 = x_343; +x_23 = x_342; +goto block_338; +} +else +{ +lean_object* x_344; lean_object* x_345; +lean_dec(x_340); +x_344 = lean_ctor_get(x_339, 1); +lean_inc(x_344); +lean_dec(x_339); +lean_inc(x_3); +lean_inc(x_10); +x_345 = l_Lean_Meta_synthPending(x_10, x_3, x_344); +if (lean_obj_tag(x_345) == 0) +{ +lean_object* x_346; lean_object* x_347; uint8_t x_348; +x_346 = lean_ctor_get(x_345, 0); +lean_inc(x_346); +x_347 = lean_ctor_get(x_345, 1); +lean_inc(x_347); +lean_dec(x_345); +x_348 = lean_unbox(x_346); +lean_dec(x_346); +x_22 = x_348; +x_23 = x_347; +goto block_338; +} +else +{ +uint8_t x_349; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_349 = !lean_is_exclusive(x_345); +if (x_349 == 0) +{ +return x_345; +} +else +{ +lean_object* x_350; lean_object* x_351; lean_object* x_352; +x_350 = lean_ctor_get(x_345, 0); +x_351 = lean_ctor_get(x_345, 1); +lean_inc(x_351); +lean_inc(x_350); +lean_dec(x_345); +x_352 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_352, 0, x_350); +lean_ctor_set(x_352, 1, x_351); +return x_352; +} +} +} +} +else +{ +uint8_t x_353; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_353 = !lean_is_exclusive(x_339); +if (x_353 == 0) +{ +return x_339; +} +else +{ +lean_object* x_354; lean_object* x_355; lean_object* x_356; +x_354 = lean_ctor_get(x_339, 0); +x_355 = lean_ctor_get(x_339, 1); +lean_inc(x_355); +lean_inc(x_354); +lean_dec(x_339); +x_356 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_356, 0, x_354); +lean_ctor_set(x_356, 1, x_355); +return x_356; +} +} +} +else +{ +lean_object* x_357; lean_object* x_358; lean_object* x_359; +lean_dec(x_10); +lean_dec(x_9); +x_357 = l_Lean_Meta_instantiateMVars(x_1, x_3, x_21); +x_358 = lean_ctor_get(x_357, 0); +lean_inc(x_358); +x_359 = lean_ctor_get(x_357, 1); +lean_inc(x_359); +lean_dec(x_357); +x_1 = x_358; +x_4 = x_359; +goto _start; +} +block_338: +{ +if (x_22 == 0) +{ +lean_object* x_24; +lean_inc(x_9); +x_24 = l___private_Init_Lean_Meta_ExprDefEq_24__isAssignable(x_9, x_3, x_23); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +lean_inc(x_10); +x_27 = l___private_Init_Lean_Meta_ExprDefEq_24__isAssignable(x_10, x_3, x_26); +if (lean_obj_tag(x_27) == 0) +{ +uint8_t x_28; +x_28 = lean_unbox(x_25); +lean_dec(x_25); +if (x_28 == 0) +{ +lean_object* x_29; uint8_t x_30; +lean_dec(x_9); +x_29 = lean_ctor_get(x_27, 0); +lean_inc(x_29); +x_30 = lean_unbox(x_29); +lean_dec(x_29); +if (x_30 == 0) +{ +if (x_11 == 0) +{ +uint8_t x_31; +x_31 = !lean_is_exclusive(x_27); +if (x_31 == 0) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; +x_32 = lean_ctor_get(x_27, 1); +x_33 = lean_ctor_get(x_27, 0); +lean_dec(x_33); +x_34 = l_Lean_Expr_isMVar(x_10); +lean_dec(x_10); +if (x_34 == 0) +{ +uint8_t x_35; lean_object* x_36; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_35 = 2; +x_36 = lean_box(x_35); +lean_ctor_set(x_27, 0, x_36); +return x_27; +} +else +{ +lean_object* x_37; uint8_t x_38; +x_37 = lean_ctor_get(x_3, 0); +lean_inc(x_37); +x_38 = lean_ctor_get_uint8(x_37, sizeof(void*)*1 + 3); +lean_dec(x_37); +if (x_38 == 0) +{ +uint8_t x_39; lean_object* x_40; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_39 = 0; +x_40 = lean_box(x_39); +lean_ctor_set(x_27, 0, x_40); +return x_27; +} +else +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_41 = lean_ctor_get(x_32, 0); +lean_inc(x_41); +x_42 = lean_ctor_get(x_32, 1); +lean_inc(x_42); +x_43 = lean_ctor_get(x_3, 1); +lean_inc(x_43); +lean_dec(x_3); +x_44 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_44, 0, x_41); +lean_ctor_set(x_44, 1, x_42); +lean_ctor_set(x_44, 2, x_43); +x_45 = lean_alloc_ctor(11, 3, 0); +lean_ctor_set(x_45, 0, x_1); +lean_ctor_set(x_45, 1, x_2); +lean_ctor_set(x_45, 2, x_44); +lean_ctor_set_tag(x_27, 1); +lean_ctor_set(x_27, 0, x_45); +return x_27; +} +} +} +else +{ +lean_object* x_46; uint8_t x_47; +x_46 = lean_ctor_get(x_27, 1); +lean_inc(x_46); +lean_dec(x_27); +x_47 = l_Lean_Expr_isMVar(x_10); +lean_dec(x_10); +if (x_47 == 0) +{ +uint8_t x_48; lean_object* x_49; lean_object* x_50; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_48 = 2; +x_49 = lean_box(x_48); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_49); +lean_ctor_set(x_50, 1, x_46); +return x_50; +} +else +{ +lean_object* x_51; uint8_t x_52; +x_51 = lean_ctor_get(x_3, 0); +lean_inc(x_51); +x_52 = lean_ctor_get_uint8(x_51, sizeof(void*)*1 + 3); +lean_dec(x_51); +if (x_52 == 0) +{ +uint8_t x_53; lean_object* x_54; lean_object* x_55; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_53 = 0; +x_54 = lean_box(x_53); +x_55 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_55, 0, x_54); +lean_ctor_set(x_55, 1, x_46); +return x_55; +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_56 = lean_ctor_get(x_46, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_46, 1); +lean_inc(x_57); +x_58 = lean_ctor_get(x_3, 1); +lean_inc(x_58); +lean_dec(x_3); +x_59 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_59, 0, x_56); +lean_ctor_set(x_59, 1, x_57); +lean_ctor_set(x_59, 2, x_58); +x_60 = lean_alloc_ctor(11, 3, 0); +lean_ctor_set(x_60, 0, x_1); +lean_ctor_set(x_60, 1, x_2); +lean_ctor_set(x_60, 2, x_59); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_60); +lean_ctor_set(x_61, 1, x_46); +return x_61; +} +} +} +} +else +{ +lean_object* x_62; uint8_t x_63; +lean_dec(x_10); +x_62 = lean_ctor_get(x_3, 0); +lean_inc(x_62); +x_63 = lean_ctor_get_uint8(x_62, sizeof(void*)*1 + 3); +lean_dec(x_62); +if (x_63 == 0) +{ +uint8_t x_64; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_64 = !lean_is_exclusive(x_27); +if (x_64 == 0) +{ +lean_object* x_65; uint8_t x_66; lean_object* x_67; +x_65 = lean_ctor_get(x_27, 0); +lean_dec(x_65); +x_66 = 0; +x_67 = lean_box(x_66); +lean_ctor_set(x_27, 0, x_67); +return x_27; +} +else +{ +lean_object* x_68; uint8_t x_69; lean_object* x_70; lean_object* x_71; +x_68 = lean_ctor_get(x_27, 1); +lean_inc(x_68); +lean_dec(x_27); +x_69 = 0; +x_70 = lean_box(x_69); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_70); +lean_ctor_set(x_71, 1, x_68); +return x_71; +} +} +else +{ +uint8_t x_72; +x_72 = !lean_is_exclusive(x_27); +if (x_72 == 0) +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_73 = lean_ctor_get(x_27, 1); +x_74 = lean_ctor_get(x_27, 0); +lean_dec(x_74); +x_75 = lean_ctor_get(x_73, 0); +lean_inc(x_75); +x_76 = lean_ctor_get(x_73, 1); +lean_inc(x_76); +x_77 = lean_ctor_get(x_3, 1); +lean_inc(x_77); +lean_dec(x_3); +x_78 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_78, 0, x_75); +lean_ctor_set(x_78, 1, x_76); +lean_ctor_set(x_78, 2, x_77); +x_79 = lean_alloc_ctor(11, 3, 0); +lean_ctor_set(x_79, 0, x_1); +lean_ctor_set(x_79, 1, x_2); +lean_ctor_set(x_79, 2, x_78); +lean_ctor_set_tag(x_27, 1); +lean_ctor_set(x_27, 0, x_79); +return x_27; +} +else +{ +lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_80 = lean_ctor_get(x_27, 1); +lean_inc(x_80); +lean_dec(x_27); +x_81 = lean_ctor_get(x_80, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_80, 1); +lean_inc(x_82); +x_83 = lean_ctor_get(x_3, 1); +lean_inc(x_83); +lean_dec(x_3); +x_84 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_84, 0, x_81); +lean_ctor_set(x_84, 1, x_82); +lean_ctor_set(x_84, 2, x_83); +x_85 = lean_alloc_ctor(11, 3, 0); +lean_ctor_set(x_85, 0, x_1); +lean_ctor_set(x_85, 1, x_2); +lean_ctor_set(x_85, 2, x_84); +x_86 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_86, 0, x_85); +lean_ctor_set(x_86, 1, x_80); +return x_86; +} +} +} +} +else +{ +lean_object* x_87; lean_object* x_88; +lean_dec(x_10); +x_87 = lean_ctor_get(x_27, 1); +lean_inc(x_87); +lean_dec(x_27); +x_88 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_2, x_1, x_3, x_87); if (lean_obj_tag(x_88) == 0) { uint8_t x_89; @@ -13114,109 +22776,122 @@ return x_103; } } } -else -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_104 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1; -x_105 = lean_name_mk_string(x_4, x_104); -x_106 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_105); -x_107 = l_Lean_Name_append___main(x_106, x_105); -x_108 = l_Lean_Meta_tracer; -x_109 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_5, x_108, x_107); -lean_inc(x_10); -x_110 = lean_apply_2(x_109, x_10, x_11); -if (lean_obj_tag(x_110) == 0) -{ -lean_object* x_111; uint8_t x_112; -x_111 = lean_ctor_get(x_110, 0); -lean_inc(x_111); -x_112 = lean_unbox(x_111); -lean_dec(x_111); -if (x_112 == 0) -{ -lean_object* x_113; lean_object* x_114; -lean_dec(x_105); -lean_dec(x_8); -lean_dec(x_7); -x_113 = lean_ctor_get(x_110, 1); -lean_inc(x_113); -lean_dec(x_110); -x_114 = lean_apply_4(x_2, x_1, x_9, x_10, x_113); -if (lean_obj_tag(x_114) == 0) -{ -uint8_t x_115; -x_115 = !lean_is_exclusive(x_114); -if (x_115 == 0) -{ -lean_object* x_116; uint8_t x_117; uint8_t x_118; lean_object* x_119; -x_116 = lean_ctor_get(x_114, 0); -x_117 = lean_unbox(x_116); -lean_dec(x_116); -x_118 = l_Bool_toLBool(x_117); -x_119 = lean_box(x_118); -lean_ctor_set(x_114, 0, x_119); -return x_114; } else { -lean_object* x_120; lean_object* x_121; uint8_t x_122; uint8_t x_123; lean_object* x_124; lean_object* x_125; -x_120 = lean_ctor_get(x_114, 0); -x_121 = lean_ctor_get(x_114, 1); +lean_object* x_104; uint8_t x_105; +x_104 = lean_ctor_get(x_27, 0); +lean_inc(x_104); +x_105 = lean_unbox(x_104); +lean_dec(x_104); +if (x_105 == 0) +{ +lean_object* x_106; lean_object* x_107; +lean_dec(x_10); +lean_dec(x_9); +x_106 = lean_ctor_get(x_27, 1); +lean_inc(x_106); +lean_dec(x_27); +x_107 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_1, x_2, x_3, x_106); +if (lean_obj_tag(x_107) == 0) +{ +uint8_t x_108; +x_108 = !lean_is_exclusive(x_107); +if (x_108 == 0) +{ +lean_object* x_109; uint8_t x_110; uint8_t x_111; lean_object* x_112; +x_109 = lean_ctor_get(x_107, 0); +x_110 = lean_unbox(x_109); +lean_dec(x_109); +x_111 = l_Bool_toLBool(x_110); +x_112 = lean_box(x_111); +lean_ctor_set(x_107, 0, x_112); +return x_107; +} +else +{ +lean_object* x_113; lean_object* x_114; uint8_t x_115; uint8_t x_116; lean_object* x_117; lean_object* x_118; +x_113 = lean_ctor_get(x_107, 0); +x_114 = lean_ctor_get(x_107, 1); +lean_inc(x_114); +lean_inc(x_113); +lean_dec(x_107); +x_115 = lean_unbox(x_113); +lean_dec(x_113); +x_116 = l_Bool_toLBool(x_115); +x_117 = lean_box(x_116); +x_118 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_118, 0, x_117); +lean_ctor_set(x_118, 1, x_114); +return x_118; +} +} +else +{ +uint8_t x_119; +x_119 = !lean_is_exclusive(x_107); +if (x_119 == 0) +{ +return x_107; +} +else +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_107, 0); +x_121 = lean_ctor_get(x_107, 1); lean_inc(x_121); lean_inc(x_120); -lean_dec(x_114); -x_122 = lean_unbox(x_120); -lean_dec(x_120); -x_123 = l_Bool_toLBool(x_122); -x_124 = lean_box(x_123); -x_125 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_125, 0, x_124); -lean_ctor_set(x_125, 1, x_121); -return x_125; +lean_dec(x_107); +x_122 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_122, 0, x_120); +lean_ctor_set(x_122, 1, x_121); +return x_122; +} } } else { -uint8_t x_126; -x_126 = !lean_is_exclusive(x_114); -if (x_126 == 0) +lean_object* x_123; lean_object* x_124; lean_object* x_125; +x_123 = lean_ctor_get(x_27, 1); +lean_inc(x_123); +lean_dec(x_27); +x_124 = l_Lean_Expr_mvarId_x21(x_9); +lean_dec(x_9); +x_125 = l_Lean_Meta_getMVarDecl(x_124, x_3, x_123); +if (lean_obj_tag(x_125) == 0) { -return x_114; -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; -x_127 = lean_ctor_get(x_114, 0); -x_128 = lean_ctor_get(x_114, 1); -lean_inc(x_128); +lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_125, 1); lean_inc(x_127); -lean_dec(x_114); -x_129 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_129, 0, x_127); -lean_ctor_set(x_129, 1, x_128); -return x_129; -} -} -} -else +lean_dec(x_125); +x_128 = l_Lean_Expr_mvarId_x21(x_10); +lean_dec(x_10); +x_129 = l_Lean_Meta_getMVarDecl(x_128, x_3, x_127); +if (lean_obj_tag(x_129) == 0) { -lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; -x_130 = lean_ctor_get(x_110, 1); +lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; uint8_t x_134; +x_130 = lean_ctor_get(x_129, 0); lean_inc(x_130); -lean_dec(x_110); -x_131 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_131, 0, x_8); -x_132 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_7, x_105, x_131); -lean_inc(x_10); -x_133 = lean_apply_2(x_132, x_10, x_130); -if (lean_obj_tag(x_133) == 0) +x_131 = lean_ctor_get(x_129, 1); +lean_inc(x_131); +lean_dec(x_129); +x_132 = lean_ctor_get(x_130, 1); +lean_inc(x_132); +lean_dec(x_130); +x_133 = lean_ctor_get(x_126, 1); +lean_inc(x_133); +lean_dec(x_126); +lean_inc(x_133); +lean_inc(x_132); +x_134 = l_Lean_LocalContext_isSubPrefixOf(x_132, x_133); +if (x_134 == 0) { -lean_object* x_134; lean_object* x_135; -x_134 = lean_ctor_get(x_133, 1); -lean_inc(x_134); +lean_object* x_135; lean_dec(x_133); -x_135 = lean_apply_4(x_2, x_1, x_9, x_10, x_134); +lean_dec(x_132); +x_135 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_2, x_1, x_3, x_131); if (lean_obj_tag(x_135) == 0) { uint8_t x_136; @@ -13275,283 +22950,1527 @@ return x_150; } else { -uint8_t x_151; -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_2); -lean_dec(x_1); -x_151 = !lean_is_exclusive(x_133); +uint8_t x_151; uint8_t x_152; +x_151 = l_Lean_Expr_isApp(x_1); if (x_151 == 0) { -return x_133; +uint8_t x_301; +x_301 = l_Lean_Expr_isApp(x_2); +if (x_301 == 0) +{ +x_152 = x_301; +goto block_300; } else { -lean_object* x_152; lean_object* x_153; lean_object* x_154; -x_152 = lean_ctor_get(x_133, 0); -x_153 = lean_ctor_get(x_133, 1); -lean_inc(x_153); -lean_inc(x_152); +lean_object* x_302; lean_dec(x_133); -x_154 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_154, 0, x_152); -lean_ctor_set(x_154, 1, x_153); -return x_154; +lean_dec(x_132); +x_302 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_1, x_2, x_3, x_131); +if (lean_obj_tag(x_302) == 0) +{ +uint8_t x_303; +x_303 = !lean_is_exclusive(x_302); +if (x_303 == 0) +{ +lean_object* x_304; uint8_t x_305; uint8_t x_306; lean_object* x_307; +x_304 = lean_ctor_get(x_302, 0); +x_305 = lean_unbox(x_304); +lean_dec(x_304); +x_306 = l_Bool_toLBool(x_305); +x_307 = lean_box(x_306); +lean_ctor_set(x_302, 0, x_307); +return x_302; +} +else +{ +lean_object* x_308; lean_object* x_309; uint8_t x_310; uint8_t x_311; lean_object* x_312; lean_object* x_313; +x_308 = lean_ctor_get(x_302, 0); +x_309 = lean_ctor_get(x_302, 1); +lean_inc(x_309); +lean_inc(x_308); +lean_dec(x_302); +x_310 = lean_unbox(x_308); +lean_dec(x_308); +x_311 = l_Bool_toLBool(x_310); +x_312 = lean_box(x_311); +x_313 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_313, 0, x_312); +lean_ctor_set(x_313, 1, x_309); +return x_313; +} +} +else +{ +uint8_t x_314; +x_314 = !lean_is_exclusive(x_302); +if (x_314 == 0) +{ +return x_302; +} +else +{ +lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_315 = lean_ctor_get(x_302, 0); +x_316 = lean_ctor_get(x_302, 1); +lean_inc(x_316); +lean_inc(x_315); +lean_dec(x_302); +x_317 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_317, 0, x_315); +lean_ctor_set(x_317, 1, x_316); +return x_317; } } } } else { +x_152 = x_22; +goto block_300; +} +block_300: +{ +uint8_t x_153; +x_153 = l_Lean_Expr_isApp(x_2); +if (x_153 == 0) +{ +if (x_151 == 0) +{ +lean_dec(x_133); +lean_dec(x_132); +if (x_152 == 0) +{ +lean_object* x_154; +x_154 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_1, x_2, x_3, x_131); +if (lean_obj_tag(x_154) == 0) +{ uint8_t x_155; -lean_dec(x_105); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_2); -lean_dec(x_1); -x_155 = !lean_is_exclusive(x_110); +x_155 = !lean_is_exclusive(x_154); if (x_155 == 0) { -return x_110; +lean_object* x_156; uint8_t x_157; uint8_t x_158; lean_object* x_159; +x_156 = lean_ctor_get(x_154, 0); +x_157 = lean_unbox(x_156); +lean_dec(x_156); +x_158 = l_Bool_toLBool(x_157); +x_159 = lean_box(x_158); +lean_ctor_set(x_154, 0, x_159); +return x_154; } else { -lean_object* x_156; lean_object* x_157; lean_object* x_158; -x_156 = lean_ctor_get(x_110, 0); -x_157 = lean_ctor_get(x_110, 1); -lean_inc(x_157); -lean_inc(x_156); -lean_dec(x_110); -x_158 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_158, 0, x_156); -lean_ctor_set(x_158, 1, x_157); -return x_158; +lean_object* x_160; lean_object* x_161; uint8_t x_162; uint8_t x_163; lean_object* x_164; lean_object* x_165; +x_160 = lean_ctor_get(x_154, 0); +x_161 = lean_ctor_get(x_154, 1); +lean_inc(x_161); +lean_inc(x_160); +lean_dec(x_154); +x_162 = lean_unbox(x_160); +lean_dec(x_160); +x_163 = l_Bool_toLBool(x_162); +x_164 = lean_box(x_163); +x_165 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_165, 0, x_164); +lean_ctor_set(x_165, 1, x_161); +return x_165; } } -} -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13, lean_object* x_14, lean_object* x_15) { -_start: +else { -uint8_t x_16; -x_16 = l___private_Init_Lean_Meta_ExprDefEq_18__sameHeadSymbol(x_13, x_1); -if (x_16 == 0) +uint8_t x_166; +x_166 = !lean_is_exclusive(x_154); +if (x_166 == 0) +{ +return x_154; +} +else +{ +lean_object* x_167; lean_object* x_168; lean_object* x_169; +x_167 = lean_ctor_get(x_154, 0); +x_168 = lean_ctor_get(x_154, 1); +lean_inc(x_168); +lean_inc(x_167); +lean_dec(x_154); +x_169 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_169, 0, x_167); +lean_ctor_set(x_169, 1, x_168); +return x_169; +} +} +} +else +{ +lean_object* x_170; +x_170 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_2, x_1, x_3, x_131); +if (lean_obj_tag(x_170) == 0) +{ +uint8_t x_171; +x_171 = !lean_is_exclusive(x_170); +if (x_171 == 0) +{ +lean_object* x_172; uint8_t x_173; uint8_t x_174; lean_object* x_175; +x_172 = lean_ctor_get(x_170, 0); +x_173 = lean_unbox(x_172); +lean_dec(x_172); +x_174 = l_Bool_toLBool(x_173); +x_175 = lean_box(x_174); +lean_ctor_set(x_170, 0, x_175); +return x_170; +} +else +{ +lean_object* x_176; lean_object* x_177; uint8_t x_178; uint8_t x_179; lean_object* x_180; lean_object* x_181; +x_176 = lean_ctor_get(x_170, 0); +x_177 = lean_ctor_get(x_170, 1); +lean_inc(x_177); +lean_inc(x_176); +lean_dec(x_170); +x_178 = lean_unbox(x_176); +lean_dec(x_176); +x_179 = l_Bool_toLBool(x_178); +x_180 = lean_box(x_179); +x_181 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_181, 0, x_180); +lean_ctor_set(x_181, 1, x_177); +return x_181; +} +} +else +{ +uint8_t x_182; +x_182 = !lean_is_exclusive(x_170); +if (x_182 == 0) +{ +return x_170; +} +else +{ +lean_object* x_183; lean_object* x_184; lean_object* x_185; +x_183 = lean_ctor_get(x_170, 0); +x_184 = lean_ctor_get(x_170, 1); +lean_inc(x_184); +lean_inc(x_183); +lean_dec(x_170); +x_185 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_185, 0, x_183); +lean_ctor_set(x_185, 1, x_184); +return x_185; +} +} +} +} +else +{ +uint8_t x_186; +x_186 = l_Lean_LocalContext_isSubPrefixOf(x_133, x_132); +if (x_186 == 0) +{ +lean_object* x_187; +x_187 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_1, x_2, x_3, x_131); +if (lean_obj_tag(x_187) == 0) +{ +uint8_t x_188; +x_188 = !lean_is_exclusive(x_187); +if (x_188 == 0) +{ +lean_object* x_189; uint8_t x_190; uint8_t x_191; lean_object* x_192; +x_189 = lean_ctor_get(x_187, 0); +x_190 = lean_unbox(x_189); +lean_dec(x_189); +x_191 = l_Bool_toLBool(x_190); +x_192 = lean_box(x_191); +lean_ctor_set(x_187, 0, x_192); +return x_187; +} +else +{ +lean_object* x_193; lean_object* x_194; uint8_t x_195; uint8_t x_196; lean_object* x_197; lean_object* x_198; +x_193 = lean_ctor_get(x_187, 0); +x_194 = lean_ctor_get(x_187, 1); +lean_inc(x_194); +lean_inc(x_193); +lean_dec(x_187); +x_195 = lean_unbox(x_193); +lean_dec(x_193); +x_196 = l_Bool_toLBool(x_195); +x_197 = lean_box(x_196); +x_198 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_198, 0, x_197); +lean_ctor_set(x_198, 1, x_194); +return x_198; +} +} +else +{ +uint8_t x_199; +x_199 = !lean_is_exclusive(x_187); +if (x_199 == 0) +{ +return x_187; +} +else +{ +lean_object* x_200; lean_object* x_201; lean_object* x_202; +x_200 = lean_ctor_get(x_187, 0); +x_201 = lean_ctor_get(x_187, 1); +lean_inc(x_201); +lean_inc(x_200); +lean_dec(x_187); +x_202 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_202, 0, x_200); +lean_ctor_set(x_202, 1, x_201); +return x_202; +} +} +} +else +{ +lean_object* x_203; +x_203 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_2, x_1, x_3, x_131); +if (lean_obj_tag(x_203) == 0) +{ +uint8_t x_204; +x_204 = !lean_is_exclusive(x_203); +if (x_204 == 0) +{ +lean_object* x_205; uint8_t x_206; uint8_t x_207; lean_object* x_208; +x_205 = lean_ctor_get(x_203, 0); +x_206 = lean_unbox(x_205); +lean_dec(x_205); +x_207 = l_Bool_toLBool(x_206); +x_208 = lean_box(x_207); +lean_ctor_set(x_203, 0, x_208); +return x_203; +} +else +{ +lean_object* x_209; lean_object* x_210; uint8_t x_211; uint8_t x_212; lean_object* x_213; lean_object* x_214; +x_209 = lean_ctor_get(x_203, 0); +x_210 = lean_ctor_get(x_203, 1); +lean_inc(x_210); +lean_inc(x_209); +lean_dec(x_203); +x_211 = lean_unbox(x_209); +lean_dec(x_209); +x_212 = l_Bool_toLBool(x_211); +x_213 = lean_box(x_212); +x_214 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_214, 0, x_213); +lean_ctor_set(x_214, 1, x_210); +return x_214; +} +} +else +{ +uint8_t x_215; +x_215 = !lean_is_exclusive(x_203); +if (x_215 == 0) +{ +return x_203; +} +else +{ +lean_object* x_216; lean_object* x_217; lean_object* x_218; +x_216 = lean_ctor_get(x_203, 0); +x_217 = lean_ctor_get(x_203, 1); +lean_inc(x_217); +lean_inc(x_216); +lean_dec(x_203); +x_218 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_218, 0, x_216); +lean_ctor_set(x_218, 1, x_217); +return x_218; +} +} +} +} +} +else +{ +if (x_152 == 0) +{ +lean_object* x_219; +lean_dec(x_133); +lean_dec(x_132); +x_219 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_1, x_2, x_3, x_131); +if (lean_obj_tag(x_219) == 0) +{ +uint8_t x_220; +x_220 = !lean_is_exclusive(x_219); +if (x_220 == 0) +{ +lean_object* x_221; uint8_t x_222; uint8_t x_223; lean_object* x_224; +x_221 = lean_ctor_get(x_219, 0); +x_222 = lean_unbox(x_221); +lean_dec(x_221); +x_223 = l_Bool_toLBool(x_222); +x_224 = lean_box(x_223); +lean_ctor_set(x_219, 0, x_224); +return x_219; +} +else +{ +lean_object* x_225; lean_object* x_226; uint8_t x_227; uint8_t x_228; lean_object* x_229; lean_object* x_230; +x_225 = lean_ctor_get(x_219, 0); +x_226 = lean_ctor_get(x_219, 1); +lean_inc(x_226); +lean_inc(x_225); +lean_dec(x_219); +x_227 = lean_unbox(x_225); +lean_dec(x_225); +x_228 = l_Bool_toLBool(x_227); +x_229 = lean_box(x_228); +x_230 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_230, 0, x_229); +lean_ctor_set(x_230, 1, x_226); +return x_230; +} +} +else +{ +uint8_t x_231; +x_231 = !lean_is_exclusive(x_219); +if (x_231 == 0) +{ +return x_219; +} +else +{ +lean_object* x_232; lean_object* x_233; lean_object* x_234; +x_232 = lean_ctor_get(x_219, 0); +x_233 = lean_ctor_get(x_219, 1); +lean_inc(x_233); +lean_inc(x_232); +lean_dec(x_219); +x_234 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_234, 0, x_232); +lean_ctor_set(x_234, 1, x_233); +return x_234; +} +} +} +else +{ +if (x_151 == 0) +{ +lean_dec(x_133); +lean_dec(x_132); +if (x_152 == 0) +{ +lean_object* x_235; +x_235 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_1, x_2, x_3, x_131); +if (lean_obj_tag(x_235) == 0) +{ +uint8_t x_236; +x_236 = !lean_is_exclusive(x_235); +if (x_236 == 0) +{ +lean_object* x_237; uint8_t x_238; uint8_t x_239; lean_object* x_240; +x_237 = lean_ctor_get(x_235, 0); +x_238 = lean_unbox(x_237); +lean_dec(x_237); +x_239 = l_Bool_toLBool(x_238); +x_240 = lean_box(x_239); +lean_ctor_set(x_235, 0, x_240); +return x_235; +} +else +{ +lean_object* x_241; lean_object* x_242; uint8_t x_243; uint8_t x_244; lean_object* x_245; lean_object* x_246; +x_241 = lean_ctor_get(x_235, 0); +x_242 = lean_ctor_get(x_235, 1); +lean_inc(x_242); +lean_inc(x_241); +lean_dec(x_235); +x_243 = lean_unbox(x_241); +lean_dec(x_241); +x_244 = l_Bool_toLBool(x_243); +x_245 = lean_box(x_244); +x_246 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_246, 0, x_245); +lean_ctor_set(x_246, 1, x_242); +return x_246; +} +} +else +{ +uint8_t x_247; +x_247 = !lean_is_exclusive(x_235); +if (x_247 == 0) +{ +return x_235; +} +else +{ +lean_object* x_248; lean_object* x_249; lean_object* x_250; +x_248 = lean_ctor_get(x_235, 0); +x_249 = lean_ctor_get(x_235, 1); +lean_inc(x_249); +lean_inc(x_248); +lean_dec(x_235); +x_250 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_250, 0, x_248); +lean_ctor_set(x_250, 1, x_249); +return x_250; +} +} +} +else +{ +lean_object* x_251; +x_251 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_2, x_1, x_3, x_131); +if (lean_obj_tag(x_251) == 0) +{ +uint8_t x_252; +x_252 = !lean_is_exclusive(x_251); +if (x_252 == 0) +{ +lean_object* x_253; uint8_t x_254; uint8_t x_255; lean_object* x_256; +x_253 = lean_ctor_get(x_251, 0); +x_254 = lean_unbox(x_253); +lean_dec(x_253); +x_255 = l_Bool_toLBool(x_254); +x_256 = lean_box(x_255); +lean_ctor_set(x_251, 0, x_256); +return x_251; +} +else +{ +lean_object* x_257; lean_object* x_258; uint8_t x_259; uint8_t x_260; lean_object* x_261; lean_object* x_262; +x_257 = lean_ctor_get(x_251, 0); +x_258 = lean_ctor_get(x_251, 1); +lean_inc(x_258); +lean_inc(x_257); +lean_dec(x_251); +x_259 = lean_unbox(x_257); +lean_dec(x_257); +x_260 = l_Bool_toLBool(x_259); +x_261 = lean_box(x_260); +x_262 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_262, 0, x_261); +lean_ctor_set(x_262, 1, x_258); +return x_262; +} +} +else +{ +uint8_t x_263; +x_263 = !lean_is_exclusive(x_251); +if (x_263 == 0) +{ +return x_251; +} +else +{ +lean_object* x_264; lean_object* x_265; lean_object* x_266; +x_264 = lean_ctor_get(x_251, 0); +x_265 = lean_ctor_get(x_251, 1); +lean_inc(x_265); +lean_inc(x_264); +lean_dec(x_251); +x_266 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_266, 0, x_264); +lean_ctor_set(x_266, 1, x_265); +return x_266; +} +} +} +} +else +{ +uint8_t x_267; +x_267 = l_Lean_LocalContext_isSubPrefixOf(x_133, x_132); +if (x_267 == 0) +{ +lean_object* x_268; +x_268 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_1, x_2, x_3, x_131); +if (lean_obj_tag(x_268) == 0) +{ +uint8_t x_269; +x_269 = !lean_is_exclusive(x_268); +if (x_269 == 0) +{ +lean_object* x_270; uint8_t x_271; uint8_t x_272; lean_object* x_273; +x_270 = lean_ctor_get(x_268, 0); +x_271 = lean_unbox(x_270); +lean_dec(x_270); +x_272 = l_Bool_toLBool(x_271); +x_273 = lean_box(x_272); +lean_ctor_set(x_268, 0, x_273); +return x_268; +} +else +{ +lean_object* x_274; lean_object* x_275; uint8_t x_276; uint8_t x_277; lean_object* x_278; lean_object* x_279; +x_274 = lean_ctor_get(x_268, 0); +x_275 = lean_ctor_get(x_268, 1); +lean_inc(x_275); +lean_inc(x_274); +lean_dec(x_268); +x_276 = lean_unbox(x_274); +lean_dec(x_274); +x_277 = l_Bool_toLBool(x_276); +x_278 = lean_box(x_277); +x_279 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_279, 0, x_278); +lean_ctor_set(x_279, 1, x_275); +return x_279; +} +} +else +{ +uint8_t x_280; +x_280 = !lean_is_exclusive(x_268); +if (x_280 == 0) +{ +return x_268; +} +else +{ +lean_object* x_281; lean_object* x_282; lean_object* x_283; +x_281 = lean_ctor_get(x_268, 0); +x_282 = lean_ctor_get(x_268, 1); +lean_inc(x_282); +lean_inc(x_281); +lean_dec(x_268); +x_283 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_283, 0, x_281); +lean_ctor_set(x_283, 1, x_282); +return x_283; +} +} +} +else +{ +lean_object* x_284; +x_284 = l___private_Init_Lean_Meta_ExprDefEq_18__processAssignment(x_2, x_1, x_3, x_131); +if (lean_obj_tag(x_284) == 0) +{ +uint8_t x_285; +x_285 = !lean_is_exclusive(x_284); +if (x_285 == 0) +{ +lean_object* x_286; uint8_t x_287; uint8_t x_288; lean_object* x_289; +x_286 = lean_ctor_get(x_284, 0); +x_287 = lean_unbox(x_286); +lean_dec(x_286); +x_288 = l_Bool_toLBool(x_287); +x_289 = lean_box(x_288); +lean_ctor_set(x_284, 0, x_289); +return x_284; +} +else +{ +lean_object* x_290; lean_object* x_291; uint8_t x_292; uint8_t x_293; lean_object* x_294; lean_object* x_295; +x_290 = lean_ctor_get(x_284, 0); +x_291 = lean_ctor_get(x_284, 1); +lean_inc(x_291); +lean_inc(x_290); +lean_dec(x_284); +x_292 = lean_unbox(x_290); +lean_dec(x_290); +x_293 = l_Bool_toLBool(x_292); +x_294 = lean_box(x_293); +x_295 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_295, 0, x_294); +lean_ctor_set(x_295, 1, x_291); +return x_295; +} +} +else +{ +uint8_t x_296; +x_296 = !lean_is_exclusive(x_284); +if (x_296 == 0) +{ +return x_284; +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; +x_297 = lean_ctor_get(x_284, 0); +x_298 = lean_ctor_get(x_284, 1); +lean_inc(x_298); +lean_inc(x_297); +lean_dec(x_284); +x_299 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_299, 0, x_297); +lean_ctor_set(x_299, 1, x_298); +return x_299; +} +} +} +} +} +} +} +} +} +else +{ +uint8_t x_318; +lean_dec(x_126); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_318 = !lean_is_exclusive(x_129); +if (x_318 == 0) +{ +return x_129; +} +else +{ +lean_object* x_319; lean_object* x_320; lean_object* x_321; +x_319 = lean_ctor_get(x_129, 0); +x_320 = lean_ctor_get(x_129, 1); +lean_inc(x_320); +lean_inc(x_319); +lean_dec(x_129); +x_321 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_321, 0, x_319); +lean_ctor_set(x_321, 1, x_320); +return x_321; +} +} +} +else +{ +uint8_t x_322; +lean_dec(x_10); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_322 = !lean_is_exclusive(x_125); +if (x_322 == 0) +{ +return x_125; +} +else +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; +x_323 = lean_ctor_get(x_125, 0); +x_324 = lean_ctor_get(x_125, 1); +lean_inc(x_324); +lean_inc(x_323); +lean_dec(x_125); +x_325 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_325, 0, x_323); +lean_ctor_set(x_325, 1, x_324); +return x_325; +} +} +} +} +} +else +{ +uint8_t x_326; +lean_dec(x_25); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_326 = !lean_is_exclusive(x_27); +if (x_326 == 0) { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_17 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1; -lean_inc(x_2); -x_18 = lean_name_mk_string(x_2, x_17); -lean_inc(x_3); -lean_inc(x_18); -x_19 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__4___boxed), 5, 2); -lean_closure_set(x_19, 0, x_18); -lean_closure_set(x_19, 1, x_3); -x_20 = l_Lean_Meta_tracer___closed__3; -lean_inc(x_4); -x_21 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_21, 0, x_4); -lean_closure_set(x_21, 1, lean_box(0)); -lean_closure_set(x_21, 2, lean_box(0)); -lean_closure_set(x_21, 3, x_20); -lean_closure_set(x_21, 4, x_19); -lean_inc(x_6); -lean_inc(x_5); -x_22 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__5___boxed), 6, 3); -lean_closure_set(x_22, 0, x_5); -lean_closure_set(x_22, 1, x_6); -lean_closure_set(x_22, 2, x_18); -lean_inc(x_4); -x_23 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_23, 0, x_4); -lean_closure_set(x_23, 1, lean_box(0)); -lean_closure_set(x_23, 2, lean_box(0)); -lean_closure_set(x_23, 3, x_21); -lean_closure_set(x_23, 4, x_22); -lean_inc(x_1); -lean_inc(x_13); -lean_inc(x_7); -x_24 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__6___boxed), 6, 3); -lean_closure_set(x_24, 0, x_7); -lean_closure_set(x_24, 1, x_13); -lean_closure_set(x_24, 2, x_1); -x_25 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_25, 0, x_4); -lean_closure_set(x_25, 1, lean_box(0)); -lean_closure_set(x_25, 2, lean_box(0)); -lean_closure_set(x_25, 3, x_23); -lean_closure_set(x_25, 4, x_24); -lean_inc(x_7); -x_26 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__10), 11, 8); -lean_closure_set(x_26, 0, x_8); -lean_closure_set(x_26, 1, x_7); -lean_closure_set(x_26, 2, x_13); -lean_closure_set(x_26, 3, x_2); -lean_closure_set(x_26, 4, x_3); -lean_closure_set(x_26, 5, x_5); -lean_closure_set(x_26, 6, x_6); -lean_closure_set(x_26, 7, x_9); -x_27 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_10, x_11, x_7, x_12, x_1, x_25, x_26, x_14, x_15); return x_27; } else { -lean_object* x_28; uint8_t x_29; -lean_dec(x_12); -lean_dec(x_11); +lean_object* x_327; lean_object* x_328; lean_object* x_329; +x_327 = lean_ctor_get(x_27, 0); +x_328 = lean_ctor_get(x_27, 1); +lean_inc(x_328); +lean_inc(x_327); +lean_dec(x_27); +x_329 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_329, 0, x_327); +lean_ctor_set(x_329, 1, x_328); +return x_329; +} +} +} +else +{ +uint8_t x_330; lean_dec(x_10); lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_4); -x_28 = lean_ctor_get(x_15, 4); -lean_inc(x_28); -x_29 = lean_ctor_get_uint8(x_28, sizeof(void*)*1); -lean_dec(x_28); -if (x_29 == 0) -{ -lean_object* x_30; -lean_dec(x_6); -lean_dec(x_5); lean_dec(x_3); lean_dec(x_2); -x_30 = lean_apply_4(x_7, x_13, x_1, x_14, x_15); -if (lean_obj_tag(x_30) == 0) +lean_dec(x_1); +x_330 = !lean_is_exclusive(x_24); +if (x_330 == 0) { -uint8_t x_31; -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; uint8_t x_33; uint8_t x_34; lean_object* x_35; -x_32 = lean_ctor_get(x_30, 0); -x_33 = lean_unbox(x_32); -lean_dec(x_32); -x_34 = l_Bool_toLBool(x_33); -x_35 = lean_box(x_34); -lean_ctor_set(x_30, 0, x_35); -return x_30; +return x_24; } else { -lean_object* x_36; lean_object* x_37; uint8_t x_38; uint8_t x_39; lean_object* x_40; lean_object* x_41; -x_36 = lean_ctor_get(x_30, 0); -x_37 = lean_ctor_get(x_30, 1); +lean_object* x_331; lean_object* x_332; lean_object* x_333; +x_331 = lean_ctor_get(x_24, 0); +x_332 = lean_ctor_get(x_24, 1); +lean_inc(x_332); +lean_inc(x_331); +lean_dec(x_24); +x_333 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_333, 0, x_331); +lean_ctor_set(x_333, 1, x_332); +return x_333; +} +} +} +else +{ +lean_object* x_334; lean_object* x_335; lean_object* x_336; +lean_dec(x_10); +lean_dec(x_9); +x_334 = l_Lean_Meta_instantiateMVars(x_2, x_3, x_23); +x_335 = lean_ctor_get(x_334, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_334, 1); +lean_inc(x_336); +lean_dec(x_334); +x_2 = x_335; +x_4 = x_336; +goto _start; +} +} +} +} +else +{ +lean_object* x_385; lean_object* x_386; lean_object* x_387; lean_object* x_388; +lean_dec(x_10); +lean_dec(x_9); +x_385 = lean_ctor_get(x_13, 1); +lean_inc(x_385); +lean_dec(x_13); +x_386 = l_Lean_Meta_instantiateMVars(x_1, x_3, x_385); +x_387 = lean_ctor_get(x_386, 0); +lean_inc(x_387); +x_388 = lean_ctor_get(x_386, 1); +lean_inc(x_388); +lean_dec(x_386); +x_1 = x_387; +x_4 = x_388; +goto _start; +} +} +} +else +{ +uint8_t x_397; lean_object* x_398; lean_object* x_399; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_397 = 1; +x_398 = lean_box(x_397); +x_399 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_399, 0, x_398); +lean_ctor_set(x_399, 1, x_4); +return x_399; +} +} +else +{ +uint8_t x_400; lean_object* x_401; lean_object* x_402; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_400 = 1; +x_401 = lean_box(x_400); +x_402 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_402, 0, x_401); +lean_ctor_set(x_402, 1, x_4); +return x_402; +} +} +else +{ +uint8_t x_403; lean_object* x_404; lean_object* x_405; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_403 = 1; +x_404 = lean_box(x_403); +x_405 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_405, 0, x_404); +lean_ctor_set(x_405, 1, x_4); +return x_405; +} +} +block_426: +{ +lean_object* x_408; lean_object* x_409; lean_object* x_410; +lean_dec(x_407); +x_408 = lean_ctor_get(x_3, 1); +lean_inc(x_408); +x_409 = l_Array_empty___closed__1; +x_410 = l___private_Init_Lean_Meta_ExprDefEq_5__isDefEqBindingAux___main(x_408, x_409, x_1, x_2, x_409, x_3, x_4); +lean_dec(x_2); +if (lean_obj_tag(x_410) == 0) +{ +uint8_t x_411; +x_411 = !lean_is_exclusive(x_410); +if (x_411 == 0) +{ +lean_object* x_412; uint8_t x_413; uint8_t x_414; lean_object* x_415; +x_412 = lean_ctor_get(x_410, 0); +x_413 = lean_unbox(x_412); +lean_dec(x_412); +x_414 = l_Bool_toLBool(x_413); +x_415 = lean_box(x_414); +lean_ctor_set(x_410, 0, x_415); +return x_410; +} +else +{ +lean_object* x_416; lean_object* x_417; uint8_t x_418; uint8_t x_419; lean_object* x_420; lean_object* x_421; +x_416 = lean_ctor_get(x_410, 0); +x_417 = lean_ctor_get(x_410, 1); +lean_inc(x_417); +lean_inc(x_416); +lean_dec(x_410); +x_418 = lean_unbox(x_416); +lean_dec(x_416); +x_419 = l_Bool_toLBool(x_418); +x_420 = lean_box(x_419); +x_421 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_421, 0, x_420); +lean_ctor_set(x_421, 1, x_417); +return x_421; +} +} +else +{ +uint8_t x_422; +x_422 = !lean_is_exclusive(x_410); +if (x_422 == 0) +{ +return x_410; +} +else +{ +lean_object* x_423; lean_object* x_424; lean_object* x_425; +x_423 = lean_ctor_get(x_410, 0); +x_424 = lean_ctor_get(x_410, 1); +lean_inc(x_424); +lean_inc(x_423); +lean_dec(x_410); +x_425 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_425, 0, x_423); +lean_ctor_set(x_425, 1, x_424); +return x_425; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(x_1, x_2, x_3, x_4); +return x_5; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_28__isDefEqProofIrrel(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l_Lean_Meta_inferType(x_1, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +lean_inc(x_3); +lean_inc(x_6); +x_8 = l_Lean_Meta_isProp(x_6, x_3, x_7); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; uint8_t x_10; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_unbox(x_9); +lean_dec(x_9); +if (x_10 == 0) +{ +uint8_t x_11; +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_11 = !lean_is_exclusive(x_8); +if (x_11 == 0) +{ +lean_object* x_12; uint8_t x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_8, 0); +lean_dec(x_12); +x_13 = 2; +x_14 = lean_box(x_13); +lean_ctor_set(x_8, 0, x_14); +return x_8; +} +else +{ +lean_object* x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; +x_15 = lean_ctor_get(x_8, 1); +lean_inc(x_15); +lean_dec(x_8); +x_16 = 2; +x_17 = lean_box(x_16); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_17); +lean_ctor_set(x_18, 1, x_15); +return x_18; +} +} +else +{ +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_8, 1); +lean_inc(x_19); +lean_dec(x_8); +lean_inc(x_3); +x_20 = l_Lean_Meta_inferType(x_2, x_3, x_19); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = l_Lean_Meta_isExprDefEqAux(x_6, x_21, x_3, x_22); +if (lean_obj_tag(x_23) == 0) +{ +uint8_t x_24; +x_24 = !lean_is_exclusive(x_23); +if (x_24 == 0) +{ +lean_object* x_25; uint8_t x_26; uint8_t x_27; lean_object* x_28; +x_25 = lean_ctor_get(x_23, 0); +x_26 = lean_unbox(x_25); +lean_dec(x_25); +x_27 = l_Bool_toLBool(x_26); +x_28 = lean_box(x_27); +lean_ctor_set(x_23, 0, x_28); +return x_23; +} +else +{ +lean_object* x_29; lean_object* x_30; uint8_t x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; +x_29 = lean_ctor_get(x_23, 0); +x_30 = lean_ctor_get(x_23, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_23); +x_31 = lean_unbox(x_29); +lean_dec(x_29); +x_32 = l_Bool_toLBool(x_31); +x_33 = lean_box(x_32); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_33); +lean_ctor_set(x_34, 1, x_30); +return x_34; +} +} +else +{ +uint8_t x_35; +x_35 = !lean_is_exclusive(x_23); +if (x_35 == 0) +{ +return x_23; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_23, 0); +x_37 = lean_ctor_get(x_23, 1); lean_inc(x_37); lean_inc(x_36); -lean_dec(x_30); -x_38 = lean_unbox(x_36); -lean_dec(x_36); -x_39 = l_Bool_toLBool(x_38); -x_40 = lean_box(x_39); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_40); -lean_ctor_set(x_41, 1, x_37); -return x_41; +lean_dec(x_23); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} } } else { -uint8_t x_42; -x_42 = !lean_is_exclusive(x_30); -if (x_42 == 0) +uint8_t x_39; +lean_dec(x_6); +lean_dec(x_3); +x_39 = !lean_is_exclusive(x_20); +if (x_39 == 0) { -return x_30; +return x_20; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_30, 0); -x_44 = lean_ctor_get(x_30, 1); +lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_40 = lean_ctor_get(x_20, 0); +x_41 = lean_ctor_get(x_20, 1); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_20); +x_42 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_42, 0, x_40); +lean_ctor_set(x_42, 1, x_41); +return x_42; +} +} +} +} +else +{ +uint8_t x_43; +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_43 = !lean_is_exclusive(x_8); +if (x_43 == 0) +{ +return x_8; +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_44 = lean_ctor_get(x_8, 0); +x_45 = lean_ctor_get(x_8, 1); +lean_inc(x_45); lean_inc(x_44); -lean_inc(x_43); -lean_dec(x_30); -x_45 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_44); -return x_45; +lean_dec(x_8); +x_46 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_46, 0, x_44); +lean_ctor_set(x_46, 1, x_45); +return x_46; } } } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_46 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1; -x_47 = lean_name_mk_string(x_2, x_46); -x_48 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_47); -x_49 = l_Lean_Name_append___main(x_48, x_47); -x_50 = l_Lean_Meta_tracer; -x_51 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_3, x_50, x_49); -lean_inc(x_14); -x_52 = lean_apply_2(x_51, x_14, x_15); -if (lean_obj_tag(x_52) == 0) +uint8_t x_47; +lean_dec(x_3); +lean_dec(x_2); +x_47 = !lean_is_exclusive(x_5); +if (x_47 == 0) { -lean_object* x_53; uint8_t x_54; -x_53 = lean_ctor_get(x_52, 0); -lean_inc(x_53); -x_54 = lean_unbox(x_53); -lean_dec(x_53); -if (x_54 == 0) +return x_5; +} +else { -lean_object* x_55; lean_object* x_56; -lean_dec(x_47); +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_5, 0); +x_49 = lean_ctor_get(x_5, 1); +lean_inc(x_49); +lean_inc(x_48); +lean_dec(x_5); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +uint8_t x_14; +lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_55 = lean_ctor_get(x_52, 1); -lean_inc(x_55); -lean_dec(x_52); -x_56 = lean_apply_4(x_7, x_13, x_1, x_14, x_55); -if (lean_obj_tag(x_56) == 0) +lean_dec(x_4); +x_14 = lean_expr_eqv(x_2, x_3); +if (x_14 == 0) { -uint8_t x_57; -x_57 = !lean_is_exclusive(x_56); -if (x_57 == 0) -{ -lean_object* x_58; uint8_t x_59; uint8_t x_60; lean_object* x_61; -x_58 = lean_ctor_get(x_56, 0); -x_59 = lean_unbox(x_58); -lean_dec(x_58); -x_60 = l_Bool_toLBool(x_59); -x_61 = lean_box(x_60); -lean_ctor_set(x_56, 0, x_61); -return x_56; +lean_object* x_15; lean_object* x_16; +x_15 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_8); +return x_16; } else { -lean_object* x_62; lean_object* x_63; uint8_t x_64; uint8_t x_65; lean_object* x_66; lean_object* x_67; -x_62 = lean_ctor_get(x_56, 0); -x_63 = lean_ctor_get(x_56, 1); +lean_object* x_17; +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_1); +lean_ctor_set(x_17, 1, x_8); +return x_17; +} +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +lean_dec(x_1); +x_18 = lean_instantiate_value_lparams(x_4, x_5); +x_19 = l_Lean_Expr_betaRev(x_18, x_6); +lean_dec(x_18); +x_20 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_19); +x_21 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_20, x_7, x_8); +return x_21; +} +} +} +lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; uint8_t x_113; lean_object* x_114; +x_113 = lean_ctor_get_uint8(x_4, sizeof(void*)*1); +x_114 = lean_box(x_113); +switch (lean_obj_tag(x_114)) { +case 2: +{ +lean_object* x_115; lean_object* x_116; +x_115 = lean_unsigned_to_nat(5u); +x_116 = lean_unsigned_to_nat(3u); +x_9 = x_115; +x_10 = x_116; +goto block_112; +} +case 3: +{ +lean_object* x_117; lean_object* x_118; +x_117 = lean_unsigned_to_nat(4u); +x_118 = lean_unsigned_to_nat(3u); +x_9 = x_117; +x_10 = x_118; +goto block_112; +} +default: +{ +uint8_t x_119; +lean_dec(x_114); +lean_dec(x_7); +x_119 = lean_expr_eqv(x_2, x_3); +if (x_119 == 0) +{ +lean_object* x_120; lean_object* x_121; +x_120 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_121 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_121, 0, x_120); +lean_ctor_set(x_121, 1, x_8); +return x_121; +} +else +{ +lean_object* x_122; +x_122 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_122, 0, x_1); +lean_ctor_set(x_122, 1, x_8); +return x_122; +} +} +} +block_112: +{ +lean_object* x_11; uint8_t x_12; +x_11 = lean_array_get_size(x_6); +x_12 = lean_nat_dec_lt(x_9, x_11); +if (x_12 == 0) +{ +uint8_t x_13; +lean_dec(x_11); +lean_dec(x_7); +x_13 = lean_expr_eqv(x_2, x_3); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_1); +lean_ctor_set(x_16, 1, x_8); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_array_fget(x_6, x_9); +lean_inc(x_7); +x_18 = l_Lean_Meta_whnf(x_17, x_7, x_8); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +if (lean_obj_tag(x_19) == 5) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +if (lean_obj_tag(x_20) == 5) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +lean_dec(x_20); +if (lean_obj_tag(x_21) == 5) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +lean_dec(x_21); +if (lean_obj_tag(x_22) == 4) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_object* x_27; +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_dec(x_18); +x_24 = lean_ctor_get(x_19, 1); +lean_inc(x_24); +lean_dec(x_19); +x_25 = lean_ctor_get(x_22, 0); +lean_inc(x_25); +lean_dec(x_22); +x_26 = 0; +x_27 = l_Lean_Meta_getConstAux(x_25, x_26, x_7, x_23); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +if (lean_obj_tag(x_28) == 0) +{ +uint8_t x_29; +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_29 = !lean_is_exclusive(x_27); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_27, 0); +lean_dec(x_30); +x_31 = lean_expr_eqv(x_2, x_3); +if (x_31 == 0) +{ +lean_object* x_32; +x_32 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_32); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_33; uint8_t x_34; +x_33 = lean_ctor_get(x_27, 1); +lean_inc(x_33); +lean_dec(x_27); +x_34 = lean_expr_eqv(x_2, x_3); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; +x_35 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_33); +return x_36; +} +else +{ +lean_object* x_37; +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_1); +lean_ctor_set(x_37, 1, x_33); +return x_37; +} +} +} +else +{ +lean_object* x_38; +x_38 = lean_ctor_get(x_28, 0); +lean_inc(x_38); +lean_dec(x_28); +if (lean_obj_tag(x_38) == 4) +{ +lean_object* x_39; uint8_t x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +lean_dec(x_38); +x_40 = lean_ctor_get_uint8(x_39, sizeof(void*)*1); +lean_dec(x_39); +x_41 = lean_box(x_40); +if (lean_obj_tag(x_41) == 1) +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_1); +x_42 = lean_ctor_get(x_27, 1); +lean_inc(x_42); +lean_dec(x_27); +x_43 = l_Lean_Expr_Inhabited; +x_44 = lean_array_get(x_43, x_6, x_10); +x_45 = l_Lean_mkApp(x_44, x_24); +x_46 = lean_unsigned_to_nat(1u); +x_47 = lean_nat_add(x_9, x_46); +x_48 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_11, x_6, x_47, x_45); +lean_dec(x_11); +x_49 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_48, x_7, x_42); +return x_49; +} +else +{ +uint8_t x_50; +lean_dec(x_41); +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_50 = !lean_is_exclusive(x_27); +if (x_50 == 0) +{ +lean_object* x_51; uint8_t x_52; +x_51 = lean_ctor_get(x_27, 0); +lean_dec(x_51); +x_52 = lean_expr_eqv(x_2, x_3); +if (x_52 == 0) +{ +lean_object* x_53; +x_53 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_53); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_54; uint8_t x_55; +x_54 = lean_ctor_get(x_27, 1); +lean_inc(x_54); +lean_dec(x_27); +x_55 = lean_expr_eqv(x_2, x_3); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; +x_56 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_54); +return x_57; +} +else +{ +lean_object* x_58; +x_58 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_58, 0, x_1); +lean_ctor_set(x_58, 1, x_54); +return x_58; +} +} +} +} +else +{ +uint8_t x_59; +lean_dec(x_38); +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_59 = !lean_is_exclusive(x_27); +if (x_59 == 0) +{ +lean_object* x_60; uint8_t x_61; +x_60 = lean_ctor_get(x_27, 0); +lean_dec(x_60); +x_61 = lean_expr_eqv(x_2, x_3); +if (x_61 == 0) +{ +lean_object* x_62; +x_62 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_62); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_63; uint8_t x_64; +x_63 = lean_ctor_get(x_27, 1); lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_56); -x_64 = lean_unbox(x_62); -lean_dec(x_62); -x_65 = l_Bool_toLBool(x_64); -x_66 = lean_box(x_65); +lean_dec(x_27); +x_64 = lean_expr_eqv(x_2, x_3); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_63); +return x_66; +} +else +{ +lean_object* x_67; x_67 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 0, x_1); lean_ctor_set(x_67, 1, x_63); return x_67; } } +} +} +} else { uint8_t x_68; -x_68 = !lean_is_exclusive(x_56); +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_1); +x_68 = !lean_is_exclusive(x_27); if (x_68 == 0) { -return x_56; +return x_27; } else { lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_56, 0); -x_70 = lean_ctor_get(x_56, 1); +x_69 = lean_ctor_get(x_27, 0); +x_70 = lean_ctor_get(x_27, 1); lean_inc(x_70); lean_inc(x_69); -lean_dec(x_56); +lean_dec(x_27); x_71 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_71, 0, x_69); lean_ctor_set(x_71, 1, x_70); @@ -13561,289 +24480,6281 @@ return x_71; } else { -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_72 = lean_ctor_get(x_52, 1); -lean_inc(x_72); -lean_dec(x_52); -x_73 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_73, 0, x_5); -x_74 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_47, x_73); -lean_inc(x_14); -x_75 = lean_apply_2(x_74, x_14, x_72); -if (lean_obj_tag(x_75) == 0) +uint8_t x_72; +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_72 = !lean_is_exclusive(x_18); +if (x_72 == 0) { -lean_object* x_76; lean_object* x_77; -x_76 = lean_ctor_get(x_75, 1); -lean_inc(x_76); -lean_dec(x_75); -x_77 = lean_apply_4(x_7, x_13, x_1, x_14, x_76); -if (lean_obj_tag(x_77) == 0) +lean_object* x_73; uint8_t x_74; +x_73 = lean_ctor_get(x_18, 0); +lean_dec(x_73); +x_74 = lean_expr_eqv(x_2, x_3); +if (x_74 == 0) { -uint8_t x_78; -x_78 = !lean_is_exclusive(x_77); -if (x_78 == 0) -{ -lean_object* x_79; uint8_t x_80; uint8_t x_81; lean_object* x_82; -x_79 = lean_ctor_get(x_77, 0); -x_80 = lean_unbox(x_79); -lean_dec(x_79); -x_81 = l_Bool_toLBool(x_80); -x_82 = lean_box(x_81); -lean_ctor_set(x_77, 0, x_82); -return x_77; +lean_object* x_75; +x_75 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_75); +return x_18; } else { -lean_object* x_83; lean_object* x_84; uint8_t x_85; uint8_t x_86; lean_object* x_87; lean_object* x_88; -x_83 = lean_ctor_get(x_77, 0); -x_84 = lean_ctor_get(x_77, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_77); -x_85 = lean_unbox(x_83); -lean_dec(x_83); -x_86 = l_Bool_toLBool(x_85); -x_87 = lean_box(x_86); +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_76; uint8_t x_77; +x_76 = lean_ctor_get(x_18, 1); +lean_inc(x_76); +lean_dec(x_18); +x_77 = lean_expr_eqv(x_2, x_3); +if (x_77 == 0) +{ +lean_object* x_78; lean_object* x_79; +x_78 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_79 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_79, 0, x_78); +lean_ctor_set(x_79, 1, x_76); +return x_79; +} +else +{ +lean_object* x_80; +x_80 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_80, 0, x_1); +lean_ctor_set(x_80, 1, x_76); +return x_80; +} +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_21); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_81 = !lean_is_exclusive(x_18); +if (x_81 == 0) +{ +lean_object* x_82; uint8_t x_83; +x_82 = lean_ctor_get(x_18, 0); +lean_dec(x_82); +x_83 = lean_expr_eqv(x_2, x_3); +if (x_83 == 0) +{ +lean_object* x_84; +x_84 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_84); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_85; uint8_t x_86; +x_85 = lean_ctor_get(x_18, 1); +lean_inc(x_85); +lean_dec(x_18); +x_86 = lean_expr_eqv(x_2, x_3); +if (x_86 == 0) +{ +lean_object* x_87; lean_object* x_88; +x_87 = l_Lean_Expr_updateFn___main(x_1, x_3); x_88 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_88, 0, x_87); -lean_ctor_set(x_88, 1, x_84); +lean_ctor_set(x_88, 1, x_85); return x_88; } -} else { -uint8_t x_89; -x_89 = !lean_is_exclusive(x_77); -if (x_89 == 0) -{ -return x_77; +lean_object* x_89; +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_1); +lean_ctor_set(x_89, 1, x_85); +return x_89; } -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_77, 0); -x_91 = lean_ctor_get(x_77, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_77); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; } } } else { -uint8_t x_93; -lean_dec(x_14); -lean_dec(x_13); +uint8_t x_90; +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_90 = !lean_is_exclusive(x_18); +if (x_90 == 0) +{ +lean_object* x_91; uint8_t x_92; +x_91 = lean_ctor_get(x_18, 0); +lean_dec(x_91); +x_92 = lean_expr_eqv(x_2, x_3); +if (x_92 == 0) +{ +lean_object* x_93; +x_93 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_93); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_94; uint8_t x_95; +x_94 = lean_ctor_get(x_18, 1); +lean_inc(x_94); +lean_dec(x_18); +x_95 = lean_expr_eqv(x_2, x_3); +if (x_95 == 0) +{ +lean_object* x_96; lean_object* x_97; +x_96 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_97 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_97, 0, x_96); +lean_ctor_set(x_97, 1, x_94); +return x_97; +} +else +{ +lean_object* x_98; +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_1); +lean_ctor_set(x_98, 1, x_94); +return x_98; +} +} +} +} +else +{ +uint8_t x_99; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_99 = !lean_is_exclusive(x_18); +if (x_99 == 0) +{ +lean_object* x_100; uint8_t x_101; +x_100 = lean_ctor_get(x_18, 0); +lean_dec(x_100); +x_101 = lean_expr_eqv(x_2, x_3); +if (x_101 == 0) +{ +lean_object* x_102; +x_102 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_102); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_103; uint8_t x_104; +x_103 = lean_ctor_get(x_18, 1); +lean_inc(x_103); +lean_dec(x_18); +x_104 = lean_expr_eqv(x_2, x_3); +if (x_104 == 0) +{ +lean_object* x_105; lean_object* x_106; +x_105 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_105); +lean_ctor_set(x_106, 1, x_103); +return x_106; +} +else +{ +lean_object* x_107; +x_107 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_1); +lean_ctor_set(x_107, 1, x_103); +return x_107; +} +} +} +} +else +{ +uint8_t x_108; +lean_dec(x_11); lean_dec(x_7); lean_dec(x_1); -x_93 = !lean_is_exclusive(x_75); -if (x_93 == 0) +x_108 = !lean_is_exclusive(x_18); +if (x_108 == 0) { -return x_75; +return x_18; } else { -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_75, 0); -x_95 = lean_ctor_get(x_75, 1); +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_18, 0); +x_110 = lean_ctor_get(x_18, 1); +lean_inc(x_110); +lean_inc(x_109); +lean_dec(x_18); +x_111 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_111, 0, x_109); +lean_ctor_set(x_111, 1, x_110); +return x_111; +} +} +} +} +} +} +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; +x_5 = lean_nat_dec_lt(x_4, x_3); +if (x_5 == 0) +{ +uint8_t x_6; +lean_dec(x_4); +x_6 = 0; +return x_6; +} +else +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_fget(x_2, x_4); +x_8 = l_Lean_Expr_hasExprMVar(x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +x_9 = lean_unsigned_to_nat(1u); +x_10 = lean_nat_add(x_4, x_9); +lean_dec(x_4); +x_4 = x_10; +goto _start; +} +else +{ +lean_dec(x_4); +return x_8; +} +} +} +} +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_fget(x_3, x_5); +x_9 = l_Lean_Expr_hasExprMVar(x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_5, x_10); +lean_dec(x_5); +x_2 = lean_box(0); +x_5 = x_11; +goto _start; +} +else +{ +lean_dec(x_5); +return x_9; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l_Lean_Meta_inferType(x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +lean_inc(x_3); +x_8 = l_Lean_Meta_whnf(x_6, x_3, x_7); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_10 = lean_ctor_get(x_8, 0); +x_11 = lean_ctor_get(x_8, 1); +x_12 = l_Lean_Expr_getAppFn___main(x_10); +x_13 = l_Lean_RecursorVal_getInduct(x_1); +x_14 = l_Lean_Expr_isConstOf(x_12, x_13); +lean_dec(x_13); +lean_dec(x_12); +if (x_14 == 0) +{ +lean_object* x_15; +lean_dec(x_10); +lean_dec(x_3); +lean_dec(x_1); +x_15 = lean_box(0); +lean_ctor_set(x_8, 0, x_15); +return x_8; +} +else +{ +uint8_t x_16; +x_16 = l_Lean_Expr_hasExprMVar(x_10); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +lean_free_object(x_8); +x_17 = lean_ctor_get(x_1, 2); +lean_inc(x_17); +lean_dec(x_1); +x_18 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_19 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_18, x_10, x_17, x_3, x_11); +lean_dec(x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +if (lean_obj_tag(x_20) == 0) +{ +uint8_t x_21; +lean_dec(x_10); +lean_dec(x_3); +x_21 = !lean_is_exclusive(x_19); +if (x_21 == 0) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_19, 0); +lean_dec(x_22); +return x_19; +} +else +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_19, 1); +lean_inc(x_23); +lean_dec(x_19); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_20); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +else +{ +lean_object* x_25; uint8_t x_26; +x_25 = lean_ctor_get(x_19, 1); +lean_inc(x_25); +lean_dec(x_19); +x_26 = !lean_is_exclusive(x_20); +if (x_26 == 0) +{ +lean_object* x_27; lean_object* x_28; +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_3); +lean_inc(x_27); +x_28 = l_Lean_Meta_inferType(x_27, x_3, x_25); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = l_Lean_Meta_isExprDefEqAux(x_10, x_29, x_3, x_30); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; uint8_t x_33; +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_unbox(x_32); +lean_dec(x_32); +if (x_33 == 0) +{ +uint8_t x_34; +lean_free_object(x_20); +lean_dec(x_27); +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; +x_35 = lean_ctor_get(x_31, 0); +lean_dec(x_35); +x_36 = lean_box(0); +lean_ctor_set(x_31, 0, x_36); +return x_31; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_37 = lean_ctor_get(x_31, 1); +lean_inc(x_37); +lean_dec(x_31); +x_38 = lean_box(0); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_37); +return x_39; +} +} +else +{ +uint8_t x_40; +x_40 = !lean_is_exclusive(x_31); +if (x_40 == 0) +{ +lean_object* x_41; +x_41 = lean_ctor_get(x_31, 0); +lean_dec(x_41); +lean_ctor_set(x_31, 0, x_20); +return x_31; +} +else +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_31, 1); +lean_inc(x_42); +lean_dec(x_31); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_20); +lean_ctor_set(x_43, 1, x_42); +return x_43; +} +} +} +else +{ +uint8_t x_44; +lean_free_object(x_20); +lean_dec(x_27); +x_44 = !lean_is_exclusive(x_31); +if (x_44 == 0) +{ +return x_31; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_31, 0); +x_46 = lean_ctor_get(x_31, 1); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_31); +x_47 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_47, 0, x_45); +lean_ctor_set(x_47, 1, x_46); +return x_47; +} +} +} +else +{ +uint8_t x_48; +lean_free_object(x_20); +lean_dec(x_27); +lean_dec(x_10); +lean_dec(x_3); +x_48 = !lean_is_exclusive(x_28); +if (x_48 == 0) +{ +return x_28; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_28, 0); +x_50 = lean_ctor_get(x_28, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_28); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +else +{ +lean_object* x_52; lean_object* x_53; +x_52 = lean_ctor_get(x_20, 0); +lean_inc(x_52); +lean_dec(x_20); +lean_inc(x_3); +lean_inc(x_52); +x_53 = l_Lean_Meta_inferType(x_52, x_3, x_25); +if (lean_obj_tag(x_53) == 0) +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_54 = lean_ctor_get(x_53, 0); +lean_inc(x_54); +x_55 = lean_ctor_get(x_53, 1); +lean_inc(x_55); +lean_dec(x_53); +x_56 = l_Lean_Meta_isExprDefEqAux(x_10, x_54, x_3, x_55); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; uint8_t x_58; +x_57 = lean_ctor_get(x_56, 0); +lean_inc(x_57); +x_58 = lean_unbox(x_57); +lean_dec(x_57); +if (x_58 == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +lean_dec(x_52); +x_59 = lean_ctor_get(x_56, 1); +lean_inc(x_59); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_60 = x_56; +} else { + lean_dec_ref(x_56); + x_60 = lean_box(0); +} +x_61 = lean_box(0); +if (lean_is_scalar(x_60)) { + x_62 = lean_alloc_ctor(0, 2, 0); +} else { + x_62 = x_60; +} +lean_ctor_set(x_62, 0, x_61); +lean_ctor_set(x_62, 1, x_59); +return x_62; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_63 = lean_ctor_get(x_56, 1); +lean_inc(x_63); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_64 = x_56; +} else { + lean_dec_ref(x_56); + x_64 = lean_box(0); +} +x_65 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_65, 0, x_52); +if (lean_is_scalar(x_64)) { + x_66 = lean_alloc_ctor(0, 2, 0); +} else { + x_66 = x_64; +} +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_63); +return x_66; +} +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +lean_dec(x_52); +x_67 = lean_ctor_get(x_56, 0); +lean_inc(x_67); +x_68 = lean_ctor_get(x_56, 1); +lean_inc(x_68); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_69 = x_56; +} else { + lean_dec_ref(x_56); + x_69 = lean_box(0); +} +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(1, 2, 0); +} else { + x_70 = x_69; +} +lean_ctor_set(x_70, 0, x_67); +lean_ctor_set(x_70, 1, x_68); +return x_70; +} +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +lean_dec(x_52); +lean_dec(x_10); +lean_dec(x_3); +x_71 = lean_ctor_get(x_53, 0); +lean_inc(x_71); +x_72 = lean_ctor_get(x_53, 1); +lean_inc(x_72); +if (lean_is_exclusive(x_53)) { + lean_ctor_release(x_53, 0); + lean_ctor_release(x_53, 1); + x_73 = x_53; +} else { + lean_dec_ref(x_53); + x_73 = lean_box(0); +} +if (lean_is_scalar(x_73)) { + x_74 = lean_alloc_ctor(1, 2, 0); +} else { + x_74 = x_73; +} +lean_ctor_set(x_74, 0, x_71); +lean_ctor_set(x_74, 1, x_72); +return x_74; +} +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_10); +lean_dec(x_3); +x_75 = !lean_is_exclusive(x_19); +if (x_75 == 0) +{ +return x_19; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_19, 0); +x_77 = lean_ctor_get(x_19, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_19); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; uint8_t x_88; +x_79 = lean_unsigned_to_nat(0u); +x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_79); +x_81 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_80); +x_82 = lean_mk_array(x_80, x_81); +x_83 = lean_unsigned_to_nat(1u); +x_84 = lean_nat_sub(x_80, x_83); +lean_dec(x_80); +lean_inc(x_10); +x_85 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_10, x_82, x_84); +x_86 = lean_ctor_get(x_1, 2); +lean_inc(x_86); +lean_dec(x_1); +x_87 = lean_array_get_size(x_85); +x_88 = lean_nat_dec_le(x_87, x_87); +if (x_88 == 0) +{ +uint8_t x_89; +lean_inc(x_86); +x_89 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__6(x_10, x_85, x_87, x_86); +lean_dec(x_87); +lean_dec(x_85); +if (x_89 == 0) +{ +lean_object* x_90; lean_object* x_91; +lean_free_object(x_8); +x_90 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_91 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_90, x_10, x_86, x_3, x_11); +lean_dec(x_86); +if (lean_obj_tag(x_91) == 0) +{ +lean_object* x_92; +x_92 = lean_ctor_get(x_91, 0); +lean_inc(x_92); +if (lean_obj_tag(x_92) == 0) +{ +uint8_t x_93; +lean_dec(x_10); +lean_dec(x_3); +x_93 = !lean_is_exclusive(x_91); +if (x_93 == 0) +{ +lean_object* x_94; +x_94 = lean_ctor_get(x_91, 0); +lean_dec(x_94); +return x_91; +} +else +{ +lean_object* x_95; lean_object* x_96; +x_95 = lean_ctor_get(x_91, 1); lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_75); -x_96 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_96, 0, x_94); +lean_dec(x_91); +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_92); lean_ctor_set(x_96, 1, x_95); return x_96; } } -} -} else { -uint8_t x_97; -lean_dec(x_47); -lean_dec(x_14); -lean_dec(x_13); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_1); -x_97 = !lean_is_exclusive(x_52); -if (x_97 == 0) +lean_object* x_97; uint8_t x_98; +x_97 = lean_ctor_get(x_91, 1); +lean_inc(x_97); +lean_dec(x_91); +x_98 = !lean_is_exclusive(x_92); +if (x_98 == 0) { -return x_52; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_98 = lean_ctor_get(x_52, 0); -x_99 = lean_ctor_get(x_52, 1); +lean_object* x_99; lean_object* x_100; +x_99 = lean_ctor_get(x_92, 0); +lean_inc(x_3); lean_inc(x_99); -lean_inc(x_98); -lean_dec(x_52); -x_100 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_100, 0, x_98); -lean_ctor_set(x_100, 1, x_99); +x_100 = l_Lean_Meta_inferType(x_99, x_3, x_97); +if (lean_obj_tag(x_100) == 0) +{ +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); +lean_inc(x_101); +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = l_Lean_Meta_isExprDefEqAux(x_10, x_101, x_3, x_102); +if (lean_obj_tag(x_103) == 0) +{ +lean_object* x_104; uint8_t x_105; +x_104 = lean_ctor_get(x_103, 0); +lean_inc(x_104); +x_105 = lean_unbox(x_104); +lean_dec(x_104); +if (x_105 == 0) +{ +uint8_t x_106; +lean_free_object(x_92); +lean_dec(x_99); +x_106 = !lean_is_exclusive(x_103); +if (x_106 == 0) +{ +lean_object* x_107; lean_object* x_108; +x_107 = lean_ctor_get(x_103, 0); +lean_dec(x_107); +x_108 = lean_box(0); +lean_ctor_set(x_103, 0, x_108); +return x_103; +} +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_103, 1); +lean_inc(x_109); +lean_dec(x_103); +x_110 = lean_box(0); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_109); +return x_111; +} +} +else +{ +uint8_t x_112; +x_112 = !lean_is_exclusive(x_103); +if (x_112 == 0) +{ +lean_object* x_113; +x_113 = lean_ctor_get(x_103, 0); +lean_dec(x_113); +lean_ctor_set(x_103, 0, x_92); +return x_103; +} +else +{ +lean_object* x_114; lean_object* x_115; +x_114 = lean_ctor_get(x_103, 1); +lean_inc(x_114); +lean_dec(x_103); +x_115 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_115, 0, x_92); +lean_ctor_set(x_115, 1, x_114); +return x_115; +} +} +} +else +{ +uint8_t x_116; +lean_free_object(x_92); +lean_dec(x_99); +x_116 = !lean_is_exclusive(x_103); +if (x_116 == 0) +{ +return x_103; +} +else +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_103, 0); +x_118 = lean_ctor_get(x_103, 1); +lean_inc(x_118); +lean_inc(x_117); +lean_dec(x_103); +x_119 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_119, 0, x_117); +lean_ctor_set(x_119, 1, x_118); +return x_119; +} +} +} +else +{ +uint8_t x_120; +lean_free_object(x_92); +lean_dec(x_99); +lean_dec(x_10); +lean_dec(x_3); +x_120 = !lean_is_exclusive(x_100); +if (x_120 == 0) +{ +return x_100; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; +x_121 = lean_ctor_get(x_100, 0); +x_122 = lean_ctor_get(x_100, 1); +lean_inc(x_122); +lean_inc(x_121); +lean_dec(x_100); +x_123 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_123, 0, x_121); +lean_ctor_set(x_123, 1, x_122); +return x_123; +} +} +} +else +{ +lean_object* x_124; lean_object* x_125; +x_124 = lean_ctor_get(x_92, 0); +lean_inc(x_124); +lean_dec(x_92); +lean_inc(x_3); +lean_inc(x_124); +x_125 = l_Lean_Meta_inferType(x_124, x_3, x_97); +if (lean_obj_tag(x_125) == 0) +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_125, 1); +lean_inc(x_127); +lean_dec(x_125); +x_128 = l_Lean_Meta_isExprDefEqAux(x_10, x_126, x_3, x_127); +if (lean_obj_tag(x_128) == 0) +{ +lean_object* x_129; uint8_t x_130; +x_129 = lean_ctor_get(x_128, 0); +lean_inc(x_129); +x_130 = lean_unbox(x_129); +lean_dec(x_129); +if (x_130 == 0) +{ +lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +lean_dec(x_124); +x_131 = lean_ctor_get(x_128, 1); +lean_inc(x_131); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_132 = x_128; +} else { + lean_dec_ref(x_128); + x_132 = lean_box(0); +} +x_133 = lean_box(0); +if (lean_is_scalar(x_132)) { + x_134 = lean_alloc_ctor(0, 2, 0); +} else { + x_134 = x_132; +} +lean_ctor_set(x_134, 0, x_133); +lean_ctor_set(x_134, 1, x_131); +return x_134; +} +else +{ +lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_135 = lean_ctor_get(x_128, 1); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_137, 0, x_124); +if (lean_is_scalar(x_136)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_136; +} +lean_ctor_set(x_138, 0, x_137); +lean_ctor_set(x_138, 1, x_135); +return x_138; +} +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; +lean_dec(x_124); +x_139 = lean_ctor_get(x_128, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_128, 1); +lean_inc(x_140); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_141 = x_128; +} else { + lean_dec_ref(x_128); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(1, 2, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_139); +lean_ctor_set(x_142, 1, x_140); +return x_142; +} +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; +lean_dec(x_124); +lean_dec(x_10); +lean_dec(x_3); +x_143 = lean_ctor_get(x_125, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_125, 1); +lean_inc(x_144); +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_145 = x_125; +} else { + lean_dec_ref(x_125); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(1, 2, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_143); +lean_ctor_set(x_146, 1, x_144); +return x_146; +} +} +} +} +else +{ +uint8_t x_147; +lean_dec(x_10); +lean_dec(x_3); +x_147 = !lean_is_exclusive(x_91); +if (x_147 == 0) +{ +return x_91; +} +else +{ +lean_object* x_148; lean_object* x_149; lean_object* x_150; +x_148 = lean_ctor_get(x_91, 0); +x_149 = lean_ctor_get(x_91, 1); +lean_inc(x_149); +lean_inc(x_148); +lean_dec(x_91); +x_150 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_150, 0, x_148); +lean_ctor_set(x_150, 1, x_149); +return x_150; +} +} +} +else +{ +lean_object* x_151; +lean_dec(x_86); +lean_dec(x_10); +lean_dec(x_3); +x_151 = lean_box(0); +lean_ctor_set(x_8, 0, x_151); +return x_8; +} +} +else +{ +uint8_t x_152; +lean_inc(x_86); +x_152 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__7(x_10, lean_box(0), x_85, x_87, x_86); +lean_dec(x_87); +lean_dec(x_85); +if (x_152 == 0) +{ +lean_object* x_153; lean_object* x_154; +lean_free_object(x_8); +x_153 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_154 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_153, x_10, x_86, x_3, x_11); +lean_dec(x_86); +if (lean_obj_tag(x_154) == 0) +{ +lean_object* x_155; +x_155 = lean_ctor_get(x_154, 0); +lean_inc(x_155); +if (lean_obj_tag(x_155) == 0) +{ +uint8_t x_156; +lean_dec(x_10); +lean_dec(x_3); +x_156 = !lean_is_exclusive(x_154); +if (x_156 == 0) +{ +lean_object* x_157; +x_157 = lean_ctor_get(x_154, 0); +lean_dec(x_157); +return x_154; +} +else +{ +lean_object* x_158; lean_object* x_159; +x_158 = lean_ctor_get(x_154, 1); +lean_inc(x_158); +lean_dec(x_154); +x_159 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_159, 0, x_155); +lean_ctor_set(x_159, 1, x_158); +return x_159; +} +} +else +{ +lean_object* x_160; uint8_t x_161; +x_160 = lean_ctor_get(x_154, 1); +lean_inc(x_160); +lean_dec(x_154); +x_161 = !lean_is_exclusive(x_155); +if (x_161 == 0) +{ +lean_object* x_162; lean_object* x_163; +x_162 = lean_ctor_get(x_155, 0); +lean_inc(x_3); +lean_inc(x_162); +x_163 = l_Lean_Meta_inferType(x_162, x_3, x_160); +if (lean_obj_tag(x_163) == 0) +{ +lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_164 = lean_ctor_get(x_163, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_163, 1); +lean_inc(x_165); +lean_dec(x_163); +x_166 = l_Lean_Meta_isExprDefEqAux(x_10, x_164, x_3, x_165); +if (lean_obj_tag(x_166) == 0) +{ +lean_object* x_167; uint8_t x_168; +x_167 = lean_ctor_get(x_166, 0); +lean_inc(x_167); +x_168 = lean_unbox(x_167); +lean_dec(x_167); +if (x_168 == 0) +{ +uint8_t x_169; +lean_free_object(x_155); +lean_dec(x_162); +x_169 = !lean_is_exclusive(x_166); +if (x_169 == 0) +{ +lean_object* x_170; lean_object* x_171; +x_170 = lean_ctor_get(x_166, 0); +lean_dec(x_170); +x_171 = lean_box(0); +lean_ctor_set(x_166, 0, x_171); +return x_166; +} +else +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_166, 1); +lean_inc(x_172); +lean_dec(x_166); +x_173 = lean_box(0); +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_173); +lean_ctor_set(x_174, 1, x_172); +return x_174; +} +} +else +{ +uint8_t x_175; +x_175 = !lean_is_exclusive(x_166); +if (x_175 == 0) +{ +lean_object* x_176; +x_176 = lean_ctor_get(x_166, 0); +lean_dec(x_176); +lean_ctor_set(x_166, 0, x_155); +return x_166; +} +else +{ +lean_object* x_177; lean_object* x_178; +x_177 = lean_ctor_get(x_166, 1); +lean_inc(x_177); +lean_dec(x_166); +x_178 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_178, 0, x_155); +lean_ctor_set(x_178, 1, x_177); +return x_178; +} +} +} +else +{ +uint8_t x_179; +lean_free_object(x_155); +lean_dec(x_162); +x_179 = !lean_is_exclusive(x_166); +if (x_179 == 0) +{ +return x_166; +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; +x_180 = lean_ctor_get(x_166, 0); +x_181 = lean_ctor_get(x_166, 1); +lean_inc(x_181); +lean_inc(x_180); +lean_dec(x_166); +x_182 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_182, 0, x_180); +lean_ctor_set(x_182, 1, x_181); +return x_182; +} +} +} +else +{ +uint8_t x_183; +lean_free_object(x_155); +lean_dec(x_162); +lean_dec(x_10); +lean_dec(x_3); +x_183 = !lean_is_exclusive(x_163); +if (x_183 == 0) +{ +return x_163; +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_184 = lean_ctor_get(x_163, 0); +x_185 = lean_ctor_get(x_163, 1); +lean_inc(x_185); +lean_inc(x_184); +lean_dec(x_163); +x_186 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_186, 0, x_184); +lean_ctor_set(x_186, 1, x_185); +return x_186; +} +} +} +else +{ +lean_object* x_187; lean_object* x_188; +x_187 = lean_ctor_get(x_155, 0); +lean_inc(x_187); +lean_dec(x_155); +lean_inc(x_3); +lean_inc(x_187); +x_188 = l_Lean_Meta_inferType(x_187, x_3, x_160); +if (lean_obj_tag(x_188) == 0) +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_189 = lean_ctor_get(x_188, 0); +lean_inc(x_189); +x_190 = lean_ctor_get(x_188, 1); +lean_inc(x_190); +lean_dec(x_188); +x_191 = l_Lean_Meta_isExprDefEqAux(x_10, x_189, x_3, x_190); +if (lean_obj_tag(x_191) == 0) +{ +lean_object* x_192; uint8_t x_193; +x_192 = lean_ctor_get(x_191, 0); +lean_inc(x_192); +x_193 = lean_unbox(x_192); +lean_dec(x_192); +if (x_193 == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; +lean_dec(x_187); +x_194 = lean_ctor_get(x_191, 1); +lean_inc(x_194); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_195 = x_191; +} else { + lean_dec_ref(x_191); + x_195 = lean_box(0); +} +x_196 = lean_box(0); +if (lean_is_scalar(x_195)) { + x_197 = lean_alloc_ctor(0, 2, 0); +} else { + x_197 = x_195; +} +lean_ctor_set(x_197, 0, x_196); +lean_ctor_set(x_197, 1, x_194); +return x_197; +} +else +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; +x_198 = lean_ctor_get(x_191, 1); +lean_inc(x_198); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_199 = x_191; +} else { + lean_dec_ref(x_191); + x_199 = lean_box(0); +} +x_200 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_200, 0, x_187); +if (lean_is_scalar(x_199)) { + x_201 = lean_alloc_ctor(0, 2, 0); +} else { + x_201 = x_199; +} +lean_ctor_set(x_201, 0, x_200); +lean_ctor_set(x_201, 1, x_198); +return x_201; +} +} +else +{ +lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; +lean_dec(x_187); +x_202 = lean_ctor_get(x_191, 0); +lean_inc(x_202); +x_203 = lean_ctor_get(x_191, 1); +lean_inc(x_203); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_204 = x_191; +} else { + lean_dec_ref(x_191); + x_204 = lean_box(0); +} +if (lean_is_scalar(x_204)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_204; +} +lean_ctor_set(x_205, 0, x_202); +lean_ctor_set(x_205, 1, x_203); +return x_205; +} +} +else +{ +lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +lean_dec(x_187); +lean_dec(x_10); +lean_dec(x_3); +x_206 = lean_ctor_get(x_188, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_188, 1); +lean_inc(x_207); +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + x_208 = x_188; +} else { + lean_dec_ref(x_188); + x_208 = lean_box(0); +} +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(1, 2, 0); +} else { + x_209 = x_208; +} +lean_ctor_set(x_209, 0, x_206); +lean_ctor_set(x_209, 1, x_207); +return x_209; +} +} +} +} +else +{ +uint8_t x_210; +lean_dec(x_10); +lean_dec(x_3); +x_210 = !lean_is_exclusive(x_154); +if (x_210 == 0) +{ +return x_154; +} +else +{ +lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_211 = lean_ctor_get(x_154, 0); +x_212 = lean_ctor_get(x_154, 1); +lean_inc(x_212); +lean_inc(x_211); +lean_dec(x_154); +x_213 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_213, 0, x_211); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +} +} +else +{ +lean_object* x_214; +lean_dec(x_86); +lean_dec(x_10); +lean_dec(x_3); +x_214 = lean_box(0); +lean_ctor_set(x_8, 0, x_214); +return x_8; +} +} +} +} +} +else +{ +lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; uint8_t x_219; +x_215 = lean_ctor_get(x_8, 0); +x_216 = lean_ctor_get(x_8, 1); +lean_inc(x_216); +lean_inc(x_215); +lean_dec(x_8); +x_217 = l_Lean_Expr_getAppFn___main(x_215); +x_218 = l_Lean_RecursorVal_getInduct(x_1); +x_219 = l_Lean_Expr_isConstOf(x_217, x_218); +lean_dec(x_218); +lean_dec(x_217); +if (x_219 == 0) +{ +lean_object* x_220; lean_object* x_221; +lean_dec(x_215); +lean_dec(x_3); +lean_dec(x_1); +x_220 = lean_box(0); +x_221 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_221, 0, x_220); +lean_ctor_set(x_221, 1, x_216); +return x_221; +} +else +{ +uint8_t x_222; +x_222 = l_Lean_Expr_hasExprMVar(x_215); +if (x_222 == 0) +{ +lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_223 = lean_ctor_get(x_1, 2); +lean_inc(x_223); +lean_dec(x_1); +x_224 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_225 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_224, x_215, x_223, x_3, x_216); +lean_dec(x_223); +if (lean_obj_tag(x_225) == 0) +{ +lean_object* x_226; +x_226 = lean_ctor_get(x_225, 0); +lean_inc(x_226); +if (lean_obj_tag(x_226) == 0) +{ +lean_object* x_227; lean_object* x_228; lean_object* x_229; +lean_dec(x_215); +lean_dec(x_3); +x_227 = lean_ctor_get(x_225, 1); +lean_inc(x_227); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + x_228 = x_225; +} else { + lean_dec_ref(x_225); + x_228 = lean_box(0); +} +if (lean_is_scalar(x_228)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_228; +} +lean_ctor_set(x_229, 0, x_226); +lean_ctor_set(x_229, 1, x_227); +return x_229; +} +else +{ +lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_230 = lean_ctor_get(x_225, 1); +lean_inc(x_230); +lean_dec(x_225); +x_231 = lean_ctor_get(x_226, 0); +lean_inc(x_231); +if (lean_is_exclusive(x_226)) { + lean_ctor_release(x_226, 0); + x_232 = x_226; +} else { + lean_dec_ref(x_226); + x_232 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_231); +x_233 = l_Lean_Meta_inferType(x_231, x_3, x_230); +if (lean_obj_tag(x_233) == 0) +{ +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = l_Lean_Meta_isExprDefEqAux(x_215, x_234, x_3, x_235); +if (lean_obj_tag(x_236) == 0) +{ +lean_object* x_237; uint8_t x_238; +x_237 = lean_ctor_get(x_236, 0); +lean_inc(x_237); +x_238 = lean_unbox(x_237); +lean_dec(x_237); +if (x_238 == 0) +{ +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; +lean_dec(x_232); +lean_dec(x_231); +x_239 = lean_ctor_get(x_236, 1); +lean_inc(x_239); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_240 = x_236; +} else { + lean_dec_ref(x_236); + x_240 = lean_box(0); +} +x_241 = lean_box(0); +if (lean_is_scalar(x_240)) { + x_242 = lean_alloc_ctor(0, 2, 0); +} else { + x_242 = x_240; +} +lean_ctor_set(x_242, 0, x_241); +lean_ctor_set(x_242, 1, x_239); +return x_242; +} +else +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_243 = lean_ctor_get(x_236, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_244 = x_236; +} else { + lean_dec_ref(x_236); + x_244 = lean_box(0); +} +if (lean_is_scalar(x_232)) { + x_245 = lean_alloc_ctor(1, 1, 0); +} else { + x_245 = x_232; +} +lean_ctor_set(x_245, 0, x_231); +if (lean_is_scalar(x_244)) { + x_246 = lean_alloc_ctor(0, 2, 0); +} else { + x_246 = x_244; +} +lean_ctor_set(x_246, 0, x_245); +lean_ctor_set(x_246, 1, x_243); +return x_246; +} +} +else +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; +lean_dec(x_232); +lean_dec(x_231); +x_247 = lean_ctor_get(x_236, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_236, 1); +lean_inc(x_248); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_249 = x_236; +} else { + lean_dec_ref(x_236); + x_249 = lean_box(0); +} +if (lean_is_scalar(x_249)) { + x_250 = lean_alloc_ctor(1, 2, 0); +} else { + x_250 = x_249; +} +lean_ctor_set(x_250, 0, x_247); +lean_ctor_set(x_250, 1, x_248); +return x_250; +} +} +else +{ +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; +lean_dec(x_232); +lean_dec(x_231); +lean_dec(x_215); +lean_dec(x_3); +x_251 = lean_ctor_get(x_233, 0); +lean_inc(x_251); +x_252 = lean_ctor_get(x_233, 1); +lean_inc(x_252); +if (lean_is_exclusive(x_233)) { + lean_ctor_release(x_233, 0); + lean_ctor_release(x_233, 1); + x_253 = x_233; +} else { + lean_dec_ref(x_233); + x_253 = lean_box(0); +} +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(1, 2, 0); +} else { + x_254 = x_253; +} +lean_ctor_set(x_254, 0, x_251); +lean_ctor_set(x_254, 1, x_252); +return x_254; +} +} +} +else +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +lean_dec(x_215); +lean_dec(x_3); +x_255 = lean_ctor_get(x_225, 0); +lean_inc(x_255); +x_256 = lean_ctor_get(x_225, 1); +lean_inc(x_256); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + x_257 = x_225; +} else { + lean_dec_ref(x_225); + x_257 = lean_box(0); +} +if (lean_is_scalar(x_257)) { + x_258 = lean_alloc_ctor(1, 2, 0); +} else { + x_258 = x_257; +} +lean_ctor_set(x_258, 0, x_255); +lean_ctor_set(x_258, 1, x_256); +return x_258; +} +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; uint8_t x_268; +x_259 = lean_unsigned_to_nat(0u); +x_260 = l_Lean_Expr_getAppNumArgsAux___main(x_215, x_259); +x_261 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_260); +x_262 = lean_mk_array(x_260, x_261); +x_263 = lean_unsigned_to_nat(1u); +x_264 = lean_nat_sub(x_260, x_263); +lean_dec(x_260); +lean_inc(x_215); +x_265 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_215, x_262, x_264); +x_266 = lean_ctor_get(x_1, 2); +lean_inc(x_266); +lean_dec(x_1); +x_267 = lean_array_get_size(x_265); +x_268 = lean_nat_dec_le(x_267, x_267); +if (x_268 == 0) +{ +uint8_t x_269; +lean_inc(x_266); +x_269 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__6(x_215, x_265, x_267, x_266); +lean_dec(x_267); +lean_dec(x_265); +if (x_269 == 0) +{ +lean_object* x_270; lean_object* x_271; +x_270 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_271 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_270, x_215, x_266, x_3, x_216); +lean_dec(x_266); +if (lean_obj_tag(x_271) == 0) +{ +lean_object* x_272; +x_272 = lean_ctor_get(x_271, 0); +lean_inc(x_272); +if (lean_obj_tag(x_272) == 0) +{ +lean_object* x_273; lean_object* x_274; lean_object* x_275; +lean_dec(x_215); +lean_dec(x_3); +x_273 = lean_ctor_get(x_271, 1); +lean_inc(x_273); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + x_274 = x_271; +} else { + lean_dec_ref(x_271); + x_274 = lean_box(0); +} +if (lean_is_scalar(x_274)) { + x_275 = lean_alloc_ctor(0, 2, 0); +} else { + x_275 = x_274; +} +lean_ctor_set(x_275, 0, x_272); +lean_ctor_set(x_275, 1, x_273); +return x_275; +} +else +{ +lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; +x_276 = lean_ctor_get(x_271, 1); +lean_inc(x_276); +lean_dec(x_271); +x_277 = lean_ctor_get(x_272, 0); +lean_inc(x_277); +if (lean_is_exclusive(x_272)) { + lean_ctor_release(x_272, 0); + x_278 = x_272; +} else { + lean_dec_ref(x_272); + x_278 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_277); +x_279 = l_Lean_Meta_inferType(x_277, x_3, x_276); +if (lean_obj_tag(x_279) == 0) +{ +lean_object* x_280; lean_object* x_281; lean_object* x_282; +x_280 = lean_ctor_get(x_279, 0); +lean_inc(x_280); +x_281 = lean_ctor_get(x_279, 1); +lean_inc(x_281); +lean_dec(x_279); +x_282 = l_Lean_Meta_isExprDefEqAux(x_215, x_280, x_3, x_281); +if (lean_obj_tag(x_282) == 0) +{ +lean_object* x_283; uint8_t x_284; +x_283 = lean_ctor_get(x_282, 0); +lean_inc(x_283); +x_284 = lean_unbox(x_283); +lean_dec(x_283); +if (x_284 == 0) +{ +lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; +lean_dec(x_278); +lean_dec(x_277); +x_285 = lean_ctor_get(x_282, 1); +lean_inc(x_285); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_286 = x_282; +} else { + lean_dec_ref(x_282); + x_286 = lean_box(0); +} +x_287 = lean_box(0); +if (lean_is_scalar(x_286)) { + x_288 = lean_alloc_ctor(0, 2, 0); +} else { + x_288 = x_286; +} +lean_ctor_set(x_288, 0, x_287); +lean_ctor_set(x_288, 1, x_285); +return x_288; +} +else +{ +lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; +x_289 = lean_ctor_get(x_282, 1); +lean_inc(x_289); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_290 = x_282; +} else { + lean_dec_ref(x_282); + x_290 = lean_box(0); +} +if (lean_is_scalar(x_278)) { + x_291 = lean_alloc_ctor(1, 1, 0); +} else { + x_291 = x_278; +} +lean_ctor_set(x_291, 0, x_277); +if (lean_is_scalar(x_290)) { + x_292 = lean_alloc_ctor(0, 2, 0); +} else { + x_292 = x_290; +} +lean_ctor_set(x_292, 0, x_291); +lean_ctor_set(x_292, 1, x_289); +return x_292; +} +} +else +{ +lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +lean_dec(x_278); +lean_dec(x_277); +x_293 = lean_ctor_get(x_282, 0); +lean_inc(x_293); +x_294 = lean_ctor_get(x_282, 1); +lean_inc(x_294); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_295 = x_282; +} else { + lean_dec_ref(x_282); + x_295 = lean_box(0); +} +if (lean_is_scalar(x_295)) { + x_296 = lean_alloc_ctor(1, 2, 0); +} else { + x_296 = x_295; +} +lean_ctor_set(x_296, 0, x_293); +lean_ctor_set(x_296, 1, x_294); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; +lean_dec(x_278); +lean_dec(x_277); +lean_dec(x_215); +lean_dec(x_3); +x_297 = lean_ctor_get(x_279, 0); +lean_inc(x_297); +x_298 = lean_ctor_get(x_279, 1); +lean_inc(x_298); +if (lean_is_exclusive(x_279)) { + lean_ctor_release(x_279, 0); + lean_ctor_release(x_279, 1); + x_299 = x_279; +} else { + lean_dec_ref(x_279); + x_299 = lean_box(0); +} +if (lean_is_scalar(x_299)) { + x_300 = lean_alloc_ctor(1, 2, 0); +} else { + x_300 = x_299; +} +lean_ctor_set(x_300, 0, x_297); +lean_ctor_set(x_300, 1, x_298); +return x_300; +} +} +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; +lean_dec(x_215); +lean_dec(x_3); +x_301 = lean_ctor_get(x_271, 0); +lean_inc(x_301); +x_302 = lean_ctor_get(x_271, 1); +lean_inc(x_302); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + x_303 = x_271; +} else { + lean_dec_ref(x_271); + x_303 = lean_box(0); +} +if (lean_is_scalar(x_303)) { + x_304 = lean_alloc_ctor(1, 2, 0); +} else { + x_304 = x_303; +} +lean_ctor_set(x_304, 0, x_301); +lean_ctor_set(x_304, 1, x_302); +return x_304; +} +} +else +{ +lean_object* x_305; lean_object* x_306; +lean_dec(x_266); +lean_dec(x_215); +lean_dec(x_3); +x_305 = lean_box(0); +x_306 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_306, 0, x_305); +lean_ctor_set(x_306, 1, x_216); +return x_306; +} +} +else +{ +uint8_t x_307; +lean_inc(x_266); +x_307 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__7(x_215, lean_box(0), x_265, x_267, x_266); +lean_dec(x_267); +lean_dec(x_265); +if (x_307 == 0) +{ +lean_object* x_308; lean_object* x_309; +x_308 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_309 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_308, x_215, x_266, x_3, x_216); +lean_dec(x_266); +if (lean_obj_tag(x_309) == 0) +{ +lean_object* x_310; +x_310 = lean_ctor_get(x_309, 0); +lean_inc(x_310); +if (lean_obj_tag(x_310) == 0) +{ +lean_object* x_311; lean_object* x_312; lean_object* x_313; +lean_dec(x_215); +lean_dec(x_3); +x_311 = lean_ctor_get(x_309, 1); +lean_inc(x_311); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_312 = x_309; +} else { + lean_dec_ref(x_309); + x_312 = lean_box(0); +} +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 2, 0); +} else { + x_313 = x_312; +} +lean_ctor_set(x_313, 0, x_310); +lean_ctor_set(x_313, 1, x_311); +return x_313; +} +else +{ +lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_314 = lean_ctor_get(x_309, 1); +lean_inc(x_314); +lean_dec(x_309); +x_315 = lean_ctor_get(x_310, 0); +lean_inc(x_315); +if (lean_is_exclusive(x_310)) { + lean_ctor_release(x_310, 0); + x_316 = x_310; +} else { + lean_dec_ref(x_310); + x_316 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_315); +x_317 = l_Lean_Meta_inferType(x_315, x_3, x_314); +if (lean_obj_tag(x_317) == 0) +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; +x_318 = lean_ctor_get(x_317, 0); +lean_inc(x_318); +x_319 = lean_ctor_get(x_317, 1); +lean_inc(x_319); +lean_dec(x_317); +x_320 = l_Lean_Meta_isExprDefEqAux(x_215, x_318, x_3, x_319); +if (lean_obj_tag(x_320) == 0) +{ +lean_object* x_321; uint8_t x_322; +x_321 = lean_ctor_get(x_320, 0); +lean_inc(x_321); +x_322 = lean_unbox(x_321); +lean_dec(x_321); +if (x_322 == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; +lean_dec(x_316); +lean_dec(x_315); +x_323 = lean_ctor_get(x_320, 1); +lean_inc(x_323); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_324 = x_320; +} else { + lean_dec_ref(x_320); + x_324 = lean_box(0); +} +x_325 = lean_box(0); +if (lean_is_scalar(x_324)) { + x_326 = lean_alloc_ctor(0, 2, 0); +} else { + x_326 = x_324; +} +lean_ctor_set(x_326, 0, x_325); +lean_ctor_set(x_326, 1, x_323); +return x_326; +} +else +{ +lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_327 = lean_ctor_get(x_320, 1); +lean_inc(x_327); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_328 = x_320; +} else { + lean_dec_ref(x_320); + x_328 = lean_box(0); +} +if (lean_is_scalar(x_316)) { + x_329 = lean_alloc_ctor(1, 1, 0); +} else { + x_329 = x_316; +} +lean_ctor_set(x_329, 0, x_315); +if (lean_is_scalar(x_328)) { + x_330 = lean_alloc_ctor(0, 2, 0); +} else { + x_330 = x_328; +} +lean_ctor_set(x_330, 0, x_329); +lean_ctor_set(x_330, 1, x_327); +return x_330; +} +} +else +{ +lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; +lean_dec(x_316); +lean_dec(x_315); +x_331 = lean_ctor_get(x_320, 0); +lean_inc(x_331); +x_332 = lean_ctor_get(x_320, 1); +lean_inc(x_332); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_333 = x_320; +} else { + lean_dec_ref(x_320); + x_333 = lean_box(0); +} +if (lean_is_scalar(x_333)) { + x_334 = lean_alloc_ctor(1, 2, 0); +} else { + x_334 = x_333; +} +lean_ctor_set(x_334, 0, x_331); +lean_ctor_set(x_334, 1, x_332); +return x_334; +} +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; +lean_dec(x_316); +lean_dec(x_315); +lean_dec(x_215); +lean_dec(x_3); +x_335 = lean_ctor_get(x_317, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_317, 1); +lean_inc(x_336); +if (lean_is_exclusive(x_317)) { + lean_ctor_release(x_317, 0); + lean_ctor_release(x_317, 1); + x_337 = x_317; +} else { + lean_dec_ref(x_317); + x_337 = lean_box(0); +} +if (lean_is_scalar(x_337)) { + x_338 = lean_alloc_ctor(1, 2, 0); +} else { + x_338 = x_337; +} +lean_ctor_set(x_338, 0, x_335); +lean_ctor_set(x_338, 1, x_336); +return x_338; +} +} +} +else +{ +lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; +lean_dec(x_215); +lean_dec(x_3); +x_339 = lean_ctor_get(x_309, 0); +lean_inc(x_339); +x_340 = lean_ctor_get(x_309, 1); +lean_inc(x_340); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_341 = x_309; +} else { + lean_dec_ref(x_309); + x_341 = lean_box(0); +} +if (lean_is_scalar(x_341)) { + x_342 = lean_alloc_ctor(1, 2, 0); +} else { + x_342 = x_341; +} +lean_ctor_set(x_342, 0, x_339); +lean_ctor_set(x_342, 1, x_340); +return x_342; +} +} +else +{ +lean_object* x_343; lean_object* x_344; +lean_dec(x_266); +lean_dec(x_215); +lean_dec(x_3); +x_343 = lean_box(0); +x_344 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_344, 0, x_343); +lean_ctor_set(x_344, 1, x_216); +return x_344; +} +} +} +} +} +} +else +{ +uint8_t x_345; +lean_dec(x_3); +lean_dec(x_1); +x_345 = !lean_is_exclusive(x_8); +if (x_345 == 0) +{ +return x_8; +} +else +{ +lean_object* x_346; lean_object* x_347; lean_object* x_348; +x_346 = lean_ctor_get(x_8, 0); +x_347 = lean_ctor_get(x_8, 1); +lean_inc(x_347); +lean_inc(x_346); +lean_dec(x_8); +x_348 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_348, 0, x_346); +lean_ctor_set(x_348, 1, x_347); +return x_348; +} +} +} +else +{ +uint8_t x_349; +lean_dec(x_3); +lean_dec(x_1); +x_349 = !lean_is_exclusive(x_5); +if (x_349 == 0) +{ +return x_5; +} +else +{ +lean_object* x_350; lean_object* x_351; lean_object* x_352; +x_350 = lean_ctor_get(x_5, 0); +x_351 = lean_ctor_get(x_5, 1); +lean_inc(x_351); +lean_inc(x_350); +lean_dec(x_5); +x_352 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_352, 0, x_350); +lean_ctor_set(x_352, 1, x_351); +return x_352; +} +} +} +} +lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_9 = l_Lean_RecursorVal_getMajorIdx(x_4); +x_10 = lean_array_get_size(x_6); +x_11 = lean_nat_dec_lt(x_9, x_10); +if (x_11 == 0) +{ +uint8_t x_12; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_12 = lean_expr_eqv(x_2, x_3); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_8); +return x_14; +} +else +{ +lean_object* x_15; +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_1); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_array_fget(x_6, x_9); +lean_inc(x_7); +x_17 = l_Lean_Meta_whnf(x_16, x_7, x_8); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_62; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + lean_ctor_release(x_17, 1); + x_20 = x_17; +} else { + lean_dec_ref(x_17); + x_20 = lean_box(0); +} +x_62 = lean_ctor_get_uint8(x_4, sizeof(void*)*7); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; +lean_dec(x_20); +x_63 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_18); +lean_dec(x_18); +lean_inc(x_4); +x_64 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_63); +if (lean_obj_tag(x_64) == 0) +{ +uint8_t x_65; +lean_dec(x_63); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_65 = lean_expr_eqv(x_2, x_3); +if (x_65 == 0) +{ +lean_object* x_66; lean_object* x_67; +x_66 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_19); +return x_67; +} +else +{ +lean_object* x_68; +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_1); +lean_ctor_set(x_68, 1, x_19); +return x_68; +} +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; uint8_t x_81; +x_69 = lean_ctor_get(x_64, 0); +lean_inc(x_69); +lean_dec(x_64); +x_70 = lean_unsigned_to_nat(0u); +x_71 = l_Lean_Expr_getAppNumArgsAux___main(x_63, x_70); +x_72 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_71); +x_73 = lean_mk_array(x_71, x_72); +x_74 = lean_unsigned_to_nat(1u); +x_75 = lean_nat_sub(x_71, x_74); +lean_dec(x_71); +x_76 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_63, x_73, x_75); +x_77 = l_List_lengthAux___main___rarg(x_5, x_70); +x_78 = lean_ctor_get(x_4, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_78, 1); +lean_inc(x_79); +lean_dec(x_78); +x_80 = l_List_lengthAux___main___rarg(x_79, x_70); +x_81 = lean_nat_dec_eq(x_77, x_80); +lean_dec(x_80); +lean_dec(x_77); +if (x_81 == 0) +{ +uint8_t x_82; +lean_dec(x_79); +lean_dec(x_76); +lean_dec(x_69); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_82 = lean_expr_eqv(x_2, x_3); +if (x_82 == 0) +{ +lean_object* x_83; lean_object* x_84; +x_83 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_84 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_19); +return x_84; +} +else +{ +lean_object* x_85; +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_1); +lean_ctor_set(x_85, 1, x_19); +return x_85; +} +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +lean_dec(x_1); +x_86 = lean_ctor_get(x_69, 2); +lean_inc(x_86); +x_87 = lean_instantiate_lparams(x_86, x_79, x_5); +x_88 = lean_ctor_get(x_4, 2); +lean_inc(x_88); +x_89 = lean_ctor_get(x_4, 4); +lean_inc(x_89); +x_90 = lean_nat_add(x_88, x_89); +lean_dec(x_89); +lean_dec(x_88); +x_91 = lean_ctor_get(x_4, 5); +lean_inc(x_91); +lean_dec(x_4); +x_92 = lean_nat_add(x_90, x_91); +lean_dec(x_91); +lean_dec(x_90); +x_93 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_92, x_6, x_70, x_87); +lean_dec(x_92); +x_94 = lean_array_get_size(x_76); +x_95 = lean_ctor_get(x_69, 1); +lean_inc(x_95); +lean_dec(x_69); +x_96 = lean_nat_sub(x_94, x_95); +lean_dec(x_95); +x_97 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_94, x_76, x_96, x_93); +lean_dec(x_76); +lean_dec(x_94); +x_98 = lean_nat_add(x_9, x_74); +lean_dec(x_9); +x_99 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_98, x_97); +lean_dec(x_10); +x_100 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_99, x_7, x_19); return x_100; } } } -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: +else { -lean_object* x_10; uint8_t x_11; -x_10 = lean_ctor_get(x_9, 4); -lean_inc(x_10); -x_11 = lean_ctor_get_uint8(x_10, sizeof(void*)*1); +lean_object* x_101; +lean_inc(x_7); +lean_inc(x_18); +lean_inc(x_4); +x_101 = l___private_Init_Lean_WHNF_5__toCtorWhenK___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__5(x_4, x_18, x_7, x_19); +if (lean_obj_tag(x_101) == 0) +{ +lean_object* x_102; +x_102 = lean_ctor_get(x_101, 0); +lean_inc(x_102); +if (lean_obj_tag(x_102) == 0) +{ +lean_object* x_103; +x_103 = lean_ctor_get(x_101, 1); +lean_inc(x_103); +lean_dec(x_101); +x_21 = x_18; +x_22 = x_103; +goto block_61; +} +else +{ +lean_object* x_104; lean_object* x_105; +lean_dec(x_18); +x_104 = lean_ctor_get(x_101, 1); +lean_inc(x_104); +lean_dec(x_101); +x_105 = lean_ctor_get(x_102, 0); +lean_inc(x_105); +lean_dec(x_102); +x_21 = x_105; +x_22 = x_104; +goto block_61; +} +} +else +{ +uint8_t x_106; +lean_dec(x_20); +lean_dec(x_18); lean_dec(x_10); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_6); +lean_dec(x_9); +lean_dec(x_7); lean_dec(x_5); lean_dec(x_4); -lean_dec(x_3); -x_12 = lean_apply_4(x_1, x_7, x_2, x_8, x_9); -if (lean_obj_tag(x_12) == 0) +lean_dec(x_1); +x_106 = !lean_is_exclusive(x_101); +if (x_106 == 0) { -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_unbox(x_14); -lean_dec(x_14); -x_16 = l_Bool_toLBool(x_15); -x_17 = lean_box(x_16); -lean_ctor_set(x_12, 0, x_17); -return x_12; +return x_101; } else { -lean_object* x_18; lean_object* x_19; uint8_t x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); +lean_object* x_107; lean_object* x_108; lean_object* x_109; +x_107 = lean_ctor_get(x_101, 0); +x_108 = lean_ctor_get(x_101, 1); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_101); +x_109 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_109, 0, x_107); +lean_ctor_set(x_109, 1, x_108); +return x_109; +} +} +} +block_61: +{ +lean_object* x_23; lean_object* x_24; +x_23 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_21); +lean_dec(x_21); +lean_inc(x_4); +x_24 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_23); +if (lean_obj_tag(x_24) == 0) +{ +uint8_t x_25; +lean_dec(x_23); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_25 = lean_expr_eqv(x_2, x_3); +if (x_25 == 0) +{ +lean_object* x_26; lean_object* x_27; +x_26 = l_Lean_Expr_updateFn___main(x_1, x_3); +if (lean_is_scalar(x_20)) { + x_27 = lean_alloc_ctor(0, 2, 0); +} else { + x_27 = x_20; +} +lean_ctor_set(x_27, 0, x_26); +lean_ctor_set(x_27, 1, x_22); +return x_27; +} +else +{ +lean_object* x_28; +if (lean_is_scalar(x_20)) { + x_28 = lean_alloc_ctor(0, 2, 0); +} else { + x_28 = x_20; +} +lean_ctor_set(x_28, 0, x_1); +lean_ctor_set(x_28, 1, x_22); +return x_28; +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; uint8_t x_41; +x_29 = lean_ctor_get(x_24, 0); +lean_inc(x_29); +lean_dec(x_24); +x_30 = lean_unsigned_to_nat(0u); +x_31 = l_Lean_Expr_getAppNumArgsAux___main(x_23, x_30); +x_32 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_31); +x_33 = lean_mk_array(x_31, x_32); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_sub(x_31, x_34); +lean_dec(x_31); +x_36 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_23, x_33, x_35); +x_37 = l_List_lengthAux___main___rarg(x_5, x_30); +x_38 = lean_ctor_get(x_4, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_38, 1); +lean_inc(x_39); +lean_dec(x_38); +x_40 = l_List_lengthAux___main___rarg(x_39, x_30); +x_41 = lean_nat_dec_eq(x_37, x_40); +lean_dec(x_40); +lean_dec(x_37); +if (x_41 == 0) +{ +uint8_t x_42; +lean_dec(x_39); +lean_dec(x_36); +lean_dec(x_29); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_42 = lean_expr_eqv(x_2, x_3); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = l_Lean_Expr_updateFn___main(x_1, x_3); +if (lean_is_scalar(x_20)) { + x_44 = lean_alloc_ctor(0, 2, 0); +} else { + x_44 = x_20; +} +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_22); +return x_44; +} +else +{ +lean_object* x_45; +if (lean_is_scalar(x_20)) { + x_45 = lean_alloc_ctor(0, 2, 0); +} else { + x_45 = x_20; +} +lean_ctor_set(x_45, 0, x_1); +lean_ctor_set(x_45, 1, x_22); +return x_45; +} +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +lean_dec(x_20); +lean_dec(x_1); +x_46 = lean_ctor_get(x_29, 2); +lean_inc(x_46); +x_47 = lean_instantiate_lparams(x_46, x_39, x_5); +x_48 = lean_ctor_get(x_4, 2); +lean_inc(x_48); +x_49 = lean_ctor_get(x_4, 4); +lean_inc(x_49); +x_50 = lean_nat_add(x_48, x_49); +lean_dec(x_49); +lean_dec(x_48); +x_51 = lean_ctor_get(x_4, 5); +lean_inc(x_51); +lean_dec(x_4); +x_52 = lean_nat_add(x_50, x_51); +lean_dec(x_51); +lean_dec(x_50); +x_53 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_52, x_6, x_30, x_47); +lean_dec(x_52); +x_54 = lean_array_get_size(x_36); +x_55 = lean_ctor_get(x_29, 1); +lean_inc(x_55); +lean_dec(x_29); +x_56 = lean_nat_sub(x_54, x_55); +lean_dec(x_55); +x_57 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_54, x_36, x_56, x_53); +lean_dec(x_36); +lean_dec(x_54); +x_58 = lean_nat_add(x_9, x_34); +lean_dec(x_9); +x_59 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_58, x_57); +lean_dec(x_10); +x_60 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_59, x_7, x_22); +return x_60; +} +} +} +} +else +{ +uint8_t x_110; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_110 = !lean_is_exclusive(x_17); +if (x_110 == 0) +{ +return x_17; +} +else +{ +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_17, 0); +x_112 = lean_ctor_get(x_17, 1); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_17); +x_113 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_113, 0, x_111); +lean_ctor_set(x_113, 1, x_112); +return x_113; +} +} +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_LocalDecl_value_x3f(x_3); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_1, 0); +lean_inc(x_7); +lean_dec(x_1); +x_8 = lean_ctor_get(x_7, 1); +lean_inc(x_8); +lean_dec(x_7); +x_9 = lean_apply_4(x_8, lean_box(0), x_2, x_4, x_5); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_2); +x_10 = lean_ctor_get(x_6, 0); +lean_inc(x_10); +lean_dec(x_6); +x_11 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8(x_1, x_10, x_4, x_5); +return x_11; +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +lean_dec(x_1); +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_4, x_5); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_2); +x_9 = lean_ctor_get(x_3, 0); +lean_inc(x_9); +lean_dec(x_3); +x_10 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8(x_1, x_9, x_4, x_5); +return x_10; +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +switch (lean_obj_tag(x_2)) { +case 0: +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +lean_dec(x_2); +x_10 = l_Lean_Expr_Inhabited; +x_11 = l_monadInhabited___rarg(x_1, x_10); +x_12 = l_unreachable_x21___rarg(x_11); +x_13 = lean_apply_2(x_12, x_3, x_4); +return x_13; +} +case 1: +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_14 = lean_ctor_get(x_2, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_1, 1); +lean_inc(x_15); +x_16 = lean_alloc_closure((void*)(l_Lean_Meta_getLocalDecl), 3, 1); +lean_closure_set(x_16, 0, x_14); +x_17 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__1___boxed), 5, 2); +lean_closure_set(x_17, 0, x_1); +lean_closure_set(x_17, 1, x_2); +x_18 = lean_apply_6(x_15, lean_box(0), lean_box(0), x_16, x_17, x_3, x_4); +return x_18; +} +case 2: +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_19 = lean_ctor_get(x_2, 0); lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_12); -x_20 = lean_unbox(x_18); -lean_dec(x_18); -x_21 = l_Bool_toLBool(x_20); -x_22 = lean_box(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); +x_20 = lean_ctor_get(x_1, 1); +lean_inc(x_20); +x_21 = lean_alloc_closure((void*)(l_Lean_Meta_getExprMVarAssignment___boxed), 3, 1); +lean_closure_set(x_21, 0, x_19); +x_22 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__2), 5, 2); +lean_closure_set(x_22, 0, x_1); +lean_closure_set(x_22, 1, x_2); +x_23 = lean_apply_6(x_20, lean_box(0), lean_box(0), x_21, x_22, x_3, x_4); return x_23; } -} -else +case 4: { -uint8_t x_24; -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) -{ -return x_12; +lean_object* x_24; +lean_dec(x_3); +lean_dec(x_1); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_2); +lean_ctor_set(x_24, 1, x_4); +return x_24; } -else +case 5: { lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); +lean_dec(x_1); +x_25 = lean_ctor_get(x_2, 0); lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); +x_26 = l_Lean_Expr_getAppFn___main(x_25); +lean_dec(x_25); +lean_inc(x_3); +lean_inc(x_26); +x_27 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_26, x_3, x_4); +if (lean_obj_tag(x_27) == 0) +{ +uint8_t x_28; +x_28 = !lean_is_exclusive(x_27); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; uint8_t x_31; +x_29 = lean_ctor_get(x_27, 0); +x_30 = lean_ctor_get(x_27, 1); +x_31 = l_Lean_Expr_isLambda(x_29); +if (x_31 == 0) +{ +if (lean_obj_tag(x_29) == 4) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; +lean_free_object(x_27); +x_32 = lean_ctor_get(x_29, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_29, 1); +lean_inc(x_33); +x_34 = 0; +x_35 = l_Lean_Meta_getConstAux(x_32, x_34, x_3, x_30); +if (lean_obj_tag(x_35) == 0) +{ +lean_object* x_36; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +if (lean_obj_tag(x_36) == 0) +{ +uint8_t x_37; +lean_dec(x_33); +lean_dec(x_3); +x_37 = !lean_is_exclusive(x_35); +if (x_37 == 0) +{ +lean_object* x_38; uint8_t x_39; +x_38 = lean_ctor_get(x_35, 0); +lean_dec(x_38); +x_39 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_39 == 0) +{ +lean_object* x_40; +x_40 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_40); +return x_35; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_2); +return x_35; +} +} +else +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 1); +lean_inc(x_41); +lean_dec(x_35); +x_42 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_41); +return x_44; +} +else +{ +lean_object* x_45; +lean_dec(x_29); +x_45 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_45, 0, x_2); +lean_ctor_set(x_45, 1, x_41); +return x_45; +} +} +} +else +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_36, 0); +lean_inc(x_46); +lean_dec(x_36); +switch (lean_obj_tag(x_46)) { +case 1: +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; uint8_t x_51; +x_47 = lean_ctor_get(x_35, 1); +lean_inc(x_47); +lean_dec(x_35); +x_48 = l_Lean_ConstantInfo_name(x_46); +x_49 = l_Lean_Meta_isAuxDef_x3f(x_48, x_3, x_47); +lean_dec(x_48); +x_50 = lean_ctor_get(x_49, 0); +lean_inc(x_50); +x_51 = lean_unbox(x_50); +lean_dec(x_50); +if (x_51 == 0) +{ +uint8_t x_52; +lean_dec(x_46); +lean_dec(x_33); +lean_dec(x_3); +x_52 = !lean_is_exclusive(x_49); +if (x_52 == 0) +{ +lean_object* x_53; uint8_t x_54; +x_53 = lean_ctor_get(x_49, 0); +lean_dec(x_53); +x_54 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_54 == 0) +{ +lean_object* x_55; +x_55 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_49, 0, x_55); +return x_49; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_49, 0, x_2); +return x_49; +} +} +else +{ +lean_object* x_56; uint8_t x_57; +x_56 = lean_ctor_get(x_49, 1); +lean_inc(x_56); +lean_dec(x_49); +x_57 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; +x_58 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_58); +lean_ctor_set(x_59, 1, x_56); +return x_59; +} +else +{ +lean_object* x_60; +lean_dec(x_29); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_2); +lean_ctor_set(x_60, 1, x_56); +return x_60; +} +} +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_61 = lean_ctor_get(x_49, 1); +lean_inc(x_61); +lean_dec(x_49); +x_62 = lean_unsigned_to_nat(0u); +x_63 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_62); +x_64 = lean_mk_empty_array_with_capacity(x_63); +lean_dec(x_63); +lean_inc(x_2); +x_65 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_64); +x_66 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__2(x_2, x_26, x_29, x_46, x_33, x_65, x_3, x_61); +lean_dec(x_29); +lean_dec(x_26); +return x_66; +} +} +case 4: +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_67 = lean_ctor_get(x_35, 1); +lean_inc(x_67); +lean_dec(x_35); +x_68 = lean_ctor_get(x_46, 0); +lean_inc(x_68); +lean_dec(x_46); +x_69 = lean_unsigned_to_nat(0u); +x_70 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_69); +x_71 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_70); +x_72 = lean_mk_array(x_70, x_71); +x_73 = lean_unsigned_to_nat(1u); +x_74 = lean_nat_sub(x_70, x_73); +lean_dec(x_70); +lean_inc(x_2); +x_75 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_72, x_74); +x_76 = l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__3(x_2, x_26, x_29, x_68, x_33, x_75, x_3, x_67); +lean_dec(x_75); +lean_dec(x_33); +lean_dec(x_68); +lean_dec(x_29); +lean_dec(x_26); +return x_76; +} +case 7: +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_77 = lean_ctor_get(x_35, 1); +lean_inc(x_77); +lean_dec(x_35); +x_78 = lean_ctor_get(x_46, 0); +lean_inc(x_78); +lean_dec(x_46); +x_79 = lean_unsigned_to_nat(0u); +x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_79); +x_81 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_80); +x_82 = lean_mk_array(x_80, x_81); +x_83 = lean_unsigned_to_nat(1u); +x_84 = lean_nat_sub(x_80, x_83); +lean_dec(x_80); +lean_inc(x_2); +x_85 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_82, x_84); +x_86 = l_Lean_reduceRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__4(x_2, x_26, x_29, x_78, x_33, x_85, x_3, x_77); +lean_dec(x_85); +lean_dec(x_29); +lean_dec(x_26); +return x_86; +} +default: +{ +uint8_t x_87; +lean_dec(x_46); +lean_dec(x_33); +lean_dec(x_3); +x_87 = !lean_is_exclusive(x_35); +if (x_87 == 0) +{ +lean_object* x_88; uint8_t x_89; +x_88 = lean_ctor_get(x_35, 0); +lean_dec(x_88); +x_89 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_89 == 0) +{ +lean_object* x_90; +x_90 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_90); +return x_35; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_2); +return x_35; +} +} +else +{ +lean_object* x_91; uint8_t x_92; +x_91 = lean_ctor_get(x_35, 1); +lean_inc(x_91); +lean_dec(x_35); +x_92 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_92 == 0) +{ +lean_object* x_93; lean_object* x_94; +x_93 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_94 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_94, 0, x_93); +lean_ctor_set(x_94, 1, x_91); +return x_94; +} +else +{ +lean_object* x_95; +lean_dec(x_29); +x_95 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_95, 0, x_2); +lean_ctor_set(x_95, 1, x_91); +return x_95; +} +} +} +} +} +} +else +{ +uint8_t x_96; +lean_dec(x_33); +lean_dec(x_29); +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_96 = !lean_is_exclusive(x_35); +if (x_96 == 0) +{ +return x_35; +} +else +{ +lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_97 = lean_ctor_get(x_35, 0); +x_98 = lean_ctor_get(x_35, 1); +lean_inc(x_98); +lean_inc(x_97); +lean_dec(x_35); +x_99 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_99, 0, x_97); +lean_ctor_set(x_99, 1, x_98); +return x_99; +} +} +} +else +{ +uint8_t x_100; +lean_dec(x_3); +x_100 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_100 == 0) +{ +lean_object* x_101; +x_101 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_27, 0, x_101); +return x_27; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_27, 0, x_2); return x_27; } } } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_28 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1; -x_29 = lean_name_mk_string(x_3, x_28); -x_30 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_inc(x_29); -x_31 = l_Lean_Name_append___main(x_30, x_29); -x_32 = l_Lean_Meta_tracer; -x_33 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_4, x_32, x_31); -lean_inc(x_8); -x_34 = lean_apply_2(x_33, x_8, x_9); -if (lean_obj_tag(x_34) == 0) -{ -lean_object* x_35; uint8_t x_36; -x_35 = lean_ctor_get(x_34, 0); -lean_inc(x_35); -x_36 = lean_unbox(x_35); -lean_dec(x_35); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +lean_free_object(x_27); lean_dec(x_29); +x_102 = lean_unsigned_to_nat(0u); +x_103 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_102); +x_104 = lean_mk_empty_array_with_capacity(x_103); +lean_dec(x_103); +x_105 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_104); +x_106 = l_Lean_Expr_betaRev(x_26, x_105); +lean_dec(x_26); +x_107 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_106, x_3, x_30); +return x_107; +} +} +else +{ +lean_object* x_108; lean_object* x_109; uint8_t x_110; +x_108 = lean_ctor_get(x_27, 0); +x_109 = lean_ctor_get(x_27, 1); +lean_inc(x_109); +lean_inc(x_108); +lean_dec(x_27); +x_110 = l_Lean_Expr_isLambda(x_108); +if (x_110 == 0) +{ +if (lean_obj_tag(x_108) == 4) +{ +lean_object* x_111; lean_object* x_112; uint8_t x_113; lean_object* x_114; +x_111 = lean_ctor_get(x_108, 0); +lean_inc(x_111); +x_112 = lean_ctor_get(x_108, 1); +lean_inc(x_112); +x_113 = 0; +x_114 = l_Lean_Meta_getConstAux(x_111, x_113, x_3, x_109); +if (lean_obj_tag(x_114) == 0) +{ +lean_object* x_115; +x_115 = lean_ctor_get(x_114, 0); +lean_inc(x_115); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; uint8_t x_118; +lean_dec(x_112); +lean_dec(x_3); +x_116 = lean_ctor_get(x_114, 1); +lean_inc(x_116); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_117 = x_114; +} else { + lean_dec_ref(x_114); + x_117 = lean_box(0); +} +x_118 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_118 == 0) +{ +lean_object* x_119; lean_object* x_120; +x_119 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_117)) { + x_120 = lean_alloc_ctor(0, 2, 0); +} else { + x_120 = x_117; +} +lean_ctor_set(x_120, 0, x_119); +lean_ctor_set(x_120, 1, x_116); +return x_120; +} +else +{ +lean_object* x_121; +lean_dec(x_108); +if (lean_is_scalar(x_117)) { + x_121 = lean_alloc_ctor(0, 2, 0); +} else { + x_121 = x_117; +} +lean_ctor_set(x_121, 0, x_2); +lean_ctor_set(x_121, 1, x_116); +return x_121; +} +} +else +{ +lean_object* x_122; +x_122 = lean_ctor_get(x_115, 0); +lean_inc(x_122); +lean_dec(x_115); +switch (lean_obj_tag(x_122)) { +case 1: +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; uint8_t x_127; +x_123 = lean_ctor_get(x_114, 1); +lean_inc(x_123); +lean_dec(x_114); +x_124 = l_Lean_ConstantInfo_name(x_122); +x_125 = l_Lean_Meta_isAuxDef_x3f(x_124, x_3, x_123); +lean_dec(x_124); +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_unbox(x_126); +lean_dec(x_126); +if (x_127 == 0) +{ +lean_object* x_128; lean_object* x_129; uint8_t x_130; +lean_dec(x_122); +lean_dec(x_112); +lean_dec(x_3); +x_128 = lean_ctor_get(x_125, 1); +lean_inc(x_128); +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_129 = x_125; +} else { + lean_dec_ref(x_125); + x_129 = lean_box(0); +} +x_130 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_130 == 0) +{ +lean_object* x_131; lean_object* x_132; +x_131 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_129)) { + x_132 = lean_alloc_ctor(0, 2, 0); +} else { + x_132 = x_129; +} +lean_ctor_set(x_132, 0, x_131); +lean_ctor_set(x_132, 1, x_128); +return x_132; +} +else +{ +lean_object* x_133; +lean_dec(x_108); +if (lean_is_scalar(x_129)) { + x_133 = lean_alloc_ctor(0, 2, 0); +} else { + x_133 = x_129; +} +lean_ctor_set(x_133, 0, x_2); +lean_ctor_set(x_133, 1, x_128); +return x_133; +} +} +else +{ +lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; +x_134 = lean_ctor_get(x_125, 1); +lean_inc(x_134); +lean_dec(x_125); +x_135 = lean_unsigned_to_nat(0u); +x_136 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_135); +x_137 = lean_mk_empty_array_with_capacity(x_136); +lean_dec(x_136); +lean_inc(x_2); +x_138 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_137); +x_139 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__2(x_2, x_26, x_108, x_122, x_112, x_138, x_3, x_134); +lean_dec(x_108); +lean_dec(x_26); +return x_139; +} +} +case 4: +{ +lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_140 = lean_ctor_get(x_114, 1); +lean_inc(x_140); +lean_dec(x_114); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +lean_dec(x_122); +x_142 = lean_unsigned_to_nat(0u); +x_143 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_142); +x_144 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_143); +x_145 = lean_mk_array(x_143, x_144); +x_146 = lean_unsigned_to_nat(1u); +x_147 = lean_nat_sub(x_143, x_146); +lean_dec(x_143); +lean_inc(x_2); +x_148 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_145, x_147); +x_149 = l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__3(x_2, x_26, x_108, x_141, x_112, x_148, x_3, x_140); +lean_dec(x_148); +lean_dec(x_112); +lean_dec(x_141); +lean_dec(x_108); +lean_dec(x_26); +return x_149; +} +case 7: +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_150 = lean_ctor_get(x_114, 1); +lean_inc(x_150); +lean_dec(x_114); +x_151 = lean_ctor_get(x_122, 0); +lean_inc(x_151); +lean_dec(x_122); +x_152 = lean_unsigned_to_nat(0u); +x_153 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_152); +x_154 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_153); +x_155 = lean_mk_array(x_153, x_154); +x_156 = lean_unsigned_to_nat(1u); +x_157 = lean_nat_sub(x_153, x_156); +lean_dec(x_153); +lean_inc(x_2); +x_158 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_155, x_157); +x_159 = l_Lean_reduceRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__4(x_2, x_26, x_108, x_151, x_112, x_158, x_3, x_150); +lean_dec(x_158); +lean_dec(x_108); +lean_dec(x_26); +return x_159; +} +default: +{ +lean_object* x_160; lean_object* x_161; uint8_t x_162; +lean_dec(x_122); +lean_dec(x_112); +lean_dec(x_3); +x_160 = lean_ctor_get(x_114, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_161 = x_114; +} else { + lean_dec_ref(x_114); + x_161 = lean_box(0); +} +x_162 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_162 == 0) +{ +lean_object* x_163; lean_object* x_164; +x_163 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_161)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_161; +} +lean_ctor_set(x_164, 0, x_163); +lean_ctor_set(x_164, 1, x_160); +return x_164; +} +else +{ +lean_object* x_165; +lean_dec(x_108); +if (lean_is_scalar(x_161)) { + x_165 = lean_alloc_ctor(0, 2, 0); +} else { + x_165 = x_161; +} +lean_ctor_set(x_165, 0, x_2); +lean_ctor_set(x_165, 1, x_160); +return x_165; +} +} +} +} +} +else +{ +lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; +lean_dec(x_112); +lean_dec(x_108); +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_166 = lean_ctor_get(x_114, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_114, 1); +lean_inc(x_167); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_168 = x_114; +} else { + lean_dec_ref(x_114); + x_168 = lean_box(0); +} +if (lean_is_scalar(x_168)) { + x_169 = lean_alloc_ctor(1, 2, 0); +} else { + x_169 = x_168; +} +lean_ctor_set(x_169, 0, x_166); +lean_ctor_set(x_169, 1, x_167); +return x_169; +} +} +else +{ +uint8_t x_170; +lean_dec(x_3); +x_170 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_170 == 0) +{ +lean_object* x_171; lean_object* x_172; +x_171 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_171); +lean_ctor_set(x_172, 1, x_109); +return x_172; +} +else +{ +lean_object* x_173; +lean_dec(x_108); +x_173 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_173, 0, x_2); +lean_ctor_set(x_173, 1, x_109); +return x_173; +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; +lean_dec(x_108); +x_174 = lean_unsigned_to_nat(0u); +x_175 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_174); +x_176 = lean_mk_empty_array_with_capacity(x_175); +lean_dec(x_175); +x_177 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_176); +x_178 = l_Lean_Expr_betaRev(x_26, x_177); +lean_dec(x_26); +x_179 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_178, x_3, x_109); +return x_179; +} +} +} +else +{ +uint8_t x_180; +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_180 = !lean_is_exclusive(x_27); +if (x_180 == 0) +{ +return x_27; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_27, 0); +x_182 = lean_ctor_get(x_27, 1); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_27); +x_183 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_183, 0, x_181); +lean_ctor_set(x_183, 1, x_182); +return x_183; +} +} +} +case 8: +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; +lean_dec(x_1); +x_184 = lean_ctor_get(x_2, 2); +lean_inc(x_184); +x_185 = lean_ctor_get(x_2, 3); +lean_inc(x_185); +lean_dec(x_2); +x_186 = lean_expr_instantiate1(x_185, x_184); +lean_dec(x_184); +lean_dec(x_185); +x_187 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_186, x_3, x_4); +return x_187; +} +case 10: +{ +lean_object* x_188; +x_188 = lean_ctor_get(x_2, 1); +lean_inc(x_188); +lean_dec(x_2); +x_2 = x_188; +goto _start; +} +case 11: +{ +lean_object* x_190; lean_object* x_191; lean_object* x_192; +lean_dec(x_1); +x_190 = lean_ctor_get(x_2, 1); +lean_inc(x_190); +x_191 = lean_ctor_get(x_2, 2); +lean_inc(x_191); +lean_inc(x_3); +x_192 = l_Lean_Meta_whnf(x_191, x_3, x_4); +if (lean_obj_tag(x_192) == 0) +{ +uint8_t x_193; +x_193 = !lean_is_exclusive(x_192); +if (x_193 == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; +x_194 = lean_ctor_get(x_192, 0); +x_195 = lean_ctor_get(x_192, 1); +x_196 = l_Lean_Expr_getAppFn___main(x_194); +if (lean_obj_tag(x_196) == 4) +{ +lean_object* x_197; uint8_t x_198; lean_object* x_199; +lean_free_object(x_192); +x_197 = lean_ctor_get(x_196, 0); +lean_inc(x_197); +lean_dec(x_196); +x_198 = 0; +x_199 = l_Lean_Meta_getConstAux(x_197, x_198, x_3, x_195); +lean_dec(x_3); +if (lean_obj_tag(x_199) == 0) +{ +lean_object* x_200; +x_200 = lean_ctor_get(x_199, 0); +lean_inc(x_200); +if (lean_obj_tag(x_200) == 0) +{ +uint8_t x_201; +lean_dec(x_194); +lean_dec(x_190); +x_201 = !lean_is_exclusive(x_199); +if (x_201 == 0) +{ +lean_object* x_202; +x_202 = lean_ctor_get(x_199, 0); +lean_dec(x_202); +lean_ctor_set(x_199, 0, x_2); +return x_199; +} +else +{ +lean_object* x_203; lean_object* x_204; +x_203 = lean_ctor_get(x_199, 1); +lean_inc(x_203); +lean_dec(x_199); +x_204 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_204, 0, x_2); +lean_ctor_set(x_204, 1, x_203); +return x_204; +} +} +else +{ +lean_object* x_205; +x_205 = lean_ctor_get(x_200, 0); +lean_inc(x_205); +lean_dec(x_200); +if (lean_obj_tag(x_205) == 6) +{ +uint8_t x_206; +x_206 = !lean_is_exclusive(x_199); +if (x_206 == 0) +{ +lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_207 = lean_ctor_get(x_199, 0); +lean_dec(x_207); +x_208 = lean_ctor_get(x_205, 0); +lean_inc(x_208); +lean_dec(x_205); +x_209 = lean_ctor_get(x_208, 3); +lean_inc(x_209); +lean_dec(x_208); +x_210 = lean_nat_add(x_209, x_190); +lean_dec(x_190); +lean_dec(x_209); +x_211 = lean_unsigned_to_nat(0u); +x_212 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_211); +x_213 = lean_nat_sub(x_212, x_210); +lean_dec(x_210); +lean_dec(x_212); +x_214 = lean_unsigned_to_nat(1u); +x_215 = lean_nat_sub(x_213, x_214); +lean_dec(x_213); +x_216 = l_Lean_Expr_getRevArgD___main(x_194, x_215, x_2); +lean_dec(x_2); +lean_dec(x_194); +lean_ctor_set(x_199, 0, x_216); +return x_199; +} +else +{ +lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; +x_217 = lean_ctor_get(x_199, 1); +lean_inc(x_217); +lean_dec(x_199); +x_218 = lean_ctor_get(x_205, 0); +lean_inc(x_218); +lean_dec(x_205); +x_219 = lean_ctor_get(x_218, 3); +lean_inc(x_219); +lean_dec(x_218); +x_220 = lean_nat_add(x_219, x_190); +lean_dec(x_190); +lean_dec(x_219); +x_221 = lean_unsigned_to_nat(0u); +x_222 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_221); +x_223 = lean_nat_sub(x_222, x_220); +lean_dec(x_220); +lean_dec(x_222); +x_224 = lean_unsigned_to_nat(1u); +x_225 = lean_nat_sub(x_223, x_224); +lean_dec(x_223); +x_226 = l_Lean_Expr_getRevArgD___main(x_194, x_225, x_2); +lean_dec(x_2); +lean_dec(x_194); +x_227 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_227, 0, x_226); +lean_ctor_set(x_227, 1, x_217); +return x_227; +} +} +else +{ +uint8_t x_228; +lean_dec(x_205); +lean_dec(x_194); +lean_dec(x_190); +x_228 = !lean_is_exclusive(x_199); +if (x_228 == 0) +{ +lean_object* x_229; +x_229 = lean_ctor_get(x_199, 0); +lean_dec(x_229); +lean_ctor_set(x_199, 0, x_2); +return x_199; +} +else +{ +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_199, 1); +lean_inc(x_230); +lean_dec(x_199); +x_231 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_231, 0, x_2); +lean_ctor_set(x_231, 1, x_230); +return x_231; +} +} +} +} +else +{ +uint8_t x_232; +lean_dec(x_194); +lean_dec(x_190); +lean_dec(x_2); +x_232 = !lean_is_exclusive(x_199); +if (x_232 == 0) +{ +return x_199; +} +else +{ +lean_object* x_233; lean_object* x_234; lean_object* x_235; +x_233 = lean_ctor_get(x_199, 0); +x_234 = lean_ctor_get(x_199, 1); +lean_inc(x_234); +lean_inc(x_233); +lean_dec(x_199); +x_235 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_235, 0, x_233); +lean_ctor_set(x_235, 1, x_234); +return x_235; +} +} +} +else +{ +lean_dec(x_196); +lean_dec(x_194); +lean_dec(x_190); +lean_dec(x_3); +lean_ctor_set(x_192, 0, x_2); +return x_192; +} +} +else +{ +lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_236 = lean_ctor_get(x_192, 0); +x_237 = lean_ctor_get(x_192, 1); +lean_inc(x_237); +lean_inc(x_236); +lean_dec(x_192); +x_238 = l_Lean_Expr_getAppFn___main(x_236); +if (lean_obj_tag(x_238) == 4) +{ +lean_object* x_239; uint8_t x_240; lean_object* x_241; +x_239 = lean_ctor_get(x_238, 0); +lean_inc(x_239); +lean_dec(x_238); +x_240 = 0; +x_241 = l_Lean_Meta_getConstAux(x_239, x_240, x_3, x_237); +lean_dec(x_3); +if (lean_obj_tag(x_241) == 0) +{ +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; +lean_dec(x_236); +lean_dec(x_190); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_244 = x_241; +} else { + lean_dec_ref(x_241); + x_244 = lean_box(0); +} +if (lean_is_scalar(x_244)) { + x_245 = lean_alloc_ctor(0, 2, 0); +} else { + x_245 = x_244; +} +lean_ctor_set(x_245, 0, x_2); +lean_ctor_set(x_245, 1, x_243); +return x_245; +} +else +{ +lean_object* x_246; +x_246 = lean_ctor_get(x_242, 0); +lean_inc(x_246); +lean_dec(x_242); +if (lean_obj_tag(x_246) == 6) +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; +} else { + lean_dec_ref(x_241); + x_248 = lean_box(0); +} +x_249 = lean_ctor_get(x_246, 0); +lean_inc(x_249); +lean_dec(x_246); +x_250 = lean_ctor_get(x_249, 3); +lean_inc(x_250); +lean_dec(x_249); +x_251 = lean_nat_add(x_250, x_190); +lean_dec(x_190); +lean_dec(x_250); +x_252 = lean_unsigned_to_nat(0u); +x_253 = l_Lean_Expr_getAppNumArgsAux___main(x_236, x_252); +x_254 = lean_nat_sub(x_253, x_251); +lean_dec(x_251); +lean_dec(x_253); +x_255 = lean_unsigned_to_nat(1u); +x_256 = lean_nat_sub(x_254, x_255); +lean_dec(x_254); +x_257 = l_Lean_Expr_getRevArgD___main(x_236, x_256, x_2); +lean_dec(x_2); +lean_dec(x_236); +if (lean_is_scalar(x_248)) { + x_258 = lean_alloc_ctor(0, 2, 0); +} else { + x_258 = x_248; +} +lean_ctor_set(x_258, 0, x_257); +lean_ctor_set(x_258, 1, x_247); +return x_258; +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; +lean_dec(x_246); +lean_dec(x_236); +lean_dec(x_190); +x_259 = lean_ctor_get(x_241, 1); +lean_inc(x_259); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_260 = x_241; +} else { + lean_dec_ref(x_241); + x_260 = lean_box(0); +} +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 2, 0); +} else { + x_261 = x_260; +} +lean_ctor_set(x_261, 0, x_2); +lean_ctor_set(x_261, 1, x_259); +return x_261; +} +} +} +else +{ +lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; +lean_dec(x_236); +lean_dec(x_190); +lean_dec(x_2); +x_262 = lean_ctor_get(x_241, 0); +lean_inc(x_262); +x_263 = lean_ctor_get(x_241, 1); +lean_inc(x_263); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_264 = x_241; +} else { + lean_dec_ref(x_241); + x_264 = lean_box(0); +} +if (lean_is_scalar(x_264)) { + x_265 = lean_alloc_ctor(1, 2, 0); +} else { + x_265 = x_264; +} +lean_ctor_set(x_265, 0, x_262); +lean_ctor_set(x_265, 1, x_263); +return x_265; +} +} +else +{ +lean_object* x_266; +lean_dec(x_238); +lean_dec(x_236); +lean_dec(x_190); +lean_dec(x_3); +x_266 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_266, 0, x_2); +lean_ctor_set(x_266, 1, x_237); +return x_266; +} +} +} +else +{ +uint8_t x_267; +lean_dec(x_190); +lean_dec(x_3); +lean_dec(x_2); +x_267 = !lean_is_exclusive(x_192); +if (x_267 == 0) +{ +return x_192; +} +else +{ +lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_268 = lean_ctor_get(x_192, 0); +x_269 = lean_ctor_get(x_192, 1); +lean_inc(x_269); +lean_inc(x_268); +lean_dec(x_192); +x_270 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_270, 0, x_268); +lean_ctor_set(x_270, 1, x_269); +return x_270; +} +} +} +case 12: +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; +lean_dec(x_2); +x_271 = l_Lean_Expr_Inhabited; +x_272 = l_monadInhabited___rarg(x_1, x_271); +x_273 = l_unreachable_x21___rarg(x_272); +x_274 = lean_apply_2(x_273, x_3, x_4); +return x_274; +} +default: +{ +lean_object* x_275; +x_275 = lean_box(0); +x_5 = x_275; +goto block_9; +} +} +block_9: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +lean_dec(x_5); +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +lean_dec(x_1); +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_3, x_4); +return x_8; +} +} +} +lean_object* l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_5 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8(x_4, x_1, x_2, x_3); +return x_5; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_reduceQuotRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); lean_dec(x_6); lean_dec(x_5); -x_37 = lean_ctor_get(x_34, 1); -lean_inc(x_37); -lean_dec(x_34); -x_38 = lean_apply_4(x_1, x_7, x_2, x_8, x_37); -if (lean_obj_tag(x_38) == 0) +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: { -uint8_t x_39; -x_39 = !lean_is_exclusive(x_38); -if (x_39 == 0) +uint8_t x_5; lean_object* x_6; +x_5 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__6(x_1, x_2, x_3, x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_6 = lean_box(x_5); +return x_6; +} +} +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: { -lean_object* x_40; uint8_t x_41; uint8_t x_42; lean_object* x_43; -x_40 = lean_ctor_get(x_38, 0); +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__7(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_7 = lean_box(x_6); +return x_7; +} +} +lean_object* l_Lean_reduceRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_reduceRec___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_whnfEasyCases___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__8___lambda__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +return x_6; +} +} +lean_object* l_Lean_Meta_tryL(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = lean_apply_2(x_1, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; uint8_t x_7; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_unbox(x_6); +lean_dec(x_6); +switch (x_7) { +case 0: +{ +uint8_t x_8; +lean_dec(x_3); +lean_dec(x_2); +x_8 = !lean_is_exclusive(x_5); +if (x_8 == 0) +{ +lean_object* x_9; uint8_t x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_5, 0); +lean_dec(x_9); +x_10 = 0; +x_11 = lean_box(x_10); +lean_ctor_set(x_5, 0, x_11); +return x_5; +} +else +{ +lean_object* x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; +x_12 = lean_ctor_get(x_5, 1); +lean_inc(x_12); +lean_dec(x_5); +x_13 = 0; +x_14 = lean_box(x_13); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_12); +return x_15; +} +} +case 1: +{ +uint8_t x_16; +lean_dec(x_3); +lean_dec(x_2); +x_16 = !lean_is_exclusive(x_5); +if (x_16 == 0) +{ +lean_object* x_17; uint8_t x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_5, 0); +lean_dec(x_17); +x_18 = 1; +x_19 = lean_box(x_18); +lean_ctor_set(x_5, 0, x_19); +return x_5; +} +else +{ +lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_5, 1); +lean_inc(x_20); +lean_dec(x_5); +x_21 = 1; +x_22 = lean_box(x_21); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_20); +return x_23; +} +} +default: +{ +lean_object* x_24; lean_object* x_25; +x_24 = lean_ctor_get(x_5, 1); +lean_inc(x_24); +lean_dec(x_5); +x_25 = lean_apply_2(x_2, x_3, x_24); +return x_25; +} +} +} +else +{ +uint8_t x_26; +lean_dec(x_3); +lean_dec(x_2); +x_26 = !lean_is_exclusive(x_5); +if (x_26 == 0) +{ +return x_5; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_5, 0); +x_28 = lean_ctor_get(x_5, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_5); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_30__isDefEqWHNF(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_1); +x_6 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_1, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +lean_inc(x_4); +lean_inc(x_2); +x_9 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_2, x_4, x_8); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_9, 1); +lean_inc(x_11); +lean_dec(x_9); +x_12 = lean_expr_eqv(x_1, x_7); +lean_dec(x_1); +if (x_12 == 0) +{ +lean_object* x_13; +lean_dec(x_2); +lean_inc(x_4); +lean_inc(x_10); +lean_inc(x_7); +x_13 = l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(x_7, x_10, x_4, x_11); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; uint8_t x_15; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_unbox(x_14); +lean_dec(x_14); +switch (x_15) { +case 0: +{ +uint8_t x_16; +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +x_16 = !lean_is_exclusive(x_13); +if (x_16 == 0) +{ +lean_object* x_17; uint8_t x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_13, 0); +lean_dec(x_17); +x_18 = 0; +x_19 = lean_box(x_18); +lean_ctor_set(x_13, 0, x_19); +return x_13; +} +else +{ +lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_13, 1); +lean_inc(x_20); +lean_dec(x_13); +x_21 = 0; +x_22 = lean_box(x_21); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_20); +return x_23; +} +} +case 1: +{ +uint8_t x_24; +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +x_24 = !lean_is_exclusive(x_13); +if (x_24 == 0) +{ +lean_object* x_25; uint8_t x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_13, 0); +lean_dec(x_25); +x_26 = 1; +x_27 = lean_box(x_26); +lean_ctor_set(x_13, 0, x_27); +return x_13; +} +else +{ +lean_object* x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; +x_28 = lean_ctor_get(x_13, 1); +lean_inc(x_28); +lean_dec(x_13); +x_29 = 1; +x_30 = lean_box(x_29); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_30); +lean_ctor_set(x_31, 1, x_28); +return x_31; +} +} +default: +{ +lean_object* x_32; lean_object* x_33; +x_32 = lean_ctor_get(x_13, 1); +lean_inc(x_32); +lean_dec(x_13); +x_33 = lean_apply_4(x_3, x_7, x_10, x_4, x_32); +return x_33; +} +} +} +else +{ +uint8_t x_34; +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +x_34 = !lean_is_exclusive(x_13); +if (x_34 == 0) +{ +return x_13; +} +else +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_13, 0); +x_36 = lean_ctor_get(x_13, 1); +lean_inc(x_36); +lean_inc(x_35); +lean_dec(x_13); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_35); +lean_ctor_set(x_37, 1, x_36); +return x_37; +} +} +} +else +{ +uint8_t x_38; +x_38 = lean_expr_eqv(x_2, x_10); +lean_dec(x_2); +if (x_38 == 0) +{ +lean_object* x_39; +lean_inc(x_4); +lean_inc(x_10); +lean_inc(x_7); +x_39 = l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(x_7, x_10, x_4, x_11); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; uint8_t x_41; +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); x_41 = lean_unbox(x_40); lean_dec(x_40); -x_42 = l_Bool_toLBool(x_41); -x_43 = lean_box(x_42); -lean_ctor_set(x_38, 0, x_43); +switch (x_41) { +case 0: +{ +uint8_t x_42; +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +x_42 = !lean_is_exclusive(x_39); +if (x_42 == 0) +{ +lean_object* x_43; uint8_t x_44; lean_object* x_45; +x_43 = lean_ctor_get(x_39, 0); +lean_dec(x_43); +x_44 = 0; +x_45 = lean_box(x_44); +lean_ctor_set(x_39, 0, x_45); +return x_39; +} +else +{ +lean_object* x_46; uint8_t x_47; lean_object* x_48; lean_object* x_49; +x_46 = lean_ctor_get(x_39, 1); +lean_inc(x_46); +lean_dec(x_39); +x_47 = 0; +x_48 = lean_box(x_47); +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_46); +return x_49; +} +} +case 1: +{ +uint8_t x_50; +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +x_50 = !lean_is_exclusive(x_39); +if (x_50 == 0) +{ +lean_object* x_51; uint8_t x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_39, 0); +lean_dec(x_51); +x_52 = 1; +x_53 = lean_box(x_52); +lean_ctor_set(x_39, 0, x_53); +return x_39; +} +else +{ +lean_object* x_54; uint8_t x_55; lean_object* x_56; lean_object* x_57; +x_54 = lean_ctor_get(x_39, 1); +lean_inc(x_54); +lean_dec(x_39); +x_55 = 1; +x_56 = lean_box(x_55); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_54); +return x_57; +} +} +default: +{ +lean_object* x_58; lean_object* x_59; +x_58 = lean_ctor_get(x_39, 1); +lean_inc(x_58); +lean_dec(x_39); +x_59 = lean_apply_4(x_3, x_7, x_10, x_4, x_58); +return x_59; +} +} +} +else +{ +uint8_t x_60; +lean_dec(x_10); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +x_60 = !lean_is_exclusive(x_39); +if (x_60 == 0) +{ +return x_39; +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; +x_61 = lean_ctor_get(x_39, 0); +x_62 = lean_ctor_get(x_39, 1); +lean_inc(x_62); +lean_inc(x_61); +lean_dec(x_39); +x_63 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_63, 0, x_61); +lean_ctor_set(x_63, 1, x_62); +return x_63; +} +} +} +else +{ +lean_object* x_64; +x_64 = lean_apply_4(x_3, x_7, x_10, x_4, x_11); +return x_64; +} +} +} +else +{ +uint8_t x_65; +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_65 = !lean_is_exclusive(x_9); +if (x_65 == 0) +{ +return x_9; +} +else +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_66 = lean_ctor_get(x_9, 0); +x_67 = lean_ctor_get(x_9, 1); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_9); +x_68 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +return x_68; +} +} +} +else +{ +uint8_t x_69; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_69 = !lean_is_exclusive(x_6); +if (x_69 == 0) +{ +return x_6; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_6, 0); +x_71 = lean_ctor_get(x_6, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_6); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +} +lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_getConst___boxed), 3, 0); +return x_1; +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_6 = l___private_Init_Lean_Meta_Check_2__checkLambdaLet___lambda__2___closed__1; +x_7 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___closed__1; +x_8 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4; +lean_inc(x_1); +x_9 = l_Lean_getStuckMVar___main___rarg(x_6, x_7, x_8, x_1); +lean_inc(x_4); +x_10 = lean_apply_2(x_9, x_4, x_5); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +if (lean_obj_tag(x_11) == 0) +{ +lean_object* x_12; lean_object* x_13; +lean_dec(x_2); +lean_dec(x_1); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_13 = lean_apply_2(x_3, x_4, x_12); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_10, 1); +lean_inc(x_14); +lean_dec(x_10); +x_15 = lean_ctor_get(x_11, 0); +lean_inc(x_15); +lean_dec(x_11); +lean_inc(x_4); +x_16 = l_Lean_Meta_synthPending(x_15, x_4, x_14); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; uint8_t x_18; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_unbox(x_17); +lean_dec(x_17); +if (x_18 == 0) +{ +lean_object* x_19; lean_object* x_20; +lean_dec(x_2); +lean_dec(x_1); +x_19 = lean_ctor_get(x_16, 1); +lean_inc(x_19); +lean_dec(x_16); +x_20 = lean_apply_2(x_3, x_4, x_19); +return x_20; +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +lean_dec(x_3); +x_21 = lean_ctor_get(x_16, 1); +lean_inc(x_21); +lean_dec(x_16); +x_22 = l_Lean_Meta_instantiateMVars(x_1, x_4, x_21); +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_22, 1); +lean_inc(x_24); +lean_dec(x_22); +x_25 = lean_apply_3(x_2, x_23, x_4, x_24); +return x_25; +} +} +else +{ +uint8_t x_26; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_26 = !lean_is_exclusive(x_16); +if (x_26 == 0) +{ +return x_16; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_16, 0); +x_28 = lean_ctor_get(x_16, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_16); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; +} +} +} +} +else +{ +uint8_t x_30; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_30 = !lean_is_exclusive(x_10); +if (x_30 == 0) +{ +return x_10; +} +else +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; +x_31 = lean_ctor_get(x_10, 0); +x_32 = lean_ctor_get(x_10, 1); +lean_inc(x_32); +lean_inc(x_31); +lean_dec(x_10); +x_33 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_33, 0, x_31); +lean_ctor_set(x_33, 1, x_32); +return x_33; +} +} +} +} +lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_21; lean_object* x_22; +x_21 = lean_ctor_get_uint8(x_1, sizeof(void*)*1); +x_22 = lean_box(x_21); +switch (lean_obj_tag(x_22)) { +case 2: +{ +lean_object* x_23; +x_23 = lean_unsigned_to_nat(5u); +x_6 = x_23; +goto block_20; +} +case 3: +{ +lean_object* x_24; +x_24 = lean_unsigned_to_nat(4u); +x_6 = x_24; +goto block_20; +} +default: +{ +lean_object* x_25; lean_object* x_26; +lean_dec(x_22); +lean_dec(x_4); +x_25 = lean_box(0); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_25); +lean_ctor_set(x_26, 1, x_5); +return x_26; +} +} +block_20: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_lt(x_6, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_4); +x_9 = lean_box(0); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_5); +return x_10; +} +else +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_array_fget(x_3, x_6); +lean_inc(x_4); +x_12 = l_Lean_Meta_whnf(x_11, x_4, x_5); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 1); +lean_inc(x_14); +lean_dec(x_12); +x_15 = l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__2(x_13, x_4, x_14); +return x_15; +} +else +{ +uint8_t x_16; +lean_dec(x_4); +x_16 = !lean_is_exclusive(x_12); +if (x_16 == 0) +{ +return x_12; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_12, 0); +x_18 = lean_ctor_get(x_12, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_12); +x_19 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +} +} +} +} +} +lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_ctor_get_uint8(x_1, sizeof(void*)*7); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_7 = l_Lean_RecursorVal_getMajorIdx(x_1); +x_8 = lean_array_get_size(x_3); +x_9 = lean_nat_dec_lt(x_7, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_7); +lean_dec(x_4); +x_10 = lean_box(0); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_5); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_array_fget(x_3, x_7); +lean_dec(x_7); +lean_inc(x_4); +x_13 = l_Lean_Meta_whnf(x_12, x_4, x_5); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_16 = l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__2(x_14, x_4, x_15); +return x_16; +} +else +{ +uint8_t x_17; +lean_dec(x_4); +x_17 = !lean_is_exclusive(x_13); +if (x_17 == 0) +{ +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_13, 0); +x_19 = lean_ctor_get(x_13, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_13); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +} +else +{ +lean_object* x_21; lean_object* x_22; +lean_dec(x_4); +x_21 = lean_box(0); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_5); +return x_22; +} +} +} +lean_object* l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +switch (lean_obj_tag(x_1)) { +case 2: +{ +lean_object* x_4; lean_object* x_5; +lean_dec(x_2); +x_4 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_4, 0, x_1); +x_5 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_5, 0, x_4); +lean_ctor_set(x_5, 1, x_3); +return x_5; +} +case 5: +{ +lean_object* x_6; lean_object* x_7; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +x_7 = l_Lean_Expr_getAppFn___main(x_6); +lean_dec(x_6); +switch (lean_obj_tag(x_7)) { +case 2: +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_2); +lean_dec(x_1); +x_8 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_8, 0, x_7); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_3); +return x_9; +} +case 4: +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; lean_object* x_13; +x_10 = lean_ctor_get(x_7, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_7, 1); +lean_inc(x_11); +lean_dec(x_7); +x_12 = 1; +x_13 = l_Lean_Meta_getConstAux(x_10, x_12, x_2, x_3); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +if (lean_obj_tag(x_14) == 0) +{ +uint8_t x_15; +lean_dec(x_11); +lean_dec(x_2); +lean_dec(x_1); +x_15 = !lean_is_exclusive(x_13); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_ctor_get(x_13, 0); +lean_dec(x_16); +x_17 = lean_box(0); +lean_ctor_set(x_13, 0, x_17); +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_13, 1); +lean_inc(x_18); +lean_dec(x_13); +x_19 = lean_box(0); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_18); +return x_20; +} +} +else +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_14, 0); +lean_inc(x_21); +lean_dec(x_14); +switch (lean_obj_tag(x_21)) { +case 4: +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_22 = lean_ctor_get(x_13, 1); +lean_inc(x_22); +lean_dec(x_13); +x_23 = lean_ctor_get(x_21, 0); +lean_inc(x_23); +lean_dec(x_21); +x_24 = lean_unsigned_to_nat(0u); +x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_24); +x_26 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_25); +x_27 = lean_mk_array(x_25, x_26); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_sub(x_25, x_28); +lean_dec(x_25); +x_30 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_27, x_29); +x_31 = l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__3(x_23, x_11, x_30, x_2, x_22); +lean_dec(x_30); +lean_dec(x_11); +lean_dec(x_23); +return x_31; +} +case 7: +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_32 = lean_ctor_get(x_13, 1); +lean_inc(x_32); +lean_dec(x_13); +x_33 = lean_ctor_get(x_21, 0); +lean_inc(x_33); +lean_dec(x_21); +x_34 = lean_unsigned_to_nat(0u); +x_35 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_34); +x_36 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_35); +x_37 = lean_mk_array(x_35, x_36); +x_38 = lean_unsigned_to_nat(1u); +x_39 = lean_nat_sub(x_35, x_38); +lean_dec(x_35); +x_40 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_37, x_39); +x_41 = l_Lean_isRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__4(x_33, x_11, x_40, x_2, x_32); +lean_dec(x_40); +lean_dec(x_11); +lean_dec(x_33); +return x_41; +} +default: +{ +uint8_t x_42; +lean_dec(x_21); +lean_dec(x_11); +lean_dec(x_2); +lean_dec(x_1); +x_42 = !lean_is_exclusive(x_13); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_13, 0); +lean_dec(x_43); +x_44 = lean_box(0); +lean_ctor_set(x_13, 0, x_44); +return x_13; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_13, 1); +lean_inc(x_45); +lean_dec(x_13); +x_46 = lean_box(0); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_46); +lean_ctor_set(x_47, 1, x_45); +return x_47; +} +} +} +} +} +else +{ +uint8_t x_48; +lean_dec(x_11); +lean_dec(x_2); +lean_dec(x_1); +x_48 = !lean_is_exclusive(x_13); +if (x_48 == 0) +{ +return x_13; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_13, 0); +x_50 = lean_ctor_get(x_13, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_13); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +default: +{ +lean_object* x_52; lean_object* x_53; +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_52 = lean_box(0); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_52); +lean_ctor_set(x_53, 1, x_3); +return x_53; +} +} +} +case 10: +{ +lean_object* x_54; +x_54 = lean_ctor_get(x_1, 1); +lean_inc(x_54); +lean_dec(x_1); +x_1 = x_54; +goto _start; +} +case 11: +{ +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_1, 2); +lean_inc(x_56); +lean_dec(x_1); +lean_inc(x_2); +x_57 = l_Lean_Meta_whnf(x_56, x_2, x_3); +if (lean_obj_tag(x_57) == 0) +{ +lean_object* x_58; lean_object* x_59; +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_57, 1); +lean_inc(x_59); +lean_dec(x_57); +x_1 = x_58; +x_3 = x_59; +goto _start; +} +else +{ +uint8_t x_61; +lean_dec(x_2); +x_61 = !lean_is_exclusive(x_57); +if (x_61 == 0) +{ +return x_57; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_57, 0); +x_63 = lean_ctor_get(x_57, 1); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_57); +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +return x_64; +} +} +} +default: +{ +lean_object* x_65; lean_object* x_66; +lean_dec(x_2); +lean_dec(x_1); +x_65 = lean_box(0); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_3); +return x_66; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +lean_inc(x_2); +x_5 = l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__2(x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +if (lean_obj_tag(x_6) == 0) +{ +uint8_t x_7; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_7 = !lean_is_exclusive(x_5); +if (x_7 == 0) +{ +lean_object* x_8; uint8_t x_9; lean_object* x_10; +x_8 = lean_ctor_get(x_5, 0); +lean_dec(x_8); +x_9 = 0; +x_10 = lean_box(x_9); +lean_ctor_set(x_5, 0, x_10); +return x_5; +} +else +{ +lean_object* x_11; uint8_t x_12; lean_object* x_13; lean_object* x_14; +x_11 = lean_ctor_get(x_5, 1); +lean_inc(x_11); +lean_dec(x_5); +x_12 = 0; +x_13 = lean_box(x_12); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_11); +return x_14; +} +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_5, 1); +lean_inc(x_15); +lean_dec(x_5); +x_16 = lean_ctor_get(x_6, 0); +lean_inc(x_16); +lean_dec(x_6); +lean_inc(x_3); +x_17 = l_Lean_Meta_synthPending(x_16, x_3, x_15); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; uint8_t x_19; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_unbox(x_18); +lean_dec(x_18); +if (x_19 == 0) +{ +uint8_t x_20; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_20 = !lean_is_exclusive(x_17); +if (x_20 == 0) +{ +lean_object* x_21; uint8_t x_22; lean_object* x_23; +x_21 = lean_ctor_get(x_17, 0); +lean_dec(x_21); +x_22 = 0; +x_23 = lean_box(x_22); +lean_ctor_set(x_17, 0, x_23); +return x_17; +} +else +{ +lean_object* x_24; uint8_t x_25; lean_object* x_26; lean_object* x_27; +x_24 = lean_ctor_get(x_17, 1); +lean_inc(x_24); +lean_dec(x_17); +x_25 = 0; +x_26 = lean_box(x_25); +x_27 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_27, 0, x_26); +lean_ctor_set(x_27, 1, x_24); +return x_27; +} +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_28 = lean_ctor_get(x_17, 1); +lean_inc(x_28); +lean_dec(x_17); +x_29 = l_Lean_Meta_instantiateMVars(x_2, x_3, x_28); +x_30 = lean_ctor_get(x_29, 0); +lean_inc(x_30); +x_31 = lean_ctor_get(x_29, 1); +lean_inc(x_31); +lean_dec(x_29); +x_32 = l_Lean_Meta_isExprDefEqAux(x_1, x_30, x_3, x_31); +return x_32; +} +} +else +{ +uint8_t x_33; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_33 = !lean_is_exclusive(x_17); +if (x_33 == 0) +{ +return x_17; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_34 = lean_ctor_get(x_17, 0); +x_35 = lean_ctor_get(x_17, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_17); +x_36 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_36, 0, x_34); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +} +} +else +{ +uint8_t x_37; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_37 = !lean_is_exclusive(x_5); +if (x_37 == 0) +{ +return x_5; +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_5, 0); +x_39 = lean_ctor_get(x_5, 1); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_5); +x_40 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_40, 0, x_38); +lean_ctor_set(x_40, 1, x_39); +return x_40; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +lean_inc(x_4); +lean_inc(x_3); +x_6 = l_Lean_getStuckMVar___main___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__2(x_3, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_3); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__1(x_1, x_2, x_4, x_8); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_6, 1); +lean_inc(x_10); +lean_dec(x_6); +x_11 = lean_ctor_get(x_7, 0); +lean_inc(x_11); +lean_dec(x_7); +lean_inc(x_4); +x_12 = l_Lean_Meta_synthPending(x_11, x_4, x_10); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; uint8_t x_14; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_unbox(x_13); +lean_dec(x_13); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; +lean_dec(x_3); +x_15 = lean_ctor_get(x_12, 1); +lean_inc(x_15); +lean_dec(x_12); +x_16 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__1(x_1, x_2, x_4, x_15); +return x_16; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +lean_dec(x_1); +x_17 = lean_ctor_get(x_12, 1); +lean_inc(x_17); +lean_dec(x_12); +x_18 = l_Lean_Meta_instantiateMVars(x_3, x_4, x_17); +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = l_Lean_Meta_isExprDefEqAux(x_19, x_2, x_4, x_20); +return x_21; +} +} +else +{ +uint8_t x_22; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_22 = !lean_is_exclusive(x_12); +if (x_22 == 0) +{ +return x_12; +} +else +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_23 = lean_ctor_get(x_12, 0); +x_24 = lean_ctor_get(x_12, 1); +lean_inc(x_24); +lean_inc(x_23); +lean_dec(x_12); +x_25 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_24); +return x_25; +} +} +} +} +else +{ +uint8_t x_26; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_26 = !lean_is_exclusive(x_6); +if (x_26 == 0) +{ +return x_6; +} +else +{ +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_ctor_get(x_6, 0); +x_28 = lean_ctor_get(x_6, 1); +lean_inc(x_28); +lean_inc(x_27); +lean_dec(x_6); +x_29 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_29, 0, x_27); +lean_ctor_set(x_29, 1, x_28); +return x_29; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_1); +x_5 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_1, x_2, x_1, x_3, x_4); +return x_5; +} +} +lean_object* l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_isQuotRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__3(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_Lean_isRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_isRecStuck___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__4(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +if (x_4 == 0) +{ +lean_object* x_7; lean_object* x_8; +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_7 = lean_box(x_4); +x_8 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_8, 0, x_7); +lean_ctor_set(x_8, 1, x_6); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_9 = lean_unsigned_to_nat(0u); +x_10 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_9); +x_11 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_10); +x_12 = lean_mk_array(x_10, x_11); +x_13 = lean_unsigned_to_nat(1u); +x_14 = lean_nat_sub(x_10, x_13); +lean_dec(x_10); +x_15 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_12, x_14); +x_16 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_9); +lean_inc(x_16); +x_17 = lean_mk_array(x_16, x_11); +x_18 = lean_nat_sub(x_16, x_13); +lean_dec(x_16); +x_19 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_17, x_18); +x_20 = l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs(x_3, x_15, x_19, x_5, x_6); +lean_dec(x_19); +lean_dec(x_15); +return x_20; +} +} +} +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_6 = l_Lean_Expr_getAppFn___main(x_2); +lean_inc(x_3); +x_7 = lean_alloc_closure((void*)(l_Lean_Meta_isExprDefEqAux), 4, 2); +lean_closure_set(x_7, 0, x_3); +lean_closure_set(x_7, 1, x_6); +x_8 = lean_alloc_closure((void*)(l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1___lambda__1___boxed), 6, 3); +lean_closure_set(x_8, 0, x_1); +lean_closure_set(x_8, 1, x_2); +lean_closure_set(x_8, 2, x_3); +x_9 = !lean_is_exclusive(x_5); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_22; +x_10 = lean_ctor_get(x_5, 0); +x_11 = lean_ctor_get(x_5, 1); +x_12 = lean_ctor_get(x_5, 5); +x_13 = l_PersistentArray_empty___closed__3; +lean_inc(x_11); +lean_inc(x_10); +lean_ctor_set(x_5, 5, x_13); +lean_inc(x_4); +x_22 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_7, x_8, x_4, x_5); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; uint8_t x_24; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +x_24 = lean_unbox(x_23); +if (x_24 == 0) +{ +lean_object* x_25; lean_object* x_26; uint8_t x_27; +x_25 = lean_ctor_get(x_22, 1); +lean_inc(x_25); +lean_dec(x_22); +x_26 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_10, x_11, x_12, x_4, x_25); +lean_dec(x_4); +x_27 = !lean_is_exclusive(x_26); +if (x_27 == 0) +{ +lean_object* x_28; +x_28 = lean_ctor_get(x_26, 0); +lean_dec(x_28); +lean_ctor_set(x_26, 0, x_23); +return x_26; +} +else +{ +lean_object* x_29; lean_object* x_30; +x_29 = lean_ctor_get(x_26, 1); +lean_inc(x_29); +lean_dec(x_26); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_23); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +else +{ +lean_object* x_31; lean_object* x_32; +lean_dec(x_23); +x_31 = lean_ctor_get(x_22, 1); +lean_inc(x_31); +lean_dec(x_22); +x_32 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_4, x_31); +if (lean_obj_tag(x_32) == 0) +{ +lean_object* x_33; uint8_t x_34; +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +x_34 = lean_unbox(x_33); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; uint8_t x_37; +x_35 = lean_ctor_get(x_32, 1); +lean_inc(x_35); +lean_dec(x_32); +x_36 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_10, x_11, x_12, x_4, x_35); +lean_dec(x_4); +x_37 = !lean_is_exclusive(x_36); +if (x_37 == 0) +{ +lean_object* x_38; +x_38 = lean_ctor_get(x_36, 0); +lean_dec(x_38); +lean_ctor_set(x_36, 0, x_33); +return x_36; +} +else +{ +lean_object* x_39; lean_object* x_40; +x_39 = lean_ctor_get(x_36, 1); +lean_inc(x_39); +lean_dec(x_36); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_33); +lean_ctor_set(x_40, 1, x_39); +return x_40; +} +} +else +{ +uint8_t x_41; +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_4); +x_41 = !lean_is_exclusive(x_32); +if (x_41 == 0) +{ +lean_object* x_42; +x_42 = lean_ctor_get(x_32, 0); +lean_dec(x_42); +return x_32; +} +else +{ +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_32, 1); +lean_inc(x_43); +lean_dec(x_32); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_33); +lean_ctor_set(x_44, 1, x_43); +return x_44; +} +} +} +else +{ +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_32, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_32, 1); +lean_inc(x_46); +lean_dec(x_32); +x_14 = x_45; +x_15 = x_46; +goto block_21; +} +} +} +else +{ +lean_object* x_47; lean_object* x_48; +x_47 = lean_ctor_get(x_22, 0); +lean_inc(x_47); +x_48 = lean_ctor_get(x_22, 1); +lean_inc(x_48); +lean_dec(x_22); +x_14 = x_47; +x_15 = x_48; +goto block_21; +} +block_21: +{ +lean_object* x_16; uint8_t x_17; +x_16 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_10, x_11, x_12, x_4, x_15); +lean_dec(x_4); +x_17 = !lean_is_exclusive(x_16); +if (x_17 == 0) +{ +lean_object* x_18; +x_18 = lean_ctor_get(x_16, 0); +lean_dec(x_18); +lean_ctor_set_tag(x_16, 1); +lean_ctor_set(x_16, 0, x_14); +return x_16; +} +else +{ +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_16, 1); +lean_inc(x_19); +lean_dec(x_16); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_14); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_64; +x_49 = lean_ctor_get(x_5, 0); +x_50 = lean_ctor_get(x_5, 1); +x_51 = lean_ctor_get(x_5, 2); +x_52 = lean_ctor_get(x_5, 3); +x_53 = lean_ctor_get(x_5, 4); +x_54 = lean_ctor_get(x_5, 5); +lean_inc(x_54); +lean_inc(x_53); +lean_inc(x_52); +lean_inc(x_51); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_5); +x_55 = l_PersistentArray_empty___closed__3; +lean_inc(x_50); +lean_inc(x_49); +x_56 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_56, 0, x_49); +lean_ctor_set(x_56, 1, x_50); +lean_ctor_set(x_56, 2, x_51); +lean_ctor_set(x_56, 3, x_52); +lean_ctor_set(x_56, 4, x_53); +lean_ctor_set(x_56, 5, x_55); +lean_inc(x_4); +x_64 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_7, x_8, x_4, x_56); +if (lean_obj_tag(x_64) == 0) +{ +lean_object* x_65; uint8_t x_66; +x_65 = lean_ctor_get(x_64, 0); +lean_inc(x_65); +x_66 = lean_unbox(x_65); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_67 = lean_ctor_get(x_64, 1); +lean_inc(x_67); +lean_dec(x_64); +x_68 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_49, x_50, x_54, x_4, x_67); +lean_dec(x_4); +x_69 = lean_ctor_get(x_68, 1); +lean_inc(x_69); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + x_70 = x_68; +} else { + lean_dec_ref(x_68); + x_70 = lean_box(0); +} +if (lean_is_scalar(x_70)) { + x_71 = lean_alloc_ctor(0, 2, 0); +} else { + x_71 = x_70; +} +lean_ctor_set(x_71, 0, x_65); +lean_ctor_set(x_71, 1, x_69); +return x_71; +} +else +{ +lean_object* x_72; lean_object* x_73; +lean_dec(x_65); +x_72 = lean_ctor_get(x_64, 1); +lean_inc(x_72); +lean_dec(x_64); +x_73 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_4, x_72); +if (lean_obj_tag(x_73) == 0) +{ +lean_object* x_74; uint8_t x_75; +x_74 = lean_ctor_get(x_73, 0); +lean_inc(x_74); +x_75 = lean_unbox(x_74); +if (x_75 == 0) +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_76 = lean_ctor_get(x_73, 1); +lean_inc(x_76); +lean_dec(x_73); +x_77 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_49, x_50, x_54, x_4, x_76); +lean_dec(x_4); +x_78 = lean_ctor_get(x_77, 1); +lean_inc(x_78); +if (lean_is_exclusive(x_77)) { + lean_ctor_release(x_77, 0); + lean_ctor_release(x_77, 1); + x_79 = x_77; +} else { + lean_dec_ref(x_77); + x_79 = lean_box(0); +} +if (lean_is_scalar(x_79)) { + x_80 = lean_alloc_ctor(0, 2, 0); +} else { + x_80 = x_79; +} +lean_ctor_set(x_80, 0, x_74); +lean_ctor_set(x_80, 1, x_78); +return x_80; +} +else +{ +lean_object* x_81; lean_object* x_82; lean_object* x_83; +lean_dec(x_54); +lean_dec(x_50); +lean_dec(x_49); +lean_dec(x_4); +x_81 = lean_ctor_get(x_73, 1); +lean_inc(x_81); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + x_82 = x_73; +} else { + lean_dec_ref(x_73); + x_82 = lean_box(0); +} +if (lean_is_scalar(x_82)) { + x_83 = lean_alloc_ctor(0, 2, 0); +} else { + x_83 = x_82; +} +lean_ctor_set(x_83, 0, x_74); +lean_ctor_set(x_83, 1, x_81); +return x_83; +} +} +else +{ +lean_object* x_84; lean_object* x_85; +x_84 = lean_ctor_get(x_73, 0); +lean_inc(x_84); +x_85 = lean_ctor_get(x_73, 1); +lean_inc(x_85); +lean_dec(x_73); +x_57 = x_84; +x_58 = x_85; +goto block_63; +} +} +} +else +{ +lean_object* x_86; lean_object* x_87; +x_86 = lean_ctor_get(x_64, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_64, 1); +lean_inc(x_87); +lean_dec(x_64); +x_57 = x_86; +x_58 = x_87; +goto block_63; +} +block_63: +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_59 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_49, x_50, x_54, x_4, x_58); +lean_dec(x_4); +x_60 = lean_ctor_get(x_59, 1); +lean_inc(x_60); +if (lean_is_exclusive(x_59)) { + lean_ctor_release(x_59, 0); + lean_ctor_release(x_59, 1); + x_61 = x_59; +} else { + lean_dec_ref(x_59); + x_61 = lean_box(0); +} +if (lean_is_scalar(x_61)) { + x_62 = lean_alloc_ctor(1, 2, 0); +} else { + x_62 = x_61; + lean_ctor_set_tag(x_62, 1); +} +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_60); +return x_62; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_ExprDefEq_30__isDefEqWHNF___at_Lean_Meta_isExprDefEqAuxImpl___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +lean_inc(x_1); +x_5 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_1, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +lean_inc(x_3); +lean_inc(x_2); +x_8 = l_Lean_whnfCore___main___at___private_Init_Lean_Meta_ExprDefEq_29__whnfCoreAux___spec__1(x_2, x_3, x_7); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; uint8_t x_12; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_8, 1); +lean_inc(x_10); +if (lean_is_exclusive(x_8)) { + lean_ctor_release(x_8, 0); + lean_ctor_release(x_8, 1); + x_11 = x_8; +} else { + lean_dec_ref(x_8); + x_11 = lean_box(0); +} +x_12 = lean_expr_eqv(x_1, x_6); +lean_dec(x_1); +if (x_12 == 0) +{ +lean_object* x_13; +lean_dec(x_11); +lean_dec(x_2); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_13 = l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(x_6, x_9, x_3, x_10); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; uint8_t x_15; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_unbox(x_14); +lean_dec(x_14); +switch (x_15) { +case 0: +{ +uint8_t x_16; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_16 = !lean_is_exclusive(x_13); +if (x_16 == 0) +{ +lean_object* x_17; uint8_t x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_13, 0); +lean_dec(x_17); +x_18 = 0; +x_19 = lean_box(x_18); +lean_ctor_set(x_13, 0, x_19); +return x_13; +} +else +{ +lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_13, 1); +lean_inc(x_20); +lean_dec(x_13); +x_21 = 0; +x_22 = lean_box(x_21); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_20); +return x_23; +} +} +case 1: +{ +uint8_t x_24; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_24 = !lean_is_exclusive(x_13); +if (x_24 == 0) +{ +lean_object* x_25; uint8_t x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_13, 0); +lean_dec(x_25); +x_26 = 1; +x_27 = lean_box(x_26); +lean_ctor_set(x_13, 0, x_27); +return x_13; +} +else +{ +lean_object* x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; +x_28 = lean_ctor_get(x_13, 1); +lean_inc(x_28); +lean_dec(x_13); +x_29 = 1; +x_30 = lean_box(x_29); +x_31 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_31, 0, x_30); +lean_ctor_set(x_31, 1, x_28); +return x_31; +} +} +default: +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; lean_object* x_59; +x_32 = lean_ctor_get(x_13, 1); +lean_inc(x_32); +if (lean_is_exclusive(x_13)) { + lean_ctor_release(x_13, 0); + lean_ctor_release(x_13, 1); + x_33 = x_13; +} else { + lean_dec_ref(x_13); + x_33 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_59 = l_Lean_Meta_isDefEqOffset(x_6, x_9, x_3, x_32); +if (lean_obj_tag(x_59) == 0) +{ +lean_object* x_60; uint8_t x_61; +x_60 = lean_ctor_get(x_59, 0); +lean_inc(x_60); +x_61 = lean_unbox(x_60); +lean_dec(x_60); +switch (x_61) { +case 0: +{ +uint8_t x_62; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_62 = !lean_is_exclusive(x_59); +if (x_62 == 0) +{ +lean_object* x_63; uint8_t x_64; lean_object* x_65; +x_63 = lean_ctor_get(x_59, 0); +lean_dec(x_63); +x_64 = 0; +x_65 = lean_box(x_64); +lean_ctor_set(x_59, 0, x_65); +return x_59; +} +else +{ +lean_object* x_66; uint8_t x_67; lean_object* x_68; lean_object* x_69; +x_66 = lean_ctor_get(x_59, 1); +lean_inc(x_66); +lean_dec(x_59); +x_67 = 0; +x_68 = lean_box(x_67); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_68); +lean_ctor_set(x_69, 1, x_66); +return x_69; +} +} +case 1: +{ +uint8_t x_70; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_70 = !lean_is_exclusive(x_59); +if (x_70 == 0) +{ +lean_object* x_71; uint8_t x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_59, 0); +lean_dec(x_71); +x_72 = 1; +x_73 = lean_box(x_72); +lean_ctor_set(x_59, 0, x_73); +return x_59; +} +else +{ +lean_object* x_74; uint8_t x_75; lean_object* x_76; lean_object* x_77; +x_74 = lean_ctor_get(x_59, 1); +lean_inc(x_74); +lean_dec(x_59); +x_75 = 1; +x_76 = lean_box(x_75); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_76); +lean_ctor_set(x_77, 1, x_74); +return x_77; +} +} +default: +{ +lean_object* x_78; lean_object* x_79; +x_78 = lean_ctor_get(x_59, 1); +lean_inc(x_78); +lean_dec(x_59); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_79 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta(x_6, x_9, x_3, x_78); +if (lean_obj_tag(x_79) == 0) +{ +lean_object* x_80; uint8_t x_81; +x_80 = lean_ctor_get(x_79, 0); +lean_inc(x_80); +x_81 = lean_unbox(x_80); +lean_dec(x_80); +switch (x_81) { +case 0: +{ +uint8_t x_82; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_82 = !lean_is_exclusive(x_79); +if (x_82 == 0) +{ +lean_object* x_83; uint8_t x_84; lean_object* x_85; +x_83 = lean_ctor_get(x_79, 0); +lean_dec(x_83); +x_84 = 0; +x_85 = lean_box(x_84); +lean_ctor_set(x_79, 0, x_85); +return x_79; +} +else +{ +lean_object* x_86; uint8_t x_87; lean_object* x_88; lean_object* x_89; +x_86 = lean_ctor_get(x_79, 1); +lean_inc(x_86); +lean_dec(x_79); +x_87 = 0; +x_88 = lean_box(x_87); +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_88); +lean_ctor_set(x_89, 1, x_86); +return x_89; +} +} +case 1: +{ +uint8_t x_90; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_90 = !lean_is_exclusive(x_79); +if (x_90 == 0) +{ +lean_object* x_91; uint8_t x_92; lean_object* x_93; +x_91 = lean_ctor_get(x_79, 0); +lean_dec(x_91); +x_92 = 1; +x_93 = lean_box(x_92); +lean_ctor_set(x_79, 0, x_93); +return x_79; +} +else +{ +lean_object* x_94; uint8_t x_95; lean_object* x_96; lean_object* x_97; +x_94 = lean_ctor_get(x_79, 1); +lean_inc(x_94); +lean_dec(x_79); +x_95 = 1; +x_96 = lean_box(x_95); +x_97 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_97, 0, x_96); +lean_ctor_set(x_97, 1, x_94); +return x_97; +} +} +default: +{ +lean_object* x_98; lean_object* x_99; +x_98 = lean_ctor_get(x_79, 1); +lean_inc(x_98); +lean_dec(x_79); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_99 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(x_6, x_9, x_3, x_98); +if (lean_obj_tag(x_99) == 0) +{ +lean_object* x_100; uint8_t x_101; +x_100 = lean_ctor_get(x_99, 0); +lean_inc(x_100); +x_101 = lean_unbox(x_100); +if (x_101 == 0) +{ +lean_object* x_102; lean_object* x_103; +lean_dec(x_100); +x_102 = lean_ctor_get(x_99, 1); +lean_inc(x_102); +lean_dec(x_99); +lean_inc(x_3); +lean_inc(x_6); +lean_inc(x_9); +x_103 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(x_9, x_6, x_3, x_102); +if (lean_obj_tag(x_103) == 0) +{ +lean_object* x_104; lean_object* x_105; uint8_t x_106; +x_104 = lean_ctor_get(x_103, 0); +lean_inc(x_104); +x_105 = lean_ctor_get(x_103, 1); +lean_inc(x_105); +lean_dec(x_103); +x_106 = lean_unbox(x_104); +lean_dec(x_104); +x_34 = x_106; +x_35 = x_105; +goto block_58; +} +else +{ +uint8_t x_107; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_107 = !lean_is_exclusive(x_103); +if (x_107 == 0) +{ +return x_103; +} +else +{ +lean_object* x_108; lean_object* x_109; lean_object* x_110; +x_108 = lean_ctor_get(x_103, 0); +x_109 = lean_ctor_get(x_103, 1); +lean_inc(x_109); +lean_inc(x_108); +lean_dec(x_103); +x_110 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_110, 0, x_108); +lean_ctor_set(x_110, 1, x_109); +return x_110; +} +} +} +else +{ +lean_object* x_111; uint8_t x_112; +x_111 = lean_ctor_get(x_99, 1); +lean_inc(x_111); +lean_dec(x_99); +x_112 = lean_unbox(x_100); +lean_dec(x_100); +x_34 = x_112; +x_35 = x_111; +goto block_58; +} +} +else +{ +uint8_t x_113; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_113 = !lean_is_exclusive(x_99); +if (x_113 == 0) +{ +return x_99; +} +else +{ +lean_object* x_114; lean_object* x_115; lean_object* x_116; +x_114 = lean_ctor_get(x_99, 0); +x_115 = lean_ctor_get(x_99, 1); +lean_inc(x_115); +lean_inc(x_114); +lean_dec(x_99); +x_116 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_116, 0, x_114); +lean_ctor_set(x_116, 1, x_115); +return x_116; +} +} +} +} +} +else +{ +uint8_t x_117; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_117 = !lean_is_exclusive(x_79); +if (x_117 == 0) +{ +return x_79; +} +else +{ +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_79, 0); +x_119 = lean_ctor_get(x_79, 1); +lean_inc(x_119); +lean_inc(x_118); +lean_dec(x_79); +x_120 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_120, 0, x_118); +lean_ctor_set(x_120, 1, x_119); +return x_120; +} +} +} +} +} +else +{ +uint8_t x_121; +lean_dec(x_33); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_121 = !lean_is_exclusive(x_59); +if (x_121 == 0) +{ +return x_59; +} +else +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; +x_122 = lean_ctor_get(x_59, 0); +x_123 = lean_ctor_get(x_59, 1); +lean_inc(x_123); +lean_inc(x_122); +lean_dec(x_59); +x_124 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_124, 0, x_122); +lean_ctor_set(x_124, 1, x_123); +return x_124; +} +} +block_58: +{ +if (x_34 == 0) +{ +lean_dec(x_33); +switch (lean_obj_tag(x_6)) { +case 4: +{ +if (lean_obj_tag(x_9) == 4) +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_6, 1); +lean_inc(x_36); +lean_dec(x_6); +x_37 = lean_ctor_get(x_9, 1); +lean_inc(x_37); +lean_dec(x_9); +x_38 = l_Lean_Meta_isListLevelDefEqAux___main(x_36, x_37, x_3, x_35); +lean_dec(x_3); return x_38; } else { -lean_object* x_44; lean_object* x_45; uint8_t x_46; uint8_t x_47; lean_object* x_48; lean_object* x_49; -x_44 = lean_ctor_get(x_38, 0); -x_45 = lean_ctor_get(x_38, 1); -lean_inc(x_45); +lean_object* x_39; +lean_inc(x_6); +x_39 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_35); +return x_39; +} +} +case 5: +{ +if (lean_obj_tag(x_9) == 5) +{ +lean_object* x_40; lean_object* x_41; +x_40 = l_Lean_Expr_getAppFn___main(x_6); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_41 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1(x_6, x_9, x_40, x_3, x_35); +if (lean_obj_tag(x_41) == 0) +{ +lean_object* x_42; uint8_t x_43; +x_42 = lean_ctor_get(x_41, 0); +lean_inc(x_42); +x_43 = lean_unbox(x_42); +if (x_43 == 0) +{ +lean_object* x_44; lean_object* x_45; +lean_dec(x_42); +x_44 = lean_ctor_get(x_41, 1); lean_inc(x_44); -lean_dec(x_38); -x_46 = lean_unbox(x_44); -lean_dec(x_44); -x_47 = l_Bool_toLBool(x_46); -x_48 = lean_box(x_47); +lean_dec(x_41); +lean_inc(x_6); +x_45 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_44); +return x_45; +} +else +{ +uint8_t x_46; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_46 = !lean_is_exclusive(x_41); +if (x_46 == 0) +{ +lean_object* x_47; +x_47 = lean_ctor_get(x_41, 0); +lean_dec(x_47); +return x_41; +} +else +{ +lean_object* x_48; lean_object* x_49; +x_48 = lean_ctor_get(x_41, 1); +lean_inc(x_48); +lean_dec(x_41); x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_45); +lean_ctor_set(x_49, 0, x_42); +lean_ctor_set(x_49, 1, x_48); return x_49; } } +} else { uint8_t x_50; -x_50 = !lean_is_exclusive(x_38); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_50 = !lean_is_exclusive(x_41); if (x_50 == 0) { -return x_38; +return x_41; } else { lean_object* x_51; lean_object* x_52; lean_object* x_53; -x_51 = lean_ctor_get(x_38, 0); -x_52 = lean_ctor_get(x_38, 1); +x_51 = lean_ctor_get(x_41, 0); +x_52 = lean_ctor_get(x_41, 1); lean_inc(x_52); lean_inc(x_51); -lean_dec(x_38); +lean_dec(x_41); x_53 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_53, 0, x_51); lean_ctor_set(x_53, 1, x_52); @@ -13853,5227 +30764,1521 @@ return x_53; } else { -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_54 = lean_ctor_get(x_34, 1); -lean_inc(x_54); -lean_dec(x_34); -x_55 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_55, 0, x_5); -x_56 = l___private_Init_Lean_Trace_3__addTrace___rarg(x_6, x_29, x_55); -lean_inc(x_8); -x_57 = lean_apply_2(x_56, x_8, x_54); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; lean_object* x_59; -x_58 = lean_ctor_get(x_57, 1); -lean_inc(x_58); -lean_dec(x_57); -x_59 = lean_apply_4(x_1, x_7, x_2, x_8, x_58); -if (lean_obj_tag(x_59) == 0) -{ -uint8_t x_60; -x_60 = !lean_is_exclusive(x_59); -if (x_60 == 0) -{ -lean_object* x_61; uint8_t x_62; uint8_t x_63; lean_object* x_64; -x_61 = lean_ctor_get(x_59, 0); -x_62 = lean_unbox(x_61); -lean_dec(x_61); -x_63 = l_Bool_toLBool(x_62); -x_64 = lean_box(x_63); -lean_ctor_set(x_59, 0, x_64); -return x_59; -} -else -{ -lean_object* x_65; lean_object* x_66; uint8_t x_67; uint8_t x_68; lean_object* x_69; lean_object* x_70; -x_65 = lean_ctor_get(x_59, 0); -x_66 = lean_ctor_get(x_59, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_59); -x_67 = lean_unbox(x_65); -lean_dec(x_65); -x_68 = l_Bool_toLBool(x_67); -x_69 = lean_box(x_68); -x_70 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_70, 0, x_69); -lean_ctor_set(x_70, 1, x_66); -return x_70; -} -} -else -{ -uint8_t x_71; -x_71 = !lean_is_exclusive(x_59); -if (x_71 == 0) -{ -return x_59; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_59, 0); -x_73 = lean_ctor_get(x_59, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_59); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_2); -lean_dec(x_1); -x_75 = !lean_is_exclusive(x_57); -if (x_75 == 0) -{ -return x_57; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_57, 0); -x_77 = lean_ctor_get(x_57, 1); -lean_inc(x_77); -lean_inc(x_76); -lean_dec(x_57); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; -} -} -} -} -else -{ -uint8_t x_79; -lean_dec(x_29); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); -lean_dec(x_1); -x_79 = !lean_is_exclusive(x_34); -if (x_79 == 0) -{ -return x_34; -} -else -{ -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_34, 0); -x_81 = lean_ctor_get(x_34, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_34); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; -} -} -} -} -} -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__1() { -_start: -{ -lean_object* x_1; -x_1 = lean_mk_string("delta"); -return x_1; -} -} -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2() { -_start: -{ -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__4; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__1; -x_3 = lean_name_mk_string(x_1, x_2); -return x_3; -} -} -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3() { -_start: -{ -lean_object* x_1; uint8_t x_2; lean_object* x_3; lean_object* x_4; -x_1 = l_EIO_Monad___closed__1; -x_2 = 2; -x_3 = lean_box(x_2); -x_4 = lean_alloc_closure((void*)(l_ReaderT_pure___rarg___boxed), 4, 3); -lean_closure_set(x_4, 0, x_1); -lean_closure_set(x_4, 1, lean_box(0)); -lean_closure_set(x_4, 2, x_3); -return x_4; -} -} -lean_object* _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__4() { -_start: -{ -lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_3 = l_Lean_Name_append___main(x_1, x_2); -return x_3; -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_8 = l_Lean_Expr_getAppFn___main(x_4); -x_9 = l_Lean_Expr_getAppFn___main(x_5); -x_10 = lean_unsigned_to_nat(0u); -x_11 = l_Lean_Expr_getAppNumArgsAux___main(x_4, x_10); -x_12 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_11); -x_13 = lean_mk_array(x_11, x_12); -x_14 = lean_unsigned_to_nat(1u); -x_15 = lean_nat_sub(x_11, x_14); -lean_dec(x_11); -lean_inc(x_4); -x_16 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_4, x_13, x_15); -x_17 = l_Lean_Expr_getAppNumArgsAux___main(x_5, x_10); -lean_inc(x_17); -x_18 = lean_mk_array(x_17, x_12); -x_19 = lean_nat_sub(x_17, x_14); -lean_dec(x_17); -lean_inc(x_5); -x_20 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_5, x_18, x_19); -lean_inc(x_8); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_1); -x_21 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_4__isDefEqArgs), 8, 6); -lean_closure_set(x_21, 0, x_1); -lean_closure_set(x_21, 1, x_2); -lean_closure_set(x_21, 2, x_3); -lean_closure_set(x_21, 3, x_8); -lean_closure_set(x_21, 4, x_16); -lean_closure_set(x_21, 5, x_20); -lean_inc(x_9); -lean_inc(x_8); -x_22 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__1___boxed), 5, 2); -lean_closure_set(x_22, 0, x_8); -lean_closure_set(x_22, 1, x_9); -x_23 = l_EIO_Monad___closed__1; -x_24 = lean_alloc_closure((void*)(l_ReaderT_bind___rarg), 6, 5); -lean_closure_set(x_24, 0, x_23); -lean_closure_set(x_24, 1, lean_box(0)); -lean_closure_set(x_24, 2, lean_box(0)); -lean_closure_set(x_24, 3, x_21); -lean_closure_set(x_24, 4, x_22); -x_25 = l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate(x_8, x_6, x_7); -lean_dec(x_8); -if (lean_obj_tag(x_25) == 0) -{ -uint8_t x_26; -x_26 = !lean_is_exclusive(x_25); -if (x_26 == 0) -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_27 = lean_ctor_get(x_25, 0); -x_28 = lean_ctor_get(x_25, 1); -x_29 = l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate(x_9, x_6, x_28); -lean_dec(x_9); -if (lean_obj_tag(x_29) == 0) -{ -if (lean_obj_tag(x_27) == 0) -{ -lean_object* x_30; -lean_free_object(x_25); -lean_dec(x_24); -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -if (lean_obj_tag(x_30) == 0) -{ -uint8_t x_31; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_31 = !lean_is_exclusive(x_29); -if (x_31 == 0) -{ -lean_object* x_32; uint8_t x_33; lean_object* x_34; -x_32 = lean_ctor_get(x_29, 0); -lean_dec(x_32); -x_33 = 2; -x_34 = lean_box(x_33); -lean_ctor_set(x_29, 0, x_34); -return x_29; -} -else -{ -lean_object* x_35; uint8_t x_36; lean_object* x_37; lean_object* x_38; -x_35 = lean_ctor_get(x_29, 1); -lean_inc(x_35); -lean_dec(x_29); -x_36 = 2; -x_37 = lean_box(x_36); -x_38 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_38, 0, x_37); -lean_ctor_set(x_38, 1, x_35); -return x_38; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_39 = lean_ctor_get(x_29, 1); -lean_inc(x_39); -lean_dec(x_29); -x_40 = lean_ctor_get(x_30, 0); -lean_inc(x_40); -lean_dec(x_30); -x_41 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_42 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_43 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_2); -x_44 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___boxed), 9, 6); -lean_closure_set(x_44, 0, x_2); -lean_closure_set(x_44, 1, x_4); -lean_closure_set(x_44, 2, x_40); -lean_closure_set(x_44, 3, x_41); -lean_closure_set(x_44, 4, x_42); -lean_closure_set(x_44, 5, x_43); -lean_inc(x_1); -x_45 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_45, 0, x_1); -x_46 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -x_47 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_45, x_2, x_3, x_5, x_46, x_44, x_6, x_39); -return x_47; -} -} -else -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_29, 0); -lean_inc(x_48); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -lean_free_object(x_25); -lean_dec(x_24); -x_49 = lean_ctor_get(x_29, 1); -lean_inc(x_49); -lean_dec(x_29); -x_50 = lean_ctor_get(x_27, 0); -lean_inc(x_50); -lean_dec(x_27); -x_51 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_52 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_53 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_2); -x_54 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___boxed), 9, 6); -lean_closure_set(x_54, 0, x_2); -lean_closure_set(x_54, 1, x_5); -lean_closure_set(x_54, 2, x_50); -lean_closure_set(x_54, 3, x_51); -lean_closure_set(x_54, 4, x_52); -lean_closure_set(x_54, 5, x_53); -lean_inc(x_1); -x_55 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_55, 0, x_1); -x_56 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -x_57 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_55, x_2, x_3, x_4, x_56, x_54, x_6, x_49); -return x_57; -} -else -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; uint8_t x_62; lean_object* x_63; uint8_t x_77; lean_object* x_78; lean_object* x_263; lean_object* x_264; uint8_t x_265; -x_58 = lean_ctor_get(x_29, 1); -lean_inc(x_58); -if (lean_is_exclusive(x_29)) { - lean_ctor_release(x_29, 0); - lean_ctor_release(x_29, 1); - x_59 = x_29; -} else { - lean_dec_ref(x_29); - x_59 = lean_box(0); -} -x_60 = lean_ctor_get(x_27, 0); -lean_inc(x_60); -lean_dec(x_27); -x_61 = lean_ctor_get(x_48, 0); -lean_inc(x_61); -lean_dec(x_48); -x_263 = l_Lean_ConstantInfo_name(x_60); -x_264 = l_Lean_ConstantInfo_name(x_61); -x_265 = lean_name_eq(x_263, x_264); -if (x_265 == 0) -{ -lean_object* x_266; uint8_t x_267; uint8_t x_268; uint8_t x_269; lean_object* x_270; -lean_dec(x_59); -lean_free_object(x_25); -lean_dec(x_24); -x_266 = lean_ctor_get(x_6, 0); -lean_inc(x_266); -x_267 = lean_ctor_get_uint8(x_266, sizeof(void*)*1 + 4); -lean_dec(x_266); -x_268 = 2; -x_269 = l_Lean_Meta_TransparencyMode_beq(x_267, x_268); -if (x_269 == 0) -{ -lean_object* x_281; uint8_t x_282; lean_object* x_283; lean_object* x_295; lean_object* x_308; uint8_t x_348; lean_object* x_349; -x_281 = lean_ctor_get(x_58, 0); -lean_inc(x_281); -lean_inc(x_263); -lean_inc(x_281); -x_282 = l_Lean_isReducible(x_281, x_263); -lean_inc(x_264); -x_348 = l_Lean_isReducible(x_281, x_264); -if (x_282 == 0) -{ -lean_object* x_386; -x_386 = lean_box(0); -x_349 = x_386; -goto block_385; -} -else -{ -if (x_348 == 0) -{ -uint8_t x_387; lean_object* x_388; lean_object* x_389; lean_object* x_390; lean_object* x_391; lean_object* x_392; lean_object* x_393; -x_387 = l_Lean_Expr_hasExprMVar(x_4); -x_388 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_389 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_390 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_263); -lean_inc(x_5); -lean_inc(x_2); -x_391 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_391, 0, x_2); -lean_closure_set(x_391, 1, x_5); -lean_closure_set(x_391, 2, x_388); -lean_closure_set(x_391, 3, x_389); -lean_closure_set(x_391, 4, x_263); -lean_closure_set(x_391, 5, x_390); -lean_inc(x_1); -x_392 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_392, 0, x_1); -if (x_387 == 0) -{ -uint8_t x_401; -x_401 = l_Lean_Expr_hasExprMVar(x_5); -if (x_401 == 0) -{ -lean_object* x_402; lean_object* x_403; uint8_t x_404; -x_402 = l_Lean_ConstantInfo_hints(x_60); -lean_dec(x_60); -x_403 = l_Lean_ConstantInfo_hints(x_61); -lean_dec(x_61); -x_404 = l_Lean_ReducibilityHints_lt(x_402, x_403); -if (x_404 == 0) -{ -uint8_t x_405; -x_405 = l_Lean_ReducibilityHints_lt(x_403, x_402); -lean_dec(x_402); -lean_dec(x_403); -if (x_405 == 0) -{ -lean_object* x_406; lean_object* x_407; lean_object* x_408; lean_object* x_409; lean_object* x_410; lean_object* x_411; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_406 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_406, 0, x_2); -lean_closure_set(x_406, 1, x_4); -lean_closure_set(x_406, 2, x_388); -lean_closure_set(x_406, 3, x_389); -lean_closure_set(x_406, 4, x_264); -lean_closure_set(x_406, 5, x_390); -x_407 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_408 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_408, 0, x_1); -lean_closure_set(x_408, 1, x_392); -lean_closure_set(x_408, 2, x_2); -lean_closure_set(x_408, 3, x_3); -lean_closure_set(x_408, 4, x_5); -lean_closure_set(x_408, 5, x_407); -lean_closure_set(x_408, 6, x_406); -lean_inc(x_3); -lean_inc(x_392); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_409 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_409, 0, x_5); -lean_closure_set(x_409, 1, x_388); -lean_closure_set(x_409, 2, x_389); -lean_closure_set(x_409, 3, x_23); -lean_closure_set(x_409, 4, x_263); -lean_closure_set(x_409, 5, x_390); -lean_closure_set(x_409, 6, x_2); -lean_closure_set(x_409, 7, x_4); -lean_closure_set(x_409, 8, x_264); -lean_closure_set(x_409, 9, x_1); -lean_closure_set(x_409, 10, x_392); -lean_closure_set(x_409, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_410 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_410, 0, x_1); -lean_closure_set(x_410, 1, x_392); -lean_closure_set(x_410, 2, x_2); -lean_closure_set(x_410, 3, x_3); -lean_closure_set(x_410, 4, x_4); -lean_closure_set(x_410, 5, x_408); -lean_closure_set(x_410, 6, x_409); -x_411 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_392, x_2, x_3, x_4, x_410, x_391, x_6, x_58); -return x_411; -} -else -{ -lean_object* x_412; lean_object* x_413; lean_object* x_414; lean_object* x_415; lean_object* x_416; lean_object* x_417; lean_object* x_418; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_412 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_412, 0, x_2); -lean_closure_set(x_412, 1, x_4); -lean_closure_set(x_412, 2, x_388); -lean_closure_set(x_412, 3, x_389); -lean_closure_set(x_412, 4, x_264); -lean_closure_set(x_412, 5, x_390); -x_413 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_412); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_414 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_414, 0, x_1); -lean_closure_set(x_414, 1, x_392); -lean_closure_set(x_414, 2, x_2); -lean_closure_set(x_414, 3, x_3); -lean_closure_set(x_414, 4, x_5); -lean_closure_set(x_414, 5, x_413); -lean_closure_set(x_414, 6, x_412); -lean_inc(x_3); -lean_inc(x_392); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_415 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_415, 0, x_5); -lean_closure_set(x_415, 1, x_388); -lean_closure_set(x_415, 2, x_389); -lean_closure_set(x_415, 3, x_23); -lean_closure_set(x_415, 4, x_263); -lean_closure_set(x_415, 5, x_390); -lean_closure_set(x_415, 6, x_2); -lean_closure_set(x_415, 7, x_4); -lean_closure_set(x_415, 8, x_264); -lean_closure_set(x_415, 9, x_1); -lean_closure_set(x_415, 10, x_392); -lean_closure_set(x_415, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_416 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_416, 0, x_1); -lean_closure_set(x_416, 1, x_392); -lean_closure_set(x_416, 2, x_2); -lean_closure_set(x_416, 3, x_3); -lean_closure_set(x_416, 4, x_4); -lean_closure_set(x_416, 5, x_414); -lean_closure_set(x_416, 6, x_415); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_417 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_417, 0, x_1); -lean_closure_set(x_417, 1, x_392); -lean_closure_set(x_417, 2, x_2); -lean_closure_set(x_417, 3, x_3); -lean_closure_set(x_417, 4, x_5); -lean_closure_set(x_417, 5, x_416); -lean_closure_set(x_417, 6, x_412); -x_418 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_392, x_2, x_3, x_4, x_417, x_391, x_6, x_58); -return x_418; -} -} -else -{ -lean_object* x_419; lean_object* x_420; lean_object* x_421; lean_object* x_422; lean_object* x_423; lean_object* x_424; lean_object* x_425; -lean_dec(x_403); -lean_dec(x_402); -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_419 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_419, 0, x_2); -lean_closure_set(x_419, 1, x_4); -lean_closure_set(x_419, 2, x_388); -lean_closure_set(x_419, 3, x_389); -lean_closure_set(x_419, 4, x_264); -lean_closure_set(x_419, 5, x_390); -x_420 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_421 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_421, 0, x_1); -lean_closure_set(x_421, 1, x_392); -lean_closure_set(x_421, 2, x_2); -lean_closure_set(x_421, 3, x_3); -lean_closure_set(x_421, 4, x_5); -lean_closure_set(x_421, 5, x_420); -lean_closure_set(x_421, 6, x_419); -lean_inc(x_3); -lean_inc(x_392); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_422 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_422, 0, x_5); -lean_closure_set(x_422, 1, x_388); -lean_closure_set(x_422, 2, x_389); -lean_closure_set(x_422, 3, x_23); -lean_closure_set(x_422, 4, x_263); -lean_closure_set(x_422, 5, x_390); -lean_closure_set(x_422, 6, x_2); -lean_closure_set(x_422, 7, x_4); -lean_closure_set(x_422, 8, x_264); -lean_closure_set(x_422, 9, x_1); -lean_closure_set(x_422, 10, x_392); -lean_closure_set(x_422, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_423 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_423, 0, x_1); -lean_closure_set(x_423, 1, x_392); -lean_closure_set(x_423, 2, x_2); -lean_closure_set(x_423, 3, x_3); -lean_closure_set(x_423, 4, x_4); -lean_closure_set(x_423, 5, x_421); -lean_closure_set(x_423, 6, x_422); -lean_inc(x_391); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_424 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_424, 0, x_1); -lean_closure_set(x_424, 1, x_392); -lean_closure_set(x_424, 2, x_2); -lean_closure_set(x_424, 3, x_3); -lean_closure_set(x_424, 4, x_4); -lean_closure_set(x_424, 5, x_423); -lean_closure_set(x_424, 6, x_391); -x_425 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_392, x_2, x_3, x_4, x_424, x_391, x_6, x_58); -return x_425; -} -} -else -{ -lean_object* x_426; -lean_dec(x_61); -lean_dec(x_60); -x_426 = lean_box(0); -x_393 = x_426; -goto block_400; -} -} -else -{ -lean_object* x_427; -lean_dec(x_61); -lean_dec(x_60); -x_427 = lean_box(0); -x_393 = x_427; -goto block_400; -} -block_400: -{ -lean_object* x_394; lean_object* x_395; lean_object* x_396; lean_object* x_397; lean_object* x_398; lean_object* x_399; -lean_dec(x_393); -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_394 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_394, 0, x_2); -lean_closure_set(x_394, 1, x_4); -lean_closure_set(x_394, 2, x_388); -lean_closure_set(x_394, 3, x_389); -lean_closure_set(x_394, 4, x_264); -lean_closure_set(x_394, 5, x_390); -x_395 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_396 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_396, 0, x_1); -lean_closure_set(x_396, 1, x_392); -lean_closure_set(x_396, 2, x_2); -lean_closure_set(x_396, 3, x_3); -lean_closure_set(x_396, 4, x_5); -lean_closure_set(x_396, 5, x_395); -lean_closure_set(x_396, 6, x_394); -lean_inc(x_3); -lean_inc(x_392); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_397 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_397, 0, x_5); -lean_closure_set(x_397, 1, x_388); -lean_closure_set(x_397, 2, x_389); -lean_closure_set(x_397, 3, x_23); -lean_closure_set(x_397, 4, x_263); -lean_closure_set(x_397, 5, x_390); -lean_closure_set(x_397, 6, x_2); -lean_closure_set(x_397, 7, x_4); -lean_closure_set(x_397, 8, x_264); -lean_closure_set(x_397, 9, x_1); -lean_closure_set(x_397, 10, x_392); -lean_closure_set(x_397, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_392); -lean_inc(x_1); -x_398 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_398, 0, x_1); -lean_closure_set(x_398, 1, x_392); -lean_closure_set(x_398, 2, x_2); -lean_closure_set(x_398, 3, x_3); -lean_closure_set(x_398, 4, x_4); -lean_closure_set(x_398, 5, x_396); -lean_closure_set(x_398, 6, x_397); -x_399 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_392, x_2, x_3, x_4, x_398, x_391, x_6, x_58); -return x_399; -} -} -else -{ -lean_object* x_428; -x_428 = lean_box(0); -x_349 = x_428; -goto block_385; -} -} -block_294: -{ -lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; -lean_dec(x_283); -x_284 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_285 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_286 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_287 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_287, 0, x_2); -lean_closure_set(x_287, 1, x_4); -lean_closure_set(x_287, 2, x_284); -lean_closure_set(x_287, 3, x_285); -lean_closure_set(x_287, 4, x_264); -lean_closure_set(x_287, 5, x_286); -lean_inc(x_1); -x_288 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_288, 0, x_1); -x_289 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_287); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_288); -lean_inc(x_1); -x_290 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_290, 0, x_1); -lean_closure_set(x_290, 1, x_288); -lean_closure_set(x_290, 2, x_2); -lean_closure_set(x_290, 3, x_3); -lean_closure_set(x_290, 4, x_5); -lean_closure_set(x_290, 5, x_289); -lean_closure_set(x_290, 6, x_287); -lean_inc(x_3); -lean_inc(x_288); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_291 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_291, 0, x_5); -lean_closure_set(x_291, 1, x_284); -lean_closure_set(x_291, 2, x_285); -lean_closure_set(x_291, 3, x_23); -lean_closure_set(x_291, 4, x_263); -lean_closure_set(x_291, 5, x_286); -lean_closure_set(x_291, 6, x_2); -lean_closure_set(x_291, 7, x_4); -lean_closure_set(x_291, 8, x_264); -lean_closure_set(x_291, 9, x_1); -lean_closure_set(x_291, 10, x_288); -lean_closure_set(x_291, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_288); -lean_inc(x_1); -x_292 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_292, 0, x_1); -lean_closure_set(x_292, 1, x_288); -lean_closure_set(x_292, 2, x_2); -lean_closure_set(x_292, 3, x_3); -lean_closure_set(x_292, 4, x_4); -lean_closure_set(x_292, 5, x_290); -lean_closure_set(x_292, 6, x_291); -x_293 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_288, x_2, x_3, x_5, x_292, x_287, x_6, x_58); -return x_293; -} -block_307: -{ -lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; -lean_dec(x_295); -x_296 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_297 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_298 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_299 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_299, 0, x_2); -lean_closure_set(x_299, 1, x_4); -lean_closure_set(x_299, 2, x_296); -lean_closure_set(x_299, 3, x_297); -lean_closure_set(x_299, 4, x_264); -lean_closure_set(x_299, 5, x_298); -lean_inc(x_1); -x_300 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_300, 0, x_1); -x_301 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_300); -lean_inc(x_1); -x_302 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_302, 0, x_1); -lean_closure_set(x_302, 1, x_300); -lean_closure_set(x_302, 2, x_2); -lean_closure_set(x_302, 3, x_3); -lean_closure_set(x_302, 4, x_5); -lean_closure_set(x_302, 5, x_301); -lean_closure_set(x_302, 6, x_299); -lean_inc(x_3); -lean_inc(x_300); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_263); -lean_inc(x_5); -x_303 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_303, 0, x_5); -lean_closure_set(x_303, 1, x_296); -lean_closure_set(x_303, 2, x_297); -lean_closure_set(x_303, 3, x_23); -lean_closure_set(x_303, 4, x_263); -lean_closure_set(x_303, 5, x_298); -lean_closure_set(x_303, 6, x_2); -lean_closure_set(x_303, 7, x_4); -lean_closure_set(x_303, 8, x_264); -lean_closure_set(x_303, 9, x_1); -lean_closure_set(x_303, 10, x_300); -lean_closure_set(x_303, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_300); -lean_inc(x_1); -x_304 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_304, 0, x_1); -lean_closure_set(x_304, 1, x_300); -lean_closure_set(x_304, 2, x_2); -lean_closure_set(x_304, 3, x_3); -lean_closure_set(x_304, 4, x_4); -lean_closure_set(x_304, 5, x_302); -lean_closure_set(x_304, 6, x_303); -lean_inc(x_2); -x_305 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_305, 0, x_2); -lean_closure_set(x_305, 1, x_5); -lean_closure_set(x_305, 2, x_296); -lean_closure_set(x_305, 3, x_297); -lean_closure_set(x_305, 4, x_263); -lean_closure_set(x_305, 5, x_298); -x_306 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_300, x_2, x_3, x_4, x_304, x_305, x_6, x_58); -return x_306; -} -block_347: -{ -uint8_t x_309; lean_object* x_310; lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; lean_object* x_315; -lean_dec(x_308); -x_309 = l_Lean_Expr_hasExprMVar(x_4); -x_310 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_311 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_312 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_313 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_313, 0, x_2); -lean_closure_set(x_313, 1, x_4); -lean_closure_set(x_313, 2, x_310); -lean_closure_set(x_313, 3, x_311); -lean_closure_set(x_313, 4, x_264); -lean_closure_set(x_313, 5, x_312); -lean_inc(x_1); -x_314 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_314, 0, x_1); -if (x_309 == 0) -{ -uint8_t x_322; -x_322 = l_Lean_Expr_hasExprMVar(x_5); -if (x_322 == 0) -{ -lean_object* x_323; lean_object* x_324; uint8_t x_325; -x_323 = l_Lean_ConstantInfo_hints(x_60); -lean_dec(x_60); -x_324 = l_Lean_ConstantInfo_hints(x_61); -lean_dec(x_61); -x_325 = l_Lean_ReducibilityHints_lt(x_323, x_324); -if (x_325 == 0) -{ -uint8_t x_326; -x_326 = l_Lean_ReducibilityHints_lt(x_324, x_323); -lean_dec(x_323); -lean_dec(x_324); -if (x_326 == 0) -{ -lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; lean_object* x_331; -x_327 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_313); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_328 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_328, 0, x_1); -lean_closure_set(x_328, 1, x_314); -lean_closure_set(x_328, 2, x_2); -lean_closure_set(x_328, 3, x_3); -lean_closure_set(x_328, 4, x_5); -lean_closure_set(x_328, 5, x_327); -lean_closure_set(x_328, 6, x_313); -lean_inc(x_3); -lean_inc(x_314); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_329 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_329, 0, x_5); -lean_closure_set(x_329, 1, x_310); -lean_closure_set(x_329, 2, x_311); -lean_closure_set(x_329, 3, x_23); -lean_closure_set(x_329, 4, x_263); -lean_closure_set(x_329, 5, x_312); -lean_closure_set(x_329, 6, x_2); -lean_closure_set(x_329, 7, x_4); -lean_closure_set(x_329, 8, x_264); -lean_closure_set(x_329, 9, x_1); -lean_closure_set(x_329, 10, x_314); -lean_closure_set(x_329, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_330 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_330, 0, x_1); -lean_closure_set(x_330, 1, x_314); -lean_closure_set(x_330, 2, x_2); -lean_closure_set(x_330, 3, x_3); -lean_closure_set(x_330, 4, x_4); -lean_closure_set(x_330, 5, x_328); -lean_closure_set(x_330, 6, x_329); -x_331 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_314, x_2, x_3, x_5, x_330, x_313, x_6, x_58); -return x_331; -} -else -{ -lean_object* x_332; lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; lean_object* x_337; -x_332 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_313); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_333 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_333, 0, x_1); -lean_closure_set(x_333, 1, x_314); -lean_closure_set(x_333, 2, x_2); -lean_closure_set(x_333, 3, x_3); -lean_closure_set(x_333, 4, x_5); -lean_closure_set(x_333, 5, x_332); -lean_closure_set(x_333, 6, x_313); -lean_inc(x_3); -lean_inc(x_314); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_334 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_334, 0, x_5); -lean_closure_set(x_334, 1, x_310); -lean_closure_set(x_334, 2, x_311); -lean_closure_set(x_334, 3, x_23); -lean_closure_set(x_334, 4, x_263); -lean_closure_set(x_334, 5, x_312); -lean_closure_set(x_334, 6, x_2); -lean_closure_set(x_334, 7, x_4); -lean_closure_set(x_334, 8, x_264); -lean_closure_set(x_334, 9, x_1); -lean_closure_set(x_334, 10, x_314); -lean_closure_set(x_334, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_335 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_335, 0, x_1); -lean_closure_set(x_335, 1, x_314); -lean_closure_set(x_335, 2, x_2); -lean_closure_set(x_335, 3, x_3); -lean_closure_set(x_335, 4, x_4); -lean_closure_set(x_335, 5, x_333); -lean_closure_set(x_335, 6, x_334); -lean_inc(x_313); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_336 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_336, 0, x_1); -lean_closure_set(x_336, 1, x_314); -lean_closure_set(x_336, 2, x_2); -lean_closure_set(x_336, 3, x_3); -lean_closure_set(x_336, 4, x_5); -lean_closure_set(x_336, 5, x_335); -lean_closure_set(x_336, 6, x_313); -x_337 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_314, x_2, x_3, x_5, x_336, x_313, x_6, x_58); -return x_337; -} -} -else -{ -lean_object* x_338; lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; -lean_dec(x_324); -lean_dec(x_323); -x_338 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_313); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_339 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_339, 0, x_1); -lean_closure_set(x_339, 1, x_314); -lean_closure_set(x_339, 2, x_2); -lean_closure_set(x_339, 3, x_3); -lean_closure_set(x_339, 4, x_5); -lean_closure_set(x_339, 5, x_338); -lean_closure_set(x_339, 6, x_313); -lean_inc(x_3); -lean_inc(x_314); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_263); -lean_inc(x_5); -x_340 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_340, 0, x_5); -lean_closure_set(x_340, 1, x_310); -lean_closure_set(x_340, 2, x_311); -lean_closure_set(x_340, 3, x_23); -lean_closure_set(x_340, 4, x_263); -lean_closure_set(x_340, 5, x_312); -lean_closure_set(x_340, 6, x_2); -lean_closure_set(x_340, 7, x_4); -lean_closure_set(x_340, 8, x_264); -lean_closure_set(x_340, 9, x_1); -lean_closure_set(x_340, 10, x_314); -lean_closure_set(x_340, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_341 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_341, 0, x_1); -lean_closure_set(x_341, 1, x_314); -lean_closure_set(x_341, 2, x_2); -lean_closure_set(x_341, 3, x_3); -lean_closure_set(x_341, 4, x_4); -lean_closure_set(x_341, 5, x_339); -lean_closure_set(x_341, 6, x_340); -lean_inc(x_5); -lean_inc(x_2); -x_342 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_342, 0, x_2); -lean_closure_set(x_342, 1, x_5); -lean_closure_set(x_342, 2, x_310); -lean_closure_set(x_342, 3, x_311); -lean_closure_set(x_342, 4, x_263); -lean_closure_set(x_342, 5, x_312); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_343 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_343, 0, x_1); -lean_closure_set(x_343, 1, x_314); -lean_closure_set(x_343, 2, x_2); -lean_closure_set(x_343, 3, x_3); -lean_closure_set(x_343, 4, x_4); -lean_closure_set(x_343, 5, x_341); -lean_closure_set(x_343, 6, x_342); -x_344 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_314, x_2, x_3, x_5, x_343, x_313, x_6, x_58); -return x_344; -} -} -else -{ -lean_object* x_345; -lean_dec(x_61); -lean_dec(x_60); -x_345 = lean_box(0); -x_315 = x_345; -goto block_321; -} -} -else -{ -lean_object* x_346; -lean_dec(x_61); -lean_dec(x_60); -x_346 = lean_box(0); -x_315 = x_346; -goto block_321; -} -block_321: -{ -lean_object* x_316; lean_object* x_317; lean_object* x_318; lean_object* x_319; lean_object* x_320; -lean_dec(x_315); -x_316 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_313); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_317 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_317, 0, x_1); -lean_closure_set(x_317, 1, x_314); -lean_closure_set(x_317, 2, x_2); -lean_closure_set(x_317, 3, x_3); -lean_closure_set(x_317, 4, x_5); -lean_closure_set(x_317, 5, x_316); -lean_closure_set(x_317, 6, x_313); -lean_inc(x_3); -lean_inc(x_314); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_318 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_318, 0, x_5); -lean_closure_set(x_318, 1, x_310); -lean_closure_set(x_318, 2, x_311); -lean_closure_set(x_318, 3, x_23); -lean_closure_set(x_318, 4, x_263); -lean_closure_set(x_318, 5, x_312); -lean_closure_set(x_318, 6, x_2); -lean_closure_set(x_318, 7, x_4); -lean_closure_set(x_318, 8, x_264); -lean_closure_set(x_318, 9, x_1); -lean_closure_set(x_318, 10, x_314); -lean_closure_set(x_318, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_314); -lean_inc(x_1); -x_319 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_319, 0, x_1); -lean_closure_set(x_319, 1, x_314); -lean_closure_set(x_319, 2, x_2); -lean_closure_set(x_319, 3, x_3); -lean_closure_set(x_319, 4, x_4); -lean_closure_set(x_319, 5, x_317); -lean_closure_set(x_319, 6, x_318); -x_320 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_314, x_2, x_3, x_5, x_319, x_313, x_6, x_58); -return x_320; -} -} -block_385: -{ -lean_dec(x_349); -if (x_282 == 0) -{ -if (x_348 == 0) -{ -uint8_t x_350; -x_350 = l_Lean_Expr_hasExprMVar(x_4); -if (x_350 == 0) -{ -uint8_t x_351; -x_351 = l_Lean_Expr_hasExprMVar(x_5); -if (x_351 == 0) -{ -lean_object* x_352; lean_object* x_353; uint8_t x_354; -x_352 = l_Lean_ConstantInfo_hints(x_60); -lean_dec(x_60); -x_353 = l_Lean_ConstantInfo_hints(x_61); -lean_dec(x_61); -x_354 = l_Lean_ReducibilityHints_lt(x_352, x_353); -if (x_354 == 0) -{ -uint8_t x_355; -x_355 = l_Lean_ReducibilityHints_lt(x_353, x_352); -lean_dec(x_352); -lean_dec(x_353); -if (x_355 == 0) -{ -lean_object* x_356; -x_356 = lean_box(0); -x_270 = x_356; -goto block_280; -} -else -{ -lean_object* x_357; -x_357 = lean_box(0); -x_283 = x_357; -goto block_294; -} -} -else -{ -lean_object* x_358; -lean_dec(x_353); -lean_dec(x_352); -x_358 = lean_box(0); -x_295 = x_358; -goto block_307; -} -} -else -{ -lean_object* x_359; -lean_dec(x_61); -lean_dec(x_60); -x_359 = lean_box(0); -x_270 = x_359; -goto block_280; -} -} -else -{ -lean_object* x_360; -lean_dec(x_61); -lean_dec(x_60); -x_360 = lean_box(0); -x_270 = x_360; -goto block_280; -} -} -else -{ -lean_object* x_361; -x_361 = lean_box(0); -x_308 = x_361; -goto block_347; -} -} -else -{ -if (x_269 == 0) -{ -uint8_t x_362; -x_362 = l_Lean_Expr_hasExprMVar(x_4); -if (x_362 == 0) -{ -uint8_t x_363; -x_363 = l_Lean_Expr_hasExprMVar(x_5); -if (x_363 == 0) -{ -lean_object* x_364; lean_object* x_365; uint8_t x_366; -x_364 = l_Lean_ConstantInfo_hints(x_60); -lean_dec(x_60); -x_365 = l_Lean_ConstantInfo_hints(x_61); -lean_dec(x_61); -x_366 = l_Lean_ReducibilityHints_lt(x_364, x_365); -if (x_366 == 0) -{ -uint8_t x_367; -x_367 = l_Lean_ReducibilityHints_lt(x_365, x_364); -lean_dec(x_364); -lean_dec(x_365); -if (x_367 == 0) -{ -lean_object* x_368; -x_368 = lean_box(0); -x_270 = x_368; -goto block_280; -} -else -{ -lean_object* x_369; -x_369 = lean_box(0); -x_283 = x_369; -goto block_294; -} -} -else -{ -lean_object* x_370; -lean_dec(x_365); -lean_dec(x_364); -x_370 = lean_box(0); -x_295 = x_370; -goto block_307; -} -} -else -{ -lean_object* x_371; -lean_dec(x_61); -lean_dec(x_60); -x_371 = lean_box(0); -x_270 = x_371; -goto block_280; -} -} -else -{ -lean_object* x_372; -lean_dec(x_61); -lean_dec(x_60); -x_372 = lean_box(0); -x_270 = x_372; -goto block_280; -} -} -else -{ -if (x_348 == 0) -{ -uint8_t x_373; -x_373 = l_Lean_Expr_hasExprMVar(x_4); -if (x_373 == 0) -{ -uint8_t x_374; -x_374 = l_Lean_Expr_hasExprMVar(x_5); -if (x_374 == 0) -{ -lean_object* x_375; lean_object* x_376; uint8_t x_377; -x_375 = l_Lean_ConstantInfo_hints(x_60); -lean_dec(x_60); -x_376 = l_Lean_ConstantInfo_hints(x_61); -lean_dec(x_61); -x_377 = l_Lean_ReducibilityHints_lt(x_375, x_376); -if (x_377 == 0) -{ -uint8_t x_378; -x_378 = l_Lean_ReducibilityHints_lt(x_376, x_375); -lean_dec(x_375); -lean_dec(x_376); -if (x_378 == 0) -{ -lean_object* x_379; -x_379 = lean_box(0); -x_270 = x_379; -goto block_280; -} -else -{ -lean_object* x_380; -x_380 = lean_box(0); -x_283 = x_380; -goto block_294; -} -} -else -{ -lean_object* x_381; -lean_dec(x_376); -lean_dec(x_375); -x_381 = lean_box(0); -x_295 = x_381; -goto block_307; -} -} -else -{ -lean_object* x_382; -lean_dec(x_61); -lean_dec(x_60); -x_382 = lean_box(0); -x_270 = x_382; -goto block_280; -} -} -else -{ -lean_object* x_383; -lean_dec(x_61); -lean_dec(x_60); -x_383 = lean_box(0); -x_270 = x_383; -goto block_280; -} -} -else -{ -lean_object* x_384; -x_384 = lean_box(0); -x_308 = x_384; -goto block_347; -} -} -} -} -} -else -{ -uint8_t x_429; -x_429 = l_Lean_Expr_hasExprMVar(x_4); -if (x_429 == 0) -{ -uint8_t x_430; -x_430 = l_Lean_Expr_hasExprMVar(x_5); -if (x_430 == 0) -{ -lean_object* x_431; lean_object* x_432; uint8_t x_433; -x_431 = l_Lean_ConstantInfo_hints(x_60); -lean_dec(x_60); -x_432 = l_Lean_ConstantInfo_hints(x_61); -lean_dec(x_61); -x_433 = l_Lean_ReducibilityHints_lt(x_431, x_432); -if (x_433 == 0) -{ -uint8_t x_434; -x_434 = l_Lean_ReducibilityHints_lt(x_432, x_431); -lean_dec(x_431); -lean_dec(x_432); -if (x_434 == 0) -{ -lean_object* x_435; lean_object* x_436; lean_object* x_437; lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; lean_object* x_443; -x_435 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_436 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_437 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_438 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_438, 0, x_2); -lean_closure_set(x_438, 1, x_4); -lean_closure_set(x_438, 2, x_435); -lean_closure_set(x_438, 3, x_436); -lean_closure_set(x_438, 4, x_264); -lean_closure_set(x_438, 5, x_437); -lean_inc(x_1); -x_439 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_439, 0, x_1); -x_440 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_439); -lean_inc(x_1); -x_441 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_441, 0, x_1); -lean_closure_set(x_441, 1, x_439); -lean_closure_set(x_441, 2, x_2); -lean_closure_set(x_441, 3, x_3); -lean_closure_set(x_441, 4, x_5); -lean_closure_set(x_441, 5, x_440); -lean_closure_set(x_441, 6, x_438); -lean_inc(x_3); -lean_inc(x_439); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_442 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_442, 0, x_5); -lean_closure_set(x_442, 1, x_435); -lean_closure_set(x_442, 2, x_436); -lean_closure_set(x_442, 3, x_23); -lean_closure_set(x_442, 4, x_263); -lean_closure_set(x_442, 5, x_437); -lean_closure_set(x_442, 6, x_2); -lean_closure_set(x_442, 7, x_4); -lean_closure_set(x_442, 8, x_264); -lean_closure_set(x_442, 9, x_1); -lean_closure_set(x_442, 10, x_439); -lean_closure_set(x_442, 11, x_3); -x_443 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_439, x_2, x_3, x_4, x_441, x_442, x_6, x_58); -return x_443; -} -else -{ -lean_object* x_444; lean_object* x_445; lean_object* x_446; lean_object* x_447; lean_object* x_448; lean_object* x_449; lean_object* x_450; lean_object* x_451; lean_object* x_452; lean_object* x_453; -x_444 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_445 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_446 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_447 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_447, 0, x_2); -lean_closure_set(x_447, 1, x_4); -lean_closure_set(x_447, 2, x_444); -lean_closure_set(x_447, 3, x_445); -lean_closure_set(x_447, 4, x_264); -lean_closure_set(x_447, 5, x_446); -lean_inc(x_1); -x_448 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_448, 0, x_1); -x_449 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_447); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_448); -lean_inc(x_1); -x_450 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_450, 0, x_1); -lean_closure_set(x_450, 1, x_448); -lean_closure_set(x_450, 2, x_2); -lean_closure_set(x_450, 3, x_3); -lean_closure_set(x_450, 4, x_5); -lean_closure_set(x_450, 5, x_449); -lean_closure_set(x_450, 6, x_447); -lean_inc(x_3); -lean_inc(x_448); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_451 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_451, 0, x_5); -lean_closure_set(x_451, 1, x_444); -lean_closure_set(x_451, 2, x_445); -lean_closure_set(x_451, 3, x_23); -lean_closure_set(x_451, 4, x_263); -lean_closure_set(x_451, 5, x_446); -lean_closure_set(x_451, 6, x_2); -lean_closure_set(x_451, 7, x_4); -lean_closure_set(x_451, 8, x_264); -lean_closure_set(x_451, 9, x_1); -lean_closure_set(x_451, 10, x_448); -lean_closure_set(x_451, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_448); -lean_inc(x_1); -x_452 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_452, 0, x_1); -lean_closure_set(x_452, 1, x_448); -lean_closure_set(x_452, 2, x_2); -lean_closure_set(x_452, 3, x_3); -lean_closure_set(x_452, 4, x_4); -lean_closure_set(x_452, 5, x_450); -lean_closure_set(x_452, 6, x_451); -x_453 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_448, x_2, x_3, x_5, x_452, x_447, x_6, x_58); -return x_453; -} -} -else -{ -lean_object* x_454; lean_object* x_455; lean_object* x_456; lean_object* x_457; lean_object* x_458; lean_object* x_459; lean_object* x_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; -lean_dec(x_432); -lean_dec(x_431); -x_454 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_455 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_456 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_457 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_457, 0, x_2); -lean_closure_set(x_457, 1, x_4); -lean_closure_set(x_457, 2, x_454); -lean_closure_set(x_457, 3, x_455); -lean_closure_set(x_457, 4, x_264); -lean_closure_set(x_457, 5, x_456); -lean_inc(x_1); -x_458 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_458, 0, x_1); -x_459 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_458); -lean_inc(x_1); -x_460 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_460, 0, x_1); -lean_closure_set(x_460, 1, x_458); -lean_closure_set(x_460, 2, x_2); -lean_closure_set(x_460, 3, x_3); -lean_closure_set(x_460, 4, x_5); -lean_closure_set(x_460, 5, x_459); -lean_closure_set(x_460, 6, x_457); -lean_inc(x_3); -lean_inc(x_458); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_263); -lean_inc(x_5); -x_461 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_461, 0, x_5); -lean_closure_set(x_461, 1, x_454); -lean_closure_set(x_461, 2, x_455); -lean_closure_set(x_461, 3, x_23); -lean_closure_set(x_461, 4, x_263); -lean_closure_set(x_461, 5, x_456); -lean_closure_set(x_461, 6, x_2); -lean_closure_set(x_461, 7, x_4); -lean_closure_set(x_461, 8, x_264); -lean_closure_set(x_461, 9, x_1); -lean_closure_set(x_461, 10, x_458); -lean_closure_set(x_461, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_458); -lean_inc(x_1); -x_462 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_462, 0, x_1); -lean_closure_set(x_462, 1, x_458); -lean_closure_set(x_462, 2, x_2); -lean_closure_set(x_462, 3, x_3); -lean_closure_set(x_462, 4, x_4); -lean_closure_set(x_462, 5, x_460); -lean_closure_set(x_462, 6, x_461); -lean_inc(x_2); -x_463 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_463, 0, x_2); -lean_closure_set(x_463, 1, x_5); -lean_closure_set(x_463, 2, x_454); -lean_closure_set(x_463, 3, x_455); -lean_closure_set(x_463, 4, x_263); -lean_closure_set(x_463, 5, x_456); -x_464 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_458, x_2, x_3, x_4, x_462, x_463, x_6, x_58); -return x_464; -} -} -else -{ -lean_object* x_465; -lean_dec(x_61); -lean_dec(x_60); -x_465 = lean_box(0); -x_270 = x_465; -goto block_280; -} -} -else -{ -lean_object* x_466; -lean_dec(x_61); -lean_dec(x_60); -x_466 = lean_box(0); -x_270 = x_466; -goto block_280; -} -} -block_280: -{ -lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; lean_object* x_275; lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; -lean_dec(x_270); -x_271 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_272 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_273 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_264); -lean_inc(x_4); -lean_inc(x_2); -x_274 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_274, 0, x_2); -lean_closure_set(x_274, 1, x_4); -lean_closure_set(x_274, 2, x_271); -lean_closure_set(x_274, 3, x_272); -lean_closure_set(x_274, 4, x_264); -lean_closure_set(x_274, 5, x_273); -lean_inc(x_1); -x_275 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_275, 0, x_1); -x_276 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_275); -lean_inc(x_1); -x_277 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_277, 0, x_1); -lean_closure_set(x_277, 1, x_275); -lean_closure_set(x_277, 2, x_2); -lean_closure_set(x_277, 3, x_3); -lean_closure_set(x_277, 4, x_5); -lean_closure_set(x_277, 5, x_276); -lean_closure_set(x_277, 6, x_274); -lean_inc(x_3); -lean_inc(x_275); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_278 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_278, 0, x_5); -lean_closure_set(x_278, 1, x_271); -lean_closure_set(x_278, 2, x_272); -lean_closure_set(x_278, 3, x_23); -lean_closure_set(x_278, 4, x_263); -lean_closure_set(x_278, 5, x_273); -lean_closure_set(x_278, 6, x_2); -lean_closure_set(x_278, 7, x_4); -lean_closure_set(x_278, 8, x_264); -lean_closure_set(x_278, 9, x_1); -lean_closure_set(x_278, 10, x_275); -lean_closure_set(x_278, 11, x_3); -x_279 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_275, x_2, x_3, x_4, x_277, x_278, x_6, x_58); -return x_279; -} -} -else -{ -lean_dec(x_264); -lean_dec(x_263); -switch (lean_obj_tag(x_4)) { -case 4: -{ -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_24); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -if (lean_obj_tag(x_5) == 4) -{ -lean_object* x_467; lean_object* x_468; lean_object* x_469; -lean_free_object(x_25); -x_467 = lean_ctor_get(x_4, 1); -lean_inc(x_467); -lean_dec(x_4); -x_468 = lean_ctor_get(x_5, 1); -lean_inc(x_468); -lean_dec(x_5); -x_469 = l_Lean_Meta_isListLevelDefEq___main(x_467, x_468, x_6, x_58); -if (lean_obj_tag(x_469) == 0) -{ -uint8_t x_470; -x_470 = !lean_is_exclusive(x_469); -if (x_470 == 0) -{ -lean_object* x_471; uint8_t x_472; uint8_t x_473; lean_object* x_474; -x_471 = lean_ctor_get(x_469, 0); -x_472 = lean_unbox(x_471); -lean_dec(x_471); -x_473 = l_Bool_toLBool(x_472); -x_474 = lean_box(x_473); -lean_ctor_set(x_469, 0, x_474); -return x_469; -} -else -{ -lean_object* x_475; lean_object* x_476; uint8_t x_477; uint8_t x_478; lean_object* x_479; lean_object* x_480; -x_475 = lean_ctor_get(x_469, 0); -x_476 = lean_ctor_get(x_469, 1); -lean_inc(x_476); -lean_inc(x_475); -lean_dec(x_469); -x_477 = lean_unbox(x_475); -lean_dec(x_475); -x_478 = l_Bool_toLBool(x_477); -x_479 = lean_box(x_478); -x_480 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_480, 0, x_479); -lean_ctor_set(x_480, 1, x_476); -return x_480; -} -} -else -{ -uint8_t x_481; -x_481 = !lean_is_exclusive(x_469); -if (x_481 == 0) -{ -return x_469; -} -else -{ -lean_object* x_482; lean_object* x_483; lean_object* x_484; -x_482 = lean_ctor_get(x_469, 0); -x_483 = lean_ctor_get(x_469, 1); -lean_inc(x_483); -lean_inc(x_482); -lean_dec(x_469); -x_484 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_484, 0, x_482); -lean_ctor_set(x_484, 1, x_483); -return x_484; -} -} -} -else -{ -uint8_t x_485; lean_object* x_486; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_485 = 0; -x_486 = lean_box(x_485); -lean_ctor_set(x_25, 1, x_58); -lean_ctor_set(x_25, 0, x_486); -return x_25; -} -} -case 5: -{ -if (lean_obj_tag(x_5) == 5) -{ -lean_object* x_487; uint8_t x_488; -lean_free_object(x_25); -x_487 = lean_ctor_get(x_58, 4); -lean_inc(x_487); -x_488 = lean_ctor_get_uint8(x_487, sizeof(void*)*1); -lean_dec(x_487); -if (x_488 == 0) -{ -uint8_t x_489; -x_489 = 0; -x_77 = x_489; -x_78 = x_58; -goto block_262; -} -else -{ -lean_object* x_490; lean_object* x_491; lean_object* x_492; lean_object* x_493; lean_object* x_494; -x_490 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_491 = l_Lean_Meta_tracer; -x_492 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__4; -x_493 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_490, x_491, x_492); +lean_object* x_54; lean_inc(x_6); -x_494 = lean_apply_2(x_493, x_6, x_58); -if (lean_obj_tag(x_494) == 0) -{ -lean_object* x_495; lean_object* x_496; uint8_t x_497; -x_495 = lean_ctor_get(x_494, 0); -lean_inc(x_495); -x_496 = lean_ctor_get(x_494, 1); -lean_inc(x_496); -lean_dec(x_494); -x_497 = lean_unbox(x_495); -lean_dec(x_495); -x_77 = x_497; -x_78 = x_496; -goto block_262; -} -else -{ -uint8_t x_498; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_498 = !lean_is_exclusive(x_494); -if (x_498 == 0) -{ -return x_494; -} -else -{ -lean_object* x_499; lean_object* x_500; lean_object* x_501; -x_499 = lean_ctor_get(x_494, 0); -x_500 = lean_ctor_get(x_494, 1); -lean_inc(x_500); -lean_inc(x_499); -lean_dec(x_494); -x_501 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_501, 0, x_499); -lean_ctor_set(x_501, 1, x_500); -return x_501; -} -} -} -} -else -{ -uint8_t x_502; lean_object* x_503; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_502 = 0; -x_503 = lean_box(x_502); -lean_ctor_set(x_25, 1, x_58); -lean_ctor_set(x_25, 0, x_503); -return x_25; +x_54 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_35); +return x_54; } } default: { -uint8_t x_504; lean_object* x_505; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_504 = 0; -x_505 = lean_box(x_504); -lean_ctor_set(x_25, 1, x_58); -lean_ctor_set(x_25, 0, x_505); -return x_25; -} -} -} -block_76: -{ -if (x_62 == 0) -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; -lean_dec(x_59); -x_64 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_65 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_66 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_4); -lean_inc(x_2); -x_67 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___boxed), 9, 6); -lean_closure_set(x_67, 0, x_2); -lean_closure_set(x_67, 1, x_4); -lean_closure_set(x_67, 2, x_61); -lean_closure_set(x_67, 3, x_64); -lean_closure_set(x_67, 4, x_65); -lean_closure_set(x_67, 5, x_66); -lean_inc(x_1); -x_68 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_68, 0, x_1); -x_69 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_68); -lean_inc(x_1); -x_70 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_70, 0, x_1); -lean_closure_set(x_70, 1, x_68); -lean_closure_set(x_70, 2, x_2); -lean_closure_set(x_70, 3, x_3); -lean_closure_set(x_70, 4, x_5); -lean_closure_set(x_70, 5, x_69); -lean_closure_set(x_70, 6, x_67); -lean_inc(x_3); -lean_inc(x_68); -lean_inc(x_1); -lean_inc(x_2); -x_71 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__8___boxed), 13, 10); -lean_closure_set(x_71, 0, x_60); -lean_closure_set(x_71, 1, x_64); -lean_closure_set(x_71, 2, x_65); -lean_closure_set(x_71, 3, x_23); -lean_closure_set(x_71, 4, x_66); -lean_closure_set(x_71, 5, x_2); -lean_closure_set(x_71, 6, x_5); -lean_closure_set(x_71, 7, x_1); -lean_closure_set(x_71, 8, x_68); -lean_closure_set(x_71, 9, x_3); -x_72 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_68, x_2, x_3, x_4, x_70, x_71, x_6, x_63); -return x_72; -} -else -{ -uint8_t x_73; lean_object* x_74; lean_object* x_75; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_73 = 1; -x_74 = lean_box(x_73); -if (lean_is_scalar(x_59)) { - x_75 = lean_alloc_ctor(0, 2, 0); -} else { - x_75 = x_59; -} -lean_ctor_set(x_75, 0, x_74); -lean_ctor_set(x_75, 1, x_63); -return x_75; -} -} -block_262: -{ -if (x_77 == 0) -{ -uint8_t x_79; -x_79 = !lean_is_exclusive(x_78); -if (x_79 == 0) -{ -lean_object* x_80; uint8_t x_81; -x_80 = lean_ctor_get(x_78, 4); -x_81 = !lean_is_exclusive(x_80); -if (x_81 == 0) -{ -uint8_t x_82; lean_object* x_83; -x_82 = 1; -lean_ctor_set_uint8(x_80, sizeof(void*)*1, x_82); +lean_object* x_55; lean_inc(x_6); -x_83 = l_Lean_Meta_try(x_24, x_6, x_78); -if (lean_obj_tag(x_83) == 0) -{ -lean_object* x_84; lean_object* x_85; lean_object* x_86; uint8_t x_87; -x_84 = lean_ctor_get(x_83, 1); -lean_inc(x_84); -x_85 = lean_ctor_get(x_84, 4); -lean_inc(x_85); -x_86 = lean_ctor_get(x_83, 0); -lean_inc(x_86); -lean_dec(x_83); -x_87 = !lean_is_exclusive(x_84); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; -x_88 = lean_ctor_get(x_84, 4); -lean_dec(x_88); -x_89 = !lean_is_exclusive(x_85); -if (x_89 == 0) -{ -uint8_t x_90; uint8_t x_91; -x_90 = 0; -lean_ctor_set_uint8(x_85, sizeof(void*)*1, x_90); -x_91 = lean_unbox(x_86); -lean_dec(x_86); -x_62 = x_91; -x_63 = x_84; -goto block_76; +x_55 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_35); +return x_55; } -else -{ -lean_object* x_92; uint8_t x_93; lean_object* x_94; uint8_t x_95; -x_92 = lean_ctor_get(x_85, 0); -lean_inc(x_92); -lean_dec(x_85); -x_93 = 0; -x_94 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_94, 0, x_92); -lean_ctor_set_uint8(x_94, sizeof(void*)*1, x_93); -lean_ctor_set(x_84, 4, x_94); -x_95 = lean_unbox(x_86); -lean_dec(x_86); -x_62 = x_95; -x_63 = x_84; -goto block_76; } } else { -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; uint8_t x_103; lean_object* x_104; lean_object* x_105; uint8_t x_106; -x_96 = lean_ctor_get(x_84, 0); -x_97 = lean_ctor_get(x_84, 1); -x_98 = lean_ctor_get(x_84, 2); -x_99 = lean_ctor_get(x_84, 3); -x_100 = lean_ctor_get(x_84, 5); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_inc(x_96); -lean_dec(x_84); -x_101 = lean_ctor_get(x_85, 0); -lean_inc(x_101); -if (lean_is_exclusive(x_85)) { - lean_ctor_release(x_85, 0); - x_102 = x_85; -} else { - lean_dec_ref(x_85); - x_102 = lean_box(0); -} -x_103 = 0; -if (lean_is_scalar(x_102)) { - x_104 = lean_alloc_ctor(0, 1, 1); -} else { - x_104 = x_102; -} -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set_uint8(x_104, sizeof(void*)*1, x_103); -x_105 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_105, 0, x_96); -lean_ctor_set(x_105, 1, x_97); -lean_ctor_set(x_105, 2, x_98); -lean_ctor_set(x_105, 3, x_99); -lean_ctor_set(x_105, 4, x_104); -lean_ctor_set(x_105, 5, x_100); -x_106 = lean_unbox(x_86); -lean_dec(x_86); -x_62 = x_106; -x_63 = x_105; -goto block_76; -} -} -else -{ -lean_object* x_107; lean_object* x_108; uint8_t x_109; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); +lean_object* x_56; lean_object* x_57; +lean_dec(x_9); lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); lean_dec(x_3); +x_56 = lean_box(x_34); +if (lean_is_scalar(x_33)) { + x_57 = lean_alloc_ctor(0, 2, 0); +} else { + x_57 = x_33; +} +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_35); +return x_57; +} +} +} +} +} +else +{ +uint8_t x_125; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_125 = !lean_is_exclusive(x_13); +if (x_125 == 0) +{ +return x_13; +} +else +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_13, 0); +x_127 = lean_ctor_get(x_13, 1); +lean_inc(x_127); +lean_inc(x_126); +lean_dec(x_13); +x_128 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_128, 0, x_126); +lean_ctor_set(x_128, 1, x_127); +return x_128; +} +} +} +else +{ +uint8_t x_129; +x_129 = lean_expr_eqv(x_2, x_9); lean_dec(x_2); -lean_dec(x_1); -x_107 = lean_ctor_get(x_83, 1); -lean_inc(x_107); -x_108 = lean_ctor_get(x_107, 4); -lean_inc(x_108); -x_109 = !lean_is_exclusive(x_83); -if (x_109 == 0) +if (x_129 == 0) { -lean_object* x_110; uint8_t x_111; -x_110 = lean_ctor_get(x_83, 1); -lean_dec(x_110); -x_111 = !lean_is_exclusive(x_107); -if (x_111 == 0) +lean_object* x_130; +lean_dec(x_11); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_130 = l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(x_6, x_9, x_3, x_10); +if (lean_obj_tag(x_130) == 0) { -lean_object* x_112; uint8_t x_113; -x_112 = lean_ctor_get(x_107, 4); -lean_dec(x_112); -x_113 = !lean_is_exclusive(x_108); -if (x_113 == 0) -{ -uint8_t x_114; -x_114 = 0; -lean_ctor_set_uint8(x_108, sizeof(void*)*1, x_114); -return x_83; -} -else -{ -lean_object* x_115; uint8_t x_116; lean_object* x_117; -x_115 = lean_ctor_get(x_108, 0); -lean_inc(x_115); -lean_dec(x_108); -x_116 = 0; -x_117 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_117, 0, x_115); -lean_ctor_set_uint8(x_117, sizeof(void*)*1, x_116); -lean_ctor_set(x_107, 4, x_117); -return x_83; -} -} -else -{ -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; uint8_t x_125; lean_object* x_126; lean_object* x_127; -x_118 = lean_ctor_get(x_107, 0); -x_119 = lean_ctor_get(x_107, 1); -x_120 = lean_ctor_get(x_107, 2); -x_121 = lean_ctor_get(x_107, 3); -x_122 = lean_ctor_get(x_107, 5); -lean_inc(x_122); -lean_inc(x_121); -lean_inc(x_120); -lean_inc(x_119); -lean_inc(x_118); -lean_dec(x_107); -x_123 = lean_ctor_get(x_108, 0); -lean_inc(x_123); -if (lean_is_exclusive(x_108)) { - lean_ctor_release(x_108, 0); - x_124 = x_108; -} else { - lean_dec_ref(x_108); - x_124 = lean_box(0); -} -x_125 = 0; -if (lean_is_scalar(x_124)) { - x_126 = lean_alloc_ctor(0, 1, 1); -} else { - x_126 = x_124; -} -lean_ctor_set(x_126, 0, x_123); -lean_ctor_set_uint8(x_126, sizeof(void*)*1, x_125); -x_127 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_127, 0, x_118); -lean_ctor_set(x_127, 1, x_119); -lean_ctor_set(x_127, 2, x_120); -lean_ctor_set(x_127, 3, x_121); -lean_ctor_set(x_127, 4, x_126); -lean_ctor_set(x_127, 5, x_122); -lean_ctor_set(x_83, 1, x_127); -return x_83; -} -} -else -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; uint8_t x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; -x_128 = lean_ctor_get(x_83, 0); -lean_inc(x_128); -lean_dec(x_83); -x_129 = lean_ctor_get(x_107, 0); -lean_inc(x_129); -x_130 = lean_ctor_get(x_107, 1); -lean_inc(x_130); -x_131 = lean_ctor_get(x_107, 2); +lean_object* x_131; uint8_t x_132; +x_131 = lean_ctor_get(x_130, 0); lean_inc(x_131); -x_132 = lean_ctor_get(x_107, 3); -lean_inc(x_132); -x_133 = lean_ctor_get(x_107, 5); -lean_inc(x_133); -if (lean_is_exclusive(x_107)) { - lean_ctor_release(x_107, 0); - lean_ctor_release(x_107, 1); - lean_ctor_release(x_107, 2); - lean_ctor_release(x_107, 3); - lean_ctor_release(x_107, 4); - lean_ctor_release(x_107, 5); - x_134 = x_107; -} else { - lean_dec_ref(x_107); - x_134 = lean_box(0); +x_132 = lean_unbox(x_131); +lean_dec(x_131); +switch (x_132) { +case 0: +{ +uint8_t x_133; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_133 = !lean_is_exclusive(x_130); +if (x_133 == 0) +{ +lean_object* x_134; uint8_t x_135; lean_object* x_136; +x_134 = lean_ctor_get(x_130, 0); +lean_dec(x_134); +x_135 = 0; +x_136 = lean_box(x_135); +lean_ctor_set(x_130, 0, x_136); +return x_130; } -x_135 = lean_ctor_get(x_108, 0); -lean_inc(x_135); -if (lean_is_exclusive(x_108)) { - lean_ctor_release(x_108, 0); - x_136 = x_108; -} else { - lean_dec_ref(x_108); - x_136 = lean_box(0); -} -x_137 = 0; -if (lean_is_scalar(x_136)) { - x_138 = lean_alloc_ctor(0, 1, 1); -} else { - x_138 = x_136; -} -lean_ctor_set(x_138, 0, x_135); -lean_ctor_set_uint8(x_138, sizeof(void*)*1, x_137); -if (lean_is_scalar(x_134)) { - x_139 = lean_alloc_ctor(0, 6, 0); -} else { - x_139 = x_134; -} -lean_ctor_set(x_139, 0, x_129); -lean_ctor_set(x_139, 1, x_130); -lean_ctor_set(x_139, 2, x_131); -lean_ctor_set(x_139, 3, x_132); -lean_ctor_set(x_139, 4, x_138); -lean_ctor_set(x_139, 5, x_133); -x_140 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_140, 0, x_128); -lean_ctor_set(x_140, 1, x_139); +else +{ +lean_object* x_137; uint8_t x_138; lean_object* x_139; lean_object* x_140; +x_137 = lean_ctor_get(x_130, 1); +lean_inc(x_137); +lean_dec(x_130); +x_138 = 0; +x_139 = lean_box(x_138); +x_140 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_140, 0, x_139); +lean_ctor_set(x_140, 1, x_137); return x_140; } } +case 1: +{ +uint8_t x_141; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_141 = !lean_is_exclusive(x_130); +if (x_141 == 0) +{ +lean_object* x_142; uint8_t x_143; lean_object* x_144; +x_142 = lean_ctor_get(x_130, 0); +lean_dec(x_142); +x_143 = 1; +x_144 = lean_box(x_143); +lean_ctor_set(x_130, 0, x_144); +return x_130; } else { -lean_object* x_141; uint8_t x_142; lean_object* x_143; lean_object* x_144; -x_141 = lean_ctor_get(x_80, 0); -lean_inc(x_141); -lean_dec(x_80); -x_142 = 1; -x_143 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_143, 0, x_141); -lean_ctor_set_uint8(x_143, sizeof(void*)*1, x_142); -lean_ctor_set(x_78, 4, x_143); -lean_inc(x_6); -x_144 = l_Lean_Meta_try(x_24, x_6, x_78); -if (lean_obj_tag(x_144) == 0) -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; uint8_t x_156; lean_object* x_157; lean_object* x_158; uint8_t x_159; -x_145 = lean_ctor_get(x_144, 1); +lean_object* x_145; uint8_t x_146; lean_object* x_147; lean_object* x_148; +x_145 = lean_ctor_get(x_130, 1); lean_inc(x_145); -x_146 = lean_ctor_get(x_145, 4); -lean_inc(x_146); -x_147 = lean_ctor_get(x_144, 0); -lean_inc(x_147); -lean_dec(x_144); -x_148 = lean_ctor_get(x_145, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_145, 1); +lean_dec(x_130); +x_146 = 1; +x_147 = lean_box(x_146); +x_148 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_148, 0, x_147); +lean_ctor_set(x_148, 1, x_145); +return x_148; +} +} +default: +{ +lean_object* x_149; lean_object* x_150; uint8_t x_151; lean_object* x_152; lean_object* x_176; +x_149 = lean_ctor_get(x_130, 1); lean_inc(x_149); -x_150 = lean_ctor_get(x_145, 2); -lean_inc(x_150); -x_151 = lean_ctor_get(x_145, 3); -lean_inc(x_151); -x_152 = lean_ctor_get(x_145, 5); -lean_inc(x_152); -if (lean_is_exclusive(x_145)) { - lean_ctor_release(x_145, 0); - lean_ctor_release(x_145, 1); - lean_ctor_release(x_145, 2); - lean_ctor_release(x_145, 3); - lean_ctor_release(x_145, 4); - lean_ctor_release(x_145, 5); - x_153 = x_145; +if (lean_is_exclusive(x_130)) { + lean_ctor_release(x_130, 0); + lean_ctor_release(x_130, 1); + x_150 = x_130; } else { - lean_dec_ref(x_145); - x_153 = lean_box(0); + lean_dec_ref(x_130); + x_150 = lean_box(0); } -x_154 = lean_ctor_get(x_146, 0); -lean_inc(x_154); -if (lean_is_exclusive(x_146)) { - lean_ctor_release(x_146, 0); - x_155 = x_146; -} else { - lean_dec_ref(x_146); - x_155 = lean_box(0); -} -x_156 = 0; -if (lean_is_scalar(x_155)) { - x_157 = lean_alloc_ctor(0, 1, 1); -} else { - x_157 = x_155; -} -lean_ctor_set(x_157, 0, x_154); -lean_ctor_set_uint8(x_157, sizeof(void*)*1, x_156); -if (lean_is_scalar(x_153)) { - x_158 = lean_alloc_ctor(0, 6, 0); -} else { - x_158 = x_153; -} -lean_ctor_set(x_158, 0, x_148); -lean_ctor_set(x_158, 1, x_149); -lean_ctor_set(x_158, 2, x_150); -lean_ctor_set(x_158, 3, x_151); -lean_ctor_set(x_158, 4, x_157); -lean_ctor_set(x_158, 5, x_152); -x_159 = lean_unbox(x_147); -lean_dec(x_147); -x_62 = x_159; -x_63 = x_158; -goto block_76; -} -else +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_176 = l_Lean_Meta_isDefEqOffset(x_6, x_9, x_3, x_149); +if (lean_obj_tag(x_176) == 0) { -lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; uint8_t x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_160 = lean_ctor_get(x_144, 1); -lean_inc(x_160); -x_161 = lean_ctor_get(x_160, 4); -lean_inc(x_161); -x_162 = lean_ctor_get(x_144, 0); -lean_inc(x_162); -if (lean_is_exclusive(x_144)) { - lean_ctor_release(x_144, 0); - lean_ctor_release(x_144, 1); - x_163 = x_144; -} else { - lean_dec_ref(x_144); - x_163 = lean_box(0); -} -x_164 = lean_ctor_get(x_160, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_160, 1); -lean_inc(x_165); -x_166 = lean_ctor_get(x_160, 2); -lean_inc(x_166); -x_167 = lean_ctor_get(x_160, 3); -lean_inc(x_167); -x_168 = lean_ctor_get(x_160, 5); -lean_inc(x_168); -if (lean_is_exclusive(x_160)) { - lean_ctor_release(x_160, 0); - lean_ctor_release(x_160, 1); - lean_ctor_release(x_160, 2); - lean_ctor_release(x_160, 3); - lean_ctor_release(x_160, 4); - lean_ctor_release(x_160, 5); - x_169 = x_160; -} else { - lean_dec_ref(x_160); - x_169 = lean_box(0); -} -x_170 = lean_ctor_get(x_161, 0); -lean_inc(x_170); -if (lean_is_exclusive(x_161)) { - lean_ctor_release(x_161, 0); - x_171 = x_161; -} else { - lean_dec_ref(x_161); - x_171 = lean_box(0); -} -x_172 = 0; -if (lean_is_scalar(x_171)) { - x_173 = lean_alloc_ctor(0, 1, 1); -} else { - x_173 = x_171; -} -lean_ctor_set(x_173, 0, x_170); -lean_ctor_set_uint8(x_173, sizeof(void*)*1, x_172); -if (lean_is_scalar(x_169)) { - x_174 = lean_alloc_ctor(0, 6, 0); -} else { - x_174 = x_169; -} -lean_ctor_set(x_174, 0, x_164); -lean_ctor_set(x_174, 1, x_165); -lean_ctor_set(x_174, 2, x_166); -lean_ctor_set(x_174, 3, x_167); -lean_ctor_set(x_174, 4, x_173); -lean_ctor_set(x_174, 5, x_168); -if (lean_is_scalar(x_163)) { - x_175 = lean_alloc_ctor(1, 2, 0); -} else { - x_175 = x_163; -} -lean_ctor_set(x_175, 0, x_162); -lean_ctor_set(x_175, 1, x_174); -return x_175; -} -} -} -else -{ -lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; uint8_t x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; -x_176 = lean_ctor_get(x_78, 4); -x_177 = lean_ctor_get(x_78, 0); -x_178 = lean_ctor_get(x_78, 1); -x_179 = lean_ctor_get(x_78, 2); -x_180 = lean_ctor_get(x_78, 3); -x_181 = lean_ctor_get(x_78, 5); -lean_inc(x_181); -lean_inc(x_176); -lean_inc(x_180); -lean_inc(x_179); -lean_inc(x_178); +lean_object* x_177; uint8_t x_178; +x_177 = lean_ctor_get(x_176, 0); lean_inc(x_177); -lean_dec(x_78); -x_182 = lean_ctor_get(x_176, 0); -lean_inc(x_182); -if (lean_is_exclusive(x_176)) { - lean_ctor_release(x_176, 0); - x_183 = x_176; -} else { - lean_dec_ref(x_176); - x_183 = lean_box(0); -} -x_184 = 1; -if (lean_is_scalar(x_183)) { - x_185 = lean_alloc_ctor(0, 1, 1); -} else { - x_185 = x_183; -} -lean_ctor_set(x_185, 0, x_182); -lean_ctor_set_uint8(x_185, sizeof(void*)*1, x_184); -x_186 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_186, 0, x_177); -lean_ctor_set(x_186, 1, x_178); -lean_ctor_set(x_186, 2, x_179); -lean_ctor_set(x_186, 3, x_180); -lean_ctor_set(x_186, 4, x_185); -lean_ctor_set(x_186, 5, x_181); -lean_inc(x_6); -x_187 = l_Lean_Meta_try(x_24, x_6, x_186); -if (lean_obj_tag(x_187) == 0) +x_178 = lean_unbox(x_177); +lean_dec(x_177); +switch (x_178) { +case 0: { -lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; uint8_t x_199; lean_object* x_200; lean_object* x_201; uint8_t x_202; -x_188 = lean_ctor_get(x_187, 1); -lean_inc(x_188); -x_189 = lean_ctor_get(x_188, 4); -lean_inc(x_189); -x_190 = lean_ctor_get(x_187, 0); -lean_inc(x_190); -lean_dec(x_187); -x_191 = lean_ctor_get(x_188, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_188, 1); -lean_inc(x_192); -x_193 = lean_ctor_get(x_188, 2); -lean_inc(x_193); -x_194 = lean_ctor_get(x_188, 3); -lean_inc(x_194); -x_195 = lean_ctor_get(x_188, 5); -lean_inc(x_195); -if (lean_is_exclusive(x_188)) { - lean_ctor_release(x_188, 0); - lean_ctor_release(x_188, 1); - lean_ctor_release(x_188, 2); - lean_ctor_release(x_188, 3); - lean_ctor_release(x_188, 4); - lean_ctor_release(x_188, 5); - x_196 = x_188; -} else { - lean_dec_ref(x_188); - x_196 = lean_box(0); -} -x_197 = lean_ctor_get(x_189, 0); -lean_inc(x_197); -if (lean_is_exclusive(x_189)) { - lean_ctor_release(x_189, 0); - x_198 = x_189; -} else { - lean_dec_ref(x_189); - x_198 = lean_box(0); -} -x_199 = 0; -if (lean_is_scalar(x_198)) { - x_200 = lean_alloc_ctor(0, 1, 1); -} else { - x_200 = x_198; -} -lean_ctor_set(x_200, 0, x_197); -lean_ctor_set_uint8(x_200, sizeof(void*)*1, x_199); -if (lean_is_scalar(x_196)) { - x_201 = lean_alloc_ctor(0, 6, 0); -} else { - x_201 = x_196; -} -lean_ctor_set(x_201, 0, x_191); -lean_ctor_set(x_201, 1, x_192); -lean_ctor_set(x_201, 2, x_193); -lean_ctor_set(x_201, 3, x_194); -lean_ctor_set(x_201, 4, x_200); -lean_ctor_set(x_201, 5, x_195); -x_202 = lean_unbox(x_190); -lean_dec(x_190); -x_62 = x_202; -x_63 = x_201; -goto block_76; -} -else -{ -lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; uint8_t x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); +uint8_t x_179; +lean_dec(x_150); +lean_dec(x_9); lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_203 = lean_ctor_get(x_187, 1); +x_179 = !lean_is_exclusive(x_176); +if (x_179 == 0) +{ +lean_object* x_180; uint8_t x_181; lean_object* x_182; +x_180 = lean_ctor_get(x_176, 0); +lean_dec(x_180); +x_181 = 0; +x_182 = lean_box(x_181); +lean_ctor_set(x_176, 0, x_182); +return x_176; +} +else +{ +lean_object* x_183; uint8_t x_184; lean_object* x_185; lean_object* x_186; +x_183 = lean_ctor_get(x_176, 1); +lean_inc(x_183); +lean_dec(x_176); +x_184 = 0; +x_185 = lean_box(x_184); +x_186 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_186, 0, x_185); +lean_ctor_set(x_186, 1, x_183); +return x_186; +} +} +case 1: +{ +uint8_t x_187; +lean_dec(x_150); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_187 = !lean_is_exclusive(x_176); +if (x_187 == 0) +{ +lean_object* x_188; uint8_t x_189; lean_object* x_190; +x_188 = lean_ctor_get(x_176, 0); +lean_dec(x_188); +x_189 = 1; +x_190 = lean_box(x_189); +lean_ctor_set(x_176, 0, x_190); +return x_176; +} +else +{ +lean_object* x_191; uint8_t x_192; lean_object* x_193; lean_object* x_194; +x_191 = lean_ctor_get(x_176, 1); +lean_inc(x_191); +lean_dec(x_176); +x_192 = 1; +x_193 = lean_box(x_192); +x_194 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_194, 0, x_193); +lean_ctor_set(x_194, 1, x_191); +return x_194; +} +} +default: +{ +lean_object* x_195; lean_object* x_196; +x_195 = lean_ctor_get(x_176, 1); +lean_inc(x_195); +lean_dec(x_176); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_196 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta(x_6, x_9, x_3, x_195); +if (lean_obj_tag(x_196) == 0) +{ +lean_object* x_197; uint8_t x_198; +x_197 = lean_ctor_get(x_196, 0); +lean_inc(x_197); +x_198 = lean_unbox(x_197); +lean_dec(x_197); +switch (x_198) { +case 0: +{ +uint8_t x_199; +lean_dec(x_150); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_199 = !lean_is_exclusive(x_196); +if (x_199 == 0) +{ +lean_object* x_200; uint8_t x_201; lean_object* x_202; +x_200 = lean_ctor_get(x_196, 0); +lean_dec(x_200); +x_201 = 0; +x_202 = lean_box(x_201); +lean_ctor_set(x_196, 0, x_202); +return x_196; +} +else +{ +lean_object* x_203; uint8_t x_204; lean_object* x_205; lean_object* x_206; +x_203 = lean_ctor_get(x_196, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_203, 4); -lean_inc(x_204); -x_205 = lean_ctor_get(x_187, 0); -lean_inc(x_205); -if (lean_is_exclusive(x_187)) { - lean_ctor_release(x_187, 0); - lean_ctor_release(x_187, 1); - x_206 = x_187; -} else { - lean_dec_ref(x_187); - x_206 = lean_box(0); +lean_dec(x_196); +x_204 = 0; +x_205 = lean_box(x_204); +x_206 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_206, 0, x_205); +lean_ctor_set(x_206, 1, x_203); +return x_206; } -x_207 = lean_ctor_get(x_203, 0); -lean_inc(x_207); -x_208 = lean_ctor_get(x_203, 1); -lean_inc(x_208); -x_209 = lean_ctor_get(x_203, 2); -lean_inc(x_209); -x_210 = lean_ctor_get(x_203, 3); -lean_inc(x_210); -x_211 = lean_ctor_get(x_203, 5); +} +case 1: +{ +uint8_t x_207; +lean_dec(x_150); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_207 = !lean_is_exclusive(x_196); +if (x_207 == 0) +{ +lean_object* x_208; uint8_t x_209; lean_object* x_210; +x_208 = lean_ctor_get(x_196, 0); +lean_dec(x_208); +x_209 = 1; +x_210 = lean_box(x_209); +lean_ctor_set(x_196, 0, x_210); +return x_196; +} +else +{ +lean_object* x_211; uint8_t x_212; lean_object* x_213; lean_object* x_214; +x_211 = lean_ctor_get(x_196, 1); lean_inc(x_211); -if (lean_is_exclusive(x_203)) { - lean_ctor_release(x_203, 0); - lean_ctor_release(x_203, 1); - lean_ctor_release(x_203, 2); - lean_ctor_release(x_203, 3); - lean_ctor_release(x_203, 4); - lean_ctor_release(x_203, 5); - x_212 = x_203; -} else { - lean_dec_ref(x_203); - x_212 = lean_box(0); -} -x_213 = lean_ctor_get(x_204, 0); -lean_inc(x_213); -if (lean_is_exclusive(x_204)) { - lean_ctor_release(x_204, 0); - x_214 = x_204; -} else { - lean_dec_ref(x_204); - x_214 = lean_box(0); -} -x_215 = 0; -if (lean_is_scalar(x_214)) { - x_216 = lean_alloc_ctor(0, 1, 1); -} else { - x_216 = x_214; -} -lean_ctor_set(x_216, 0, x_213); -lean_ctor_set_uint8(x_216, sizeof(void*)*1, x_215); -if (lean_is_scalar(x_212)) { - x_217 = lean_alloc_ctor(0, 6, 0); -} else { - x_217 = x_212; -} -lean_ctor_set(x_217, 0, x_207); -lean_ctor_set(x_217, 1, x_208); -lean_ctor_set(x_217, 2, x_209); -lean_ctor_set(x_217, 3, x_210); -lean_ctor_set(x_217, 4, x_216); -lean_ctor_set(x_217, 5, x_211); -if (lean_is_scalar(x_206)) { - x_218 = lean_alloc_ctor(1, 2, 0); -} else { - x_218 = x_206; -} -lean_ctor_set(x_218, 0, x_205); -lean_ctor_set(x_218, 1, x_217); -return x_218; +lean_dec(x_196); +x_212 = 1; +x_213 = lean_box(x_212); +x_214 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_214, 0, x_213); +lean_ctor_set(x_214, 1, x_211); +return x_214; } } +default: +{ +lean_object* x_215; lean_object* x_216; +x_215 = lean_ctor_get(x_196, 1); +lean_inc(x_215); +lean_dec(x_196); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_216 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(x_6, x_9, x_3, x_215); +if (lean_obj_tag(x_216) == 0) +{ +lean_object* x_217; uint8_t x_218; +x_217 = lean_ctor_get(x_216, 0); +lean_inc(x_217); +x_218 = lean_unbox(x_217); +if (x_218 == 0) +{ +lean_object* x_219; lean_object* x_220; +lean_dec(x_217); +x_219 = lean_ctor_get(x_216, 1); +lean_inc(x_219); +lean_dec(x_216); +lean_inc(x_3); +lean_inc(x_6); +lean_inc(x_9); +x_220 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(x_9, x_6, x_3, x_219); +if (lean_obj_tag(x_220) == 0) +{ +lean_object* x_221; lean_object* x_222; uint8_t x_223; +x_221 = lean_ctor_get(x_220, 0); +lean_inc(x_221); +x_222 = lean_ctor_get(x_220, 1); +lean_inc(x_222); +lean_dec(x_220); +x_223 = lean_unbox(x_221); +lean_dec(x_221); +x_151 = x_223; +x_152 = x_222; +goto block_175; } else { -lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; -x_219 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_220 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_221 = l___private_Init_Lean_Trace_2__getResetTraces___rarg(x_219, x_220); -lean_inc(x_6); -x_222 = lean_apply_2(x_221, x_6, x_78); -if (lean_obj_tag(x_222) == 0) +uint8_t x_224; +lean_dec(x_150); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_224 = !lean_is_exclusive(x_220); +if (x_224 == 0) { -lean_object* x_223; lean_object* x_224; lean_object* x_225; -x_223 = lean_ctor_get(x_222, 0); -lean_inc(x_223); -x_224 = lean_ctor_get(x_222, 1); -lean_inc(x_224); -lean_dec(x_222); -lean_inc(x_6); -x_225 = l_Lean_Meta_try(x_24, x_6, x_224); -if (lean_obj_tag(x_225) == 0) +return x_220; +} +else { -lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_226 = lean_ctor_get(x_225, 0); +lean_object* x_225; lean_object* x_226; lean_object* x_227; +x_225 = lean_ctor_get(x_220, 0); +x_226 = lean_ctor_get(x_220, 1); lean_inc(x_226); -x_227 = lean_ctor_get(x_225, 1); -lean_inc(x_227); -lean_dec(x_225); -x_228 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -lean_inc(x_223); -x_229 = l___private_Init_Lean_Trace_1__addNode___rarg(x_220, x_223, x_228); -lean_inc(x_6); -x_230 = lean_apply_2(x_229, x_6, x_227); -if (lean_obj_tag(x_230) == 0) +lean_inc(x_225); +lean_dec(x_220); +x_227 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_227, 0, x_225); +lean_ctor_set(x_227, 1, x_226); +return x_227; +} +} +} +else { -lean_object* x_231; uint8_t x_232; -lean_dec(x_223); -x_231 = lean_ctor_get(x_230, 1); +lean_object* x_228; uint8_t x_229; +x_228 = lean_ctor_get(x_216, 1); +lean_inc(x_228); +lean_dec(x_216); +x_229 = lean_unbox(x_217); +lean_dec(x_217); +x_151 = x_229; +x_152 = x_228; +goto block_175; +} +} +else +{ +uint8_t x_230; +lean_dec(x_150); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_230 = !lean_is_exclusive(x_216); +if (x_230 == 0) +{ +return x_216; +} +else +{ +lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_231 = lean_ctor_get(x_216, 0); +x_232 = lean_ctor_get(x_216, 1); +lean_inc(x_232); lean_inc(x_231); -lean_dec(x_230); -x_232 = lean_unbox(x_226); -lean_dec(x_226); -x_62 = x_232; -x_63 = x_231; -goto block_76; +lean_dec(x_216); +x_233 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_233, 0, x_231); +lean_ctor_set(x_233, 1, x_232); +return x_233; +} +} +} +} } else { -lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; -lean_dec(x_226); -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_5); -lean_dec(x_4); +uint8_t x_234; +lean_dec(x_150); +lean_dec(x_9); +lean_dec(x_6); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_233 = lean_ctor_get(x_230, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_230, 1); -lean_inc(x_234); -lean_dec(x_230); -x_235 = l___private_Init_Lean_Trace_1__addNode___rarg(x_220, x_223, x_228); -x_236 = lean_apply_2(x_235, x_6, x_234); -if (lean_obj_tag(x_236) == 0) +x_234 = !lean_is_exclusive(x_196); +if (x_234 == 0) { -uint8_t x_237; -x_237 = !lean_is_exclusive(x_236); -if (x_237 == 0) -{ -lean_object* x_238; -x_238 = lean_ctor_get(x_236, 0); -lean_dec(x_238); -lean_ctor_set_tag(x_236, 1); -lean_ctor_set(x_236, 0, x_233); -return x_236; +return x_196; } else { -lean_object* x_239; lean_object* x_240; -x_239 = lean_ctor_get(x_236, 1); +lean_object* x_235; lean_object* x_236; lean_object* x_237; +x_235 = lean_ctor_get(x_196, 0); +x_236 = lean_ctor_get(x_196, 1); +lean_inc(x_236); +lean_inc(x_235); +lean_dec(x_196); +x_237 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_237, 0, x_235); +lean_ctor_set(x_237, 1, x_236); +return x_237; +} +} +} +} +} +else +{ +uint8_t x_238; +lean_dec(x_150); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_238 = !lean_is_exclusive(x_176); +if (x_238 == 0) +{ +return x_176; +} +else +{ +lean_object* x_239; lean_object* x_240; lean_object* x_241; +x_239 = lean_ctor_get(x_176, 0); +x_240 = lean_ctor_get(x_176, 1); +lean_inc(x_240); lean_inc(x_239); -lean_dec(x_236); -x_240 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_240, 0, x_233); -lean_ctor_set(x_240, 1, x_239); -return x_240; +lean_dec(x_176); +x_241 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_241, 0, x_239); +lean_ctor_set(x_241, 1, x_240); +return x_241; } } -else +block_175: { -uint8_t x_241; -lean_dec(x_233); -x_241 = !lean_is_exclusive(x_236); -if (x_241 == 0) +if (x_151 == 0) { -return x_236; -} -else +lean_dec(x_150); +switch (lean_obj_tag(x_6)) { +case 4: { -lean_object* x_242; lean_object* x_243; lean_object* x_244; -x_242 = lean_ctor_get(x_236, 0); -x_243 = lean_ctor_get(x_236, 1); -lean_inc(x_243); -lean_inc(x_242); -lean_dec(x_236); -x_244 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_244, 0, x_242); -lean_ctor_set(x_244, 1, x_243); -return x_244; -} -} -} -} -else +if (lean_obj_tag(x_9) == 4) { -lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_5); -lean_dec(x_4); +lean_object* x_153; lean_object* x_154; lean_object* x_155; +x_153 = lean_ctor_get(x_6, 1); +lean_inc(x_153); +lean_dec(x_6); +x_154 = lean_ctor_get(x_9, 1); +lean_inc(x_154); +lean_dec(x_9); +x_155 = l_Lean_Meta_isListLevelDefEqAux___main(x_153, x_154, x_3, x_152); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_245 = lean_ctor_get(x_225, 0); -lean_inc(x_245); -x_246 = lean_ctor_get(x_225, 1); -lean_inc(x_246); -lean_dec(x_225); -x_247 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_248 = l___private_Init_Lean_Trace_1__addNode___rarg(x_220, x_223, x_247); -x_249 = lean_apply_2(x_248, x_6, x_246); -if (lean_obj_tag(x_249) == 0) +return x_155; +} +else { -uint8_t x_250; -x_250 = !lean_is_exclusive(x_249); -if (x_250 == 0) +lean_object* x_156; +lean_inc(x_6); +x_156 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_152); +return x_156; +} +} +case 5: +{ +if (lean_obj_tag(x_9) == 5) +{ +lean_object* x_157; lean_object* x_158; +x_157 = l_Lean_Expr_getAppFn___main(x_6); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_158 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1(x_6, x_9, x_157, x_3, x_152); +if (lean_obj_tag(x_158) == 0) +{ +lean_object* x_159; uint8_t x_160; +x_159 = lean_ctor_get(x_158, 0); +lean_inc(x_159); +x_160 = lean_unbox(x_159); +if (x_160 == 0) +{ +lean_object* x_161; lean_object* x_162; +lean_dec(x_159); +x_161 = lean_ctor_get(x_158, 1); +lean_inc(x_161); +lean_dec(x_158); +lean_inc(x_6); +x_162 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_161); +return x_162; +} +else +{ +uint8_t x_163; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_163 = !lean_is_exclusive(x_158); +if (x_163 == 0) +{ +lean_object* x_164; +x_164 = lean_ctor_get(x_158, 0); +lean_dec(x_164); +return x_158; +} +else +{ +lean_object* x_165; lean_object* x_166; +x_165 = lean_ctor_get(x_158, 1); +lean_inc(x_165); +lean_dec(x_158); +x_166 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_166, 0, x_159); +lean_ctor_set(x_166, 1, x_165); +return x_166; +} +} +} +else +{ +uint8_t x_167; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_167 = !lean_is_exclusive(x_158); +if (x_167 == 0) +{ +return x_158; +} +else +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_158, 0); +x_169 = lean_ctor_get(x_158, 1); +lean_inc(x_169); +lean_inc(x_168); +lean_dec(x_158); +x_170 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_170, 0, x_168); +lean_ctor_set(x_170, 1, x_169); +return x_170; +} +} +} +else +{ +lean_object* x_171; +lean_inc(x_6); +x_171 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_152); +return x_171; +} +} +default: +{ +lean_object* x_172; +lean_inc(x_6); +x_172 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_152); +return x_172; +} +} +} +else +{ +lean_object* x_173; lean_object* x_174; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_173 = lean_box(x_151); +if (lean_is_scalar(x_150)) { + x_174 = lean_alloc_ctor(0, 2, 0); +} else { + x_174 = x_150; +} +lean_ctor_set(x_174, 0, x_173); +lean_ctor_set(x_174, 1, x_152); +return x_174; +} +} +} +} +} +else +{ +uint8_t x_242; +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_242 = !lean_is_exclusive(x_130); +if (x_242 == 0) +{ +return x_130; +} +else +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_243 = lean_ctor_get(x_130, 0); +x_244 = lean_ctor_get(x_130, 1); +lean_inc(x_244); +lean_inc(x_243); +lean_dec(x_130); +x_245 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_245, 0, x_243); +lean_ctor_set(x_245, 1, x_244); +return x_245; +} +} +} +else +{ +uint8_t x_246; lean_object* x_247; lean_object* x_271; +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_271 = l_Lean_Meta_isDefEqOffset(x_6, x_9, x_3, x_10); +if (lean_obj_tag(x_271) == 0) +{ +lean_object* x_272; uint8_t x_273; +x_272 = lean_ctor_get(x_271, 0); +lean_inc(x_272); +x_273 = lean_unbox(x_272); +lean_dec(x_272); +switch (x_273) { +case 0: +{ +uint8_t x_274; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_274 = !lean_is_exclusive(x_271); +if (x_274 == 0) +{ +lean_object* x_275; uint8_t x_276; lean_object* x_277; +x_275 = lean_ctor_get(x_271, 0); +lean_dec(x_275); +x_276 = 0; +x_277 = lean_box(x_276); +lean_ctor_set(x_271, 0, x_277); +return x_271; +} +else +{ +lean_object* x_278; uint8_t x_279; lean_object* x_280; lean_object* x_281; +x_278 = lean_ctor_get(x_271, 1); +lean_inc(x_278); +lean_dec(x_271); +x_279 = 0; +x_280 = lean_box(x_279); +x_281 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_281, 0, x_280); +lean_ctor_set(x_281, 1, x_278); +return x_281; +} +} +case 1: +{ +uint8_t x_282; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_282 = !lean_is_exclusive(x_271); +if (x_282 == 0) +{ +lean_object* x_283; uint8_t x_284; lean_object* x_285; +x_283 = lean_ctor_get(x_271, 0); +lean_dec(x_283); +x_284 = 1; +x_285 = lean_box(x_284); +lean_ctor_set(x_271, 0, x_285); +return x_271; +} +else +{ +lean_object* x_286; uint8_t x_287; lean_object* x_288; lean_object* x_289; +x_286 = lean_ctor_get(x_271, 1); +lean_inc(x_286); +lean_dec(x_271); +x_287 = 1; +x_288 = lean_box(x_287); +x_289 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_289, 0, x_288); +lean_ctor_set(x_289, 1, x_286); +return x_289; +} +} +default: +{ +lean_object* x_290; lean_object* x_291; +x_290 = lean_ctor_get(x_271, 1); +lean_inc(x_290); +lean_dec(x_271); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_291 = l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta(x_6, x_9, x_3, x_290); +if (lean_obj_tag(x_291) == 0) +{ +lean_object* x_292; uint8_t x_293; +x_292 = lean_ctor_get(x_291, 0); +lean_inc(x_292); +x_293 = lean_unbox(x_292); +lean_dec(x_292); +switch (x_293) { +case 0: +{ +uint8_t x_294; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_294 = !lean_is_exclusive(x_291); +if (x_294 == 0) +{ +lean_object* x_295; uint8_t x_296; lean_object* x_297; +x_295 = lean_ctor_get(x_291, 0); +lean_dec(x_295); +x_296 = 0; +x_297 = lean_box(x_296); +lean_ctor_set(x_291, 0, x_297); +return x_291; +} +else +{ +lean_object* x_298; uint8_t x_299; lean_object* x_300; lean_object* x_301; +x_298 = lean_ctor_get(x_291, 1); +lean_inc(x_298); +lean_dec(x_291); +x_299 = 0; +x_300 = lean_box(x_299); +x_301 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_301, 0, x_300); +lean_ctor_set(x_301, 1, x_298); +return x_301; +} +} +case 1: +{ +uint8_t x_302; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_302 = !lean_is_exclusive(x_291); +if (x_302 == 0) +{ +lean_object* x_303; uint8_t x_304; lean_object* x_305; +x_303 = lean_ctor_get(x_291, 0); +lean_dec(x_303); +x_304 = 1; +x_305 = lean_box(x_304); +lean_ctor_set(x_291, 0, x_305); +return x_291; +} +else +{ +lean_object* x_306; uint8_t x_307; lean_object* x_308; lean_object* x_309; +x_306 = lean_ctor_get(x_291, 1); +lean_inc(x_306); +lean_dec(x_291); +x_307 = 1; +x_308 = lean_box(x_307); +x_309 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_309, 0, x_308); +lean_ctor_set(x_309, 1, x_306); +return x_309; +} +} +default: +{ +lean_object* x_310; lean_object* x_311; +x_310 = lean_ctor_get(x_291, 1); +lean_inc(x_310); +lean_dec(x_291); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_311 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(x_6, x_9, x_3, x_310); +if (lean_obj_tag(x_311) == 0) +{ +lean_object* x_312; uint8_t x_313; +x_312 = lean_ctor_get(x_311, 0); +lean_inc(x_312); +x_313 = lean_unbox(x_312); +if (x_313 == 0) +{ +lean_object* x_314; lean_object* x_315; +lean_dec(x_312); +x_314 = lean_ctor_get(x_311, 1); +lean_inc(x_314); +lean_dec(x_311); +lean_inc(x_3); +lean_inc(x_6); +lean_inc(x_9); +x_315 = l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta(x_9, x_6, x_3, x_314); +if (lean_obj_tag(x_315) == 0) +{ +lean_object* x_316; lean_object* x_317; uint8_t x_318; +x_316 = lean_ctor_get(x_315, 0); +lean_inc(x_316); +x_317 = lean_ctor_get(x_315, 1); +lean_inc(x_317); +lean_dec(x_315); +x_318 = lean_unbox(x_316); +lean_dec(x_316); +x_246 = x_318; +x_247 = x_317; +goto block_270; +} +else +{ +uint8_t x_319; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_319 = !lean_is_exclusive(x_315); +if (x_319 == 0) +{ +return x_315; +} +else +{ +lean_object* x_320; lean_object* x_321; lean_object* x_322; +x_320 = lean_ctor_get(x_315, 0); +x_321 = lean_ctor_get(x_315, 1); +lean_inc(x_321); +lean_inc(x_320); +lean_dec(x_315); +x_322 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_322, 0, x_320); +lean_ctor_set(x_322, 1, x_321); +return x_322; +} +} +} +else +{ +lean_object* x_323; uint8_t x_324; +x_323 = lean_ctor_get(x_311, 1); +lean_inc(x_323); +lean_dec(x_311); +x_324 = lean_unbox(x_312); +lean_dec(x_312); +x_246 = x_324; +x_247 = x_323; +goto block_270; +} +} +else +{ +uint8_t x_325; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_325 = !lean_is_exclusive(x_311); +if (x_325 == 0) +{ +return x_311; +} +else +{ +lean_object* x_326; lean_object* x_327; lean_object* x_328; +x_326 = lean_ctor_get(x_311, 0); +x_327 = lean_ctor_get(x_311, 1); +lean_inc(x_327); +lean_inc(x_326); +lean_dec(x_311); +x_328 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_328, 0, x_326); +lean_ctor_set(x_328, 1, x_327); +return x_328; +} +} +} +} +} +else +{ +uint8_t x_329; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_329 = !lean_is_exclusive(x_291); +if (x_329 == 0) +{ +return x_291; +} +else +{ +lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_330 = lean_ctor_get(x_291, 0); +x_331 = lean_ctor_get(x_291, 1); +lean_inc(x_331); +lean_inc(x_330); +lean_dec(x_291); +x_332 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_332, 0, x_330); +lean_ctor_set(x_332, 1, x_331); +return x_332; +} +} +} +} +} +else +{ +uint8_t x_333; +lean_dec(x_11); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_3); +x_333 = !lean_is_exclusive(x_271); +if (x_333 == 0) +{ +return x_271; +} +else +{ +lean_object* x_334; lean_object* x_335; lean_object* x_336; +x_334 = lean_ctor_get(x_271, 0); +x_335 = lean_ctor_get(x_271, 1); +lean_inc(x_335); +lean_inc(x_334); +lean_dec(x_271); +x_336 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_336, 0, x_334); +lean_ctor_set(x_336, 1, x_335); +return x_336; +} +} +block_270: +{ +if (x_246 == 0) +{ +lean_dec(x_11); +switch (lean_obj_tag(x_6)) { +case 4: +{ +if (lean_obj_tag(x_9) == 4) +{ +lean_object* x_248; lean_object* x_249; lean_object* x_250; +x_248 = lean_ctor_get(x_6, 1); +lean_inc(x_248); +lean_dec(x_6); +x_249 = lean_ctor_get(x_9, 1); +lean_inc(x_249); +lean_dec(x_9); +x_250 = l_Lean_Meta_isListLevelDefEqAux___main(x_248, x_249, x_3, x_247); +lean_dec(x_3); +return x_250; +} +else { lean_object* x_251; -x_251 = lean_ctor_get(x_249, 0); -lean_dec(x_251); -lean_ctor_set_tag(x_249, 1); -lean_ctor_set(x_249, 0, x_245); -return x_249; +lean_inc(x_6); +x_251 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_247); +return x_251; } -else +} +case 5: +{ +if (lean_obj_tag(x_9) == 5) { lean_object* x_252; lean_object* x_253; -x_252 = lean_ctor_get(x_249, 1); -lean_inc(x_252); -lean_dec(x_249); -x_253 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_253, 0, x_245); -lean_ctor_set(x_253, 1, x_252); -return x_253; -} -} -else +x_252 = l_Lean_Expr_getAppFn___main(x_6); +lean_inc(x_3); +lean_inc(x_9); +lean_inc(x_6); +x_253 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1(x_6, x_9, x_252, x_3, x_247); +if (lean_obj_tag(x_253) == 0) { -uint8_t x_254; -lean_dec(x_245); -x_254 = !lean_is_exclusive(x_249); -if (x_254 == 0) +lean_object* x_254; uint8_t x_255; +x_254 = lean_ctor_get(x_253, 0); +lean_inc(x_254); +x_255 = lean_unbox(x_254); +if (x_255 == 0) { -return x_249; -} -else -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; -x_255 = lean_ctor_get(x_249, 0); -x_256 = lean_ctor_get(x_249, 1); +lean_object* x_256; lean_object* x_257; +lean_dec(x_254); +x_256 = lean_ctor_get(x_253, 1); lean_inc(x_256); -lean_inc(x_255); -lean_dec(x_249); -x_257 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_257, 0, x_255); -lean_ctor_set(x_257, 1, x_256); +lean_dec(x_253); +lean_inc(x_6); +x_257 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_256); return x_257; } -} -} -} else { uint8_t x_258; -lean_dec(x_61); -lean_dec(x_60); -lean_dec(x_59); -lean_dec(x_24); +lean_dec(x_9); lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_258 = !lean_is_exclusive(x_222); +x_258 = !lean_is_exclusive(x_253); if (x_258 == 0) { -return x_222; +lean_object* x_259; +x_259 = lean_ctor_get(x_253, 0); +lean_dec(x_259); +return x_253; } else { -lean_object* x_259; lean_object* x_260; lean_object* x_261; -x_259 = lean_ctor_get(x_222, 0); -x_260 = lean_ctor_get(x_222, 1); +lean_object* x_260; lean_object* x_261; +x_260 = lean_ctor_get(x_253, 1); lean_inc(x_260); -lean_inc(x_259); -lean_dec(x_222); -x_261 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_261, 0, x_259); +lean_dec(x_253); +x_261 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_261, 0, x_254); lean_ctor_set(x_261, 1, x_260); return x_261; } } } -} -} -} -} else { -uint8_t x_506; -lean_free_object(x_25); -lean_dec(x_27); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_506 = !lean_is_exclusive(x_29); -if (x_506 == 0) -{ -return x_29; -} -else -{ -lean_object* x_507; lean_object* x_508; lean_object* x_509; -x_507 = lean_ctor_get(x_29, 0); -x_508 = lean_ctor_get(x_29, 1); -lean_inc(x_508); -lean_inc(x_507); -lean_dec(x_29); -x_509 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_509, 0, x_507); -lean_ctor_set(x_509, 1, x_508); -return x_509; -} -} -} -else -{ -lean_object* x_510; lean_object* x_511; lean_object* x_512; -x_510 = lean_ctor_get(x_25, 0); -x_511 = lean_ctor_get(x_25, 1); -lean_inc(x_511); -lean_inc(x_510); -lean_dec(x_25); -x_512 = l___private_Init_Lean_Meta_ExprDefEq_17__isDeltaCandidate(x_9, x_6, x_511); +uint8_t x_262; lean_dec(x_9); -if (lean_obj_tag(x_512) == 0) -{ -if (lean_obj_tag(x_510) == 0) -{ -lean_object* x_513; -lean_dec(x_24); -x_513 = lean_ctor_get(x_512, 0); -lean_inc(x_513); -if (lean_obj_tag(x_513) == 0) -{ -lean_object* x_514; lean_object* x_515; uint8_t x_516; lean_object* x_517; lean_object* x_518; lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_514 = lean_ctor_get(x_512, 1); -lean_inc(x_514); -if (lean_is_exclusive(x_512)) { - lean_ctor_release(x_512, 0); - lean_ctor_release(x_512, 1); - x_515 = x_512; -} else { - lean_dec_ref(x_512); - x_515 = lean_box(0); -} -x_516 = 2; -x_517 = lean_box(x_516); -if (lean_is_scalar(x_515)) { - x_518 = lean_alloc_ctor(0, 2, 0); -} else { - x_518 = x_515; -} -lean_ctor_set(x_518, 0, x_517); -lean_ctor_set(x_518, 1, x_514); -return x_518; +x_262 = !lean_is_exclusive(x_253); +if (x_262 == 0) +{ +return x_253; } else { -lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; lean_object* x_523; lean_object* x_524; lean_object* x_525; lean_object* x_526; lean_object* x_527; -x_519 = lean_ctor_get(x_512, 1); -lean_inc(x_519); -lean_dec(x_512); -x_520 = lean_ctor_get(x_513, 0); -lean_inc(x_520); -lean_dec(x_513); -x_521 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_522 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_523 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_2); -x_524 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___boxed), 9, 6); -lean_closure_set(x_524, 0, x_2); -lean_closure_set(x_524, 1, x_4); -lean_closure_set(x_524, 2, x_520); -lean_closure_set(x_524, 3, x_521); -lean_closure_set(x_524, 4, x_522); -lean_closure_set(x_524, 5, x_523); -lean_inc(x_1); -x_525 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_525, 0, x_1); -x_526 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -x_527 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_525, x_2, x_3, x_5, x_526, x_524, x_6, x_519); -return x_527; -} -} -else -{ -lean_object* x_528; -x_528 = lean_ctor_get(x_512, 0); -lean_inc(x_528); -if (lean_obj_tag(x_528) == 0) -{ -lean_object* x_529; lean_object* x_530; lean_object* x_531; lean_object* x_532; lean_object* x_533; lean_object* x_534; lean_object* x_535; lean_object* x_536; lean_object* x_537; -lean_dec(x_24); -x_529 = lean_ctor_get(x_512, 1); -lean_inc(x_529); -lean_dec(x_512); -x_530 = lean_ctor_get(x_510, 0); -lean_inc(x_530); -lean_dec(x_510); -x_531 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_532 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_533 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_2); -x_534 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___boxed), 9, 6); -lean_closure_set(x_534, 0, x_2); -lean_closure_set(x_534, 1, x_5); -lean_closure_set(x_534, 2, x_530); -lean_closure_set(x_534, 3, x_531); -lean_closure_set(x_534, 4, x_532); -lean_closure_set(x_534, 5, x_533); -lean_inc(x_1); -x_535 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_535, 0, x_1); -x_536 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -x_537 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_535, x_2, x_3, x_4, x_536, x_534, x_6, x_529); -return x_537; -} -else -{ -lean_object* x_538; lean_object* x_539; lean_object* x_540; lean_object* x_541; uint8_t x_542; lean_object* x_543; uint8_t x_557; lean_object* x_558; lean_object* x_645; lean_object* x_646; uint8_t x_647; -x_538 = lean_ctor_get(x_512, 1); -lean_inc(x_538); -if (lean_is_exclusive(x_512)) { - lean_ctor_release(x_512, 0); - lean_ctor_release(x_512, 1); - x_539 = x_512; -} else { - lean_dec_ref(x_512); - x_539 = lean_box(0); -} -x_540 = lean_ctor_get(x_510, 0); -lean_inc(x_540); -lean_dec(x_510); -x_541 = lean_ctor_get(x_528, 0); -lean_inc(x_541); -lean_dec(x_528); -x_645 = l_Lean_ConstantInfo_name(x_540); -x_646 = l_Lean_ConstantInfo_name(x_541); -x_647 = lean_name_eq(x_645, x_646); -if (x_647 == 0) -{ -lean_object* x_648; uint8_t x_649; uint8_t x_650; uint8_t x_651; lean_object* x_652; -lean_dec(x_539); -lean_dec(x_24); -x_648 = lean_ctor_get(x_6, 0); -lean_inc(x_648); -x_649 = lean_ctor_get_uint8(x_648, sizeof(void*)*1 + 4); -lean_dec(x_648); -x_650 = 2; -x_651 = l_Lean_Meta_TransparencyMode_beq(x_649, x_650); -if (x_651 == 0) -{ -lean_object* x_663; uint8_t x_664; lean_object* x_665; lean_object* x_677; lean_object* x_690; uint8_t x_730; lean_object* x_731; -x_663 = lean_ctor_get(x_538, 0); -lean_inc(x_663); -lean_inc(x_645); -lean_inc(x_663); -x_664 = l_Lean_isReducible(x_663, x_645); -lean_inc(x_646); -x_730 = l_Lean_isReducible(x_663, x_646); -if (x_664 == 0) -{ -lean_object* x_768; -x_768 = lean_box(0); -x_731 = x_768; -goto block_767; -} -else -{ -if (x_730 == 0) -{ -uint8_t x_769; lean_object* x_770; lean_object* x_771; lean_object* x_772; lean_object* x_773; lean_object* x_774; lean_object* x_775; -x_769 = l_Lean_Expr_hasExprMVar(x_4); -x_770 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_771 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_772 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_645); -lean_inc(x_5); -lean_inc(x_2); -x_773 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_773, 0, x_2); -lean_closure_set(x_773, 1, x_5); -lean_closure_set(x_773, 2, x_770); -lean_closure_set(x_773, 3, x_771); -lean_closure_set(x_773, 4, x_645); -lean_closure_set(x_773, 5, x_772); -lean_inc(x_1); -x_774 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_774, 0, x_1); -if (x_769 == 0) -{ -uint8_t x_783; -x_783 = l_Lean_Expr_hasExprMVar(x_5); -if (x_783 == 0) -{ -lean_object* x_784; lean_object* x_785; uint8_t x_786; -x_784 = l_Lean_ConstantInfo_hints(x_540); -lean_dec(x_540); -x_785 = l_Lean_ConstantInfo_hints(x_541); -lean_dec(x_541); -x_786 = l_Lean_ReducibilityHints_lt(x_784, x_785); -if (x_786 == 0) -{ -uint8_t x_787; -x_787 = l_Lean_ReducibilityHints_lt(x_785, x_784); -lean_dec(x_784); -lean_dec(x_785); -if (x_787 == 0) -{ -lean_object* x_788; lean_object* x_789; lean_object* x_790; lean_object* x_791; lean_object* x_792; lean_object* x_793; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_788 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_788, 0, x_2); -lean_closure_set(x_788, 1, x_4); -lean_closure_set(x_788, 2, x_770); -lean_closure_set(x_788, 3, x_771); -lean_closure_set(x_788, 4, x_646); -lean_closure_set(x_788, 5, x_772); -x_789 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_790 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_790, 0, x_1); -lean_closure_set(x_790, 1, x_774); -lean_closure_set(x_790, 2, x_2); -lean_closure_set(x_790, 3, x_3); -lean_closure_set(x_790, 4, x_5); -lean_closure_set(x_790, 5, x_789); -lean_closure_set(x_790, 6, x_788); -lean_inc(x_3); -lean_inc(x_774); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_791 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_791, 0, x_5); -lean_closure_set(x_791, 1, x_770); -lean_closure_set(x_791, 2, x_771); -lean_closure_set(x_791, 3, x_23); -lean_closure_set(x_791, 4, x_645); -lean_closure_set(x_791, 5, x_772); -lean_closure_set(x_791, 6, x_2); -lean_closure_set(x_791, 7, x_4); -lean_closure_set(x_791, 8, x_646); -lean_closure_set(x_791, 9, x_1); -lean_closure_set(x_791, 10, x_774); -lean_closure_set(x_791, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_792 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_792, 0, x_1); -lean_closure_set(x_792, 1, x_774); -lean_closure_set(x_792, 2, x_2); -lean_closure_set(x_792, 3, x_3); -lean_closure_set(x_792, 4, x_4); -lean_closure_set(x_792, 5, x_790); -lean_closure_set(x_792, 6, x_791); -x_793 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_774, x_2, x_3, x_4, x_792, x_773, x_6, x_538); -return x_793; -} -else -{ -lean_object* x_794; lean_object* x_795; lean_object* x_796; lean_object* x_797; lean_object* x_798; lean_object* x_799; lean_object* x_800; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_794 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_794, 0, x_2); -lean_closure_set(x_794, 1, x_4); -lean_closure_set(x_794, 2, x_770); -lean_closure_set(x_794, 3, x_771); -lean_closure_set(x_794, 4, x_646); -lean_closure_set(x_794, 5, x_772); -x_795 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_794); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_796 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_796, 0, x_1); -lean_closure_set(x_796, 1, x_774); -lean_closure_set(x_796, 2, x_2); -lean_closure_set(x_796, 3, x_3); -lean_closure_set(x_796, 4, x_5); -lean_closure_set(x_796, 5, x_795); -lean_closure_set(x_796, 6, x_794); -lean_inc(x_3); -lean_inc(x_774); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_797 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_797, 0, x_5); -lean_closure_set(x_797, 1, x_770); -lean_closure_set(x_797, 2, x_771); -lean_closure_set(x_797, 3, x_23); -lean_closure_set(x_797, 4, x_645); -lean_closure_set(x_797, 5, x_772); -lean_closure_set(x_797, 6, x_2); -lean_closure_set(x_797, 7, x_4); -lean_closure_set(x_797, 8, x_646); -lean_closure_set(x_797, 9, x_1); -lean_closure_set(x_797, 10, x_774); -lean_closure_set(x_797, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_798 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_798, 0, x_1); -lean_closure_set(x_798, 1, x_774); -lean_closure_set(x_798, 2, x_2); -lean_closure_set(x_798, 3, x_3); -lean_closure_set(x_798, 4, x_4); -lean_closure_set(x_798, 5, x_796); -lean_closure_set(x_798, 6, x_797); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_799 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_799, 0, x_1); -lean_closure_set(x_799, 1, x_774); -lean_closure_set(x_799, 2, x_2); -lean_closure_set(x_799, 3, x_3); -lean_closure_set(x_799, 4, x_5); -lean_closure_set(x_799, 5, x_798); -lean_closure_set(x_799, 6, x_794); -x_800 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_774, x_2, x_3, x_4, x_799, x_773, x_6, x_538); -return x_800; -} -} -else -{ -lean_object* x_801; lean_object* x_802; lean_object* x_803; lean_object* x_804; lean_object* x_805; lean_object* x_806; lean_object* x_807; -lean_dec(x_785); -lean_dec(x_784); -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_801 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_801, 0, x_2); -lean_closure_set(x_801, 1, x_4); -lean_closure_set(x_801, 2, x_770); -lean_closure_set(x_801, 3, x_771); -lean_closure_set(x_801, 4, x_646); -lean_closure_set(x_801, 5, x_772); -x_802 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_803 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_803, 0, x_1); -lean_closure_set(x_803, 1, x_774); -lean_closure_set(x_803, 2, x_2); -lean_closure_set(x_803, 3, x_3); -lean_closure_set(x_803, 4, x_5); -lean_closure_set(x_803, 5, x_802); -lean_closure_set(x_803, 6, x_801); -lean_inc(x_3); -lean_inc(x_774); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_804 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_804, 0, x_5); -lean_closure_set(x_804, 1, x_770); -lean_closure_set(x_804, 2, x_771); -lean_closure_set(x_804, 3, x_23); -lean_closure_set(x_804, 4, x_645); -lean_closure_set(x_804, 5, x_772); -lean_closure_set(x_804, 6, x_2); -lean_closure_set(x_804, 7, x_4); -lean_closure_set(x_804, 8, x_646); -lean_closure_set(x_804, 9, x_1); -lean_closure_set(x_804, 10, x_774); -lean_closure_set(x_804, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_805 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_805, 0, x_1); -lean_closure_set(x_805, 1, x_774); -lean_closure_set(x_805, 2, x_2); -lean_closure_set(x_805, 3, x_3); -lean_closure_set(x_805, 4, x_4); -lean_closure_set(x_805, 5, x_803); -lean_closure_set(x_805, 6, x_804); -lean_inc(x_773); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_806 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_806, 0, x_1); -lean_closure_set(x_806, 1, x_774); -lean_closure_set(x_806, 2, x_2); -lean_closure_set(x_806, 3, x_3); -lean_closure_set(x_806, 4, x_4); -lean_closure_set(x_806, 5, x_805); -lean_closure_set(x_806, 6, x_773); -x_807 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_774, x_2, x_3, x_4, x_806, x_773, x_6, x_538); -return x_807; -} -} -else -{ -lean_object* x_808; -lean_dec(x_541); -lean_dec(x_540); -x_808 = lean_box(0); -x_775 = x_808; -goto block_782; -} -} -else -{ -lean_object* x_809; -lean_dec(x_541); -lean_dec(x_540); -x_809 = lean_box(0); -x_775 = x_809; -goto block_782; -} -block_782: -{ -lean_object* x_776; lean_object* x_777; lean_object* x_778; lean_object* x_779; lean_object* x_780; lean_object* x_781; -lean_dec(x_775); -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_776 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_776, 0, x_2); -lean_closure_set(x_776, 1, x_4); -lean_closure_set(x_776, 2, x_770); -lean_closure_set(x_776, 3, x_771); -lean_closure_set(x_776, 4, x_646); -lean_closure_set(x_776, 5, x_772); -x_777 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_778 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_778, 0, x_1); -lean_closure_set(x_778, 1, x_774); -lean_closure_set(x_778, 2, x_2); -lean_closure_set(x_778, 3, x_3); -lean_closure_set(x_778, 4, x_5); -lean_closure_set(x_778, 5, x_777); -lean_closure_set(x_778, 6, x_776); -lean_inc(x_3); -lean_inc(x_774); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_779 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_779, 0, x_5); -lean_closure_set(x_779, 1, x_770); -lean_closure_set(x_779, 2, x_771); -lean_closure_set(x_779, 3, x_23); -lean_closure_set(x_779, 4, x_645); -lean_closure_set(x_779, 5, x_772); -lean_closure_set(x_779, 6, x_2); -lean_closure_set(x_779, 7, x_4); -lean_closure_set(x_779, 8, x_646); -lean_closure_set(x_779, 9, x_1); -lean_closure_set(x_779, 10, x_774); -lean_closure_set(x_779, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_774); -lean_inc(x_1); -x_780 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_780, 0, x_1); -lean_closure_set(x_780, 1, x_774); -lean_closure_set(x_780, 2, x_2); -lean_closure_set(x_780, 3, x_3); -lean_closure_set(x_780, 4, x_4); -lean_closure_set(x_780, 5, x_778); -lean_closure_set(x_780, 6, x_779); -x_781 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_774, x_2, x_3, x_4, x_780, x_773, x_6, x_538); -return x_781; -} -} -else -{ -lean_object* x_810; -x_810 = lean_box(0); -x_731 = x_810; -goto block_767; -} -} -block_676: -{ -lean_object* x_666; lean_object* x_667; lean_object* x_668; lean_object* x_669; lean_object* x_670; lean_object* x_671; lean_object* x_672; lean_object* x_673; lean_object* x_674; lean_object* x_675; -lean_dec(x_665); -x_666 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_667 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_668 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_669 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_669, 0, x_2); -lean_closure_set(x_669, 1, x_4); -lean_closure_set(x_669, 2, x_666); -lean_closure_set(x_669, 3, x_667); -lean_closure_set(x_669, 4, x_646); -lean_closure_set(x_669, 5, x_668); -lean_inc(x_1); -x_670 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_670, 0, x_1); -x_671 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_669); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_670); -lean_inc(x_1); -x_672 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_672, 0, x_1); -lean_closure_set(x_672, 1, x_670); -lean_closure_set(x_672, 2, x_2); -lean_closure_set(x_672, 3, x_3); -lean_closure_set(x_672, 4, x_5); -lean_closure_set(x_672, 5, x_671); -lean_closure_set(x_672, 6, x_669); -lean_inc(x_3); -lean_inc(x_670); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_673 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_673, 0, x_5); -lean_closure_set(x_673, 1, x_666); -lean_closure_set(x_673, 2, x_667); -lean_closure_set(x_673, 3, x_23); -lean_closure_set(x_673, 4, x_645); -lean_closure_set(x_673, 5, x_668); -lean_closure_set(x_673, 6, x_2); -lean_closure_set(x_673, 7, x_4); -lean_closure_set(x_673, 8, x_646); -lean_closure_set(x_673, 9, x_1); -lean_closure_set(x_673, 10, x_670); -lean_closure_set(x_673, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_670); -lean_inc(x_1); -x_674 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_674, 0, x_1); -lean_closure_set(x_674, 1, x_670); -lean_closure_set(x_674, 2, x_2); -lean_closure_set(x_674, 3, x_3); -lean_closure_set(x_674, 4, x_4); -lean_closure_set(x_674, 5, x_672); -lean_closure_set(x_674, 6, x_673); -x_675 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_670, x_2, x_3, x_5, x_674, x_669, x_6, x_538); -return x_675; -} -block_689: -{ -lean_object* x_678; lean_object* x_679; lean_object* x_680; lean_object* x_681; lean_object* x_682; lean_object* x_683; lean_object* x_684; lean_object* x_685; lean_object* x_686; lean_object* x_687; lean_object* x_688; -lean_dec(x_677); -x_678 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_679 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_680 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_681 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_681, 0, x_2); -lean_closure_set(x_681, 1, x_4); -lean_closure_set(x_681, 2, x_678); -lean_closure_set(x_681, 3, x_679); -lean_closure_set(x_681, 4, x_646); -lean_closure_set(x_681, 5, x_680); -lean_inc(x_1); -x_682 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_682, 0, x_1); -x_683 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_682); -lean_inc(x_1); -x_684 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_684, 0, x_1); -lean_closure_set(x_684, 1, x_682); -lean_closure_set(x_684, 2, x_2); -lean_closure_set(x_684, 3, x_3); -lean_closure_set(x_684, 4, x_5); -lean_closure_set(x_684, 5, x_683); -lean_closure_set(x_684, 6, x_681); -lean_inc(x_3); -lean_inc(x_682); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_645); -lean_inc(x_5); -x_685 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_685, 0, x_5); -lean_closure_set(x_685, 1, x_678); -lean_closure_set(x_685, 2, x_679); -lean_closure_set(x_685, 3, x_23); -lean_closure_set(x_685, 4, x_645); -lean_closure_set(x_685, 5, x_680); -lean_closure_set(x_685, 6, x_2); -lean_closure_set(x_685, 7, x_4); -lean_closure_set(x_685, 8, x_646); -lean_closure_set(x_685, 9, x_1); -lean_closure_set(x_685, 10, x_682); -lean_closure_set(x_685, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_682); -lean_inc(x_1); -x_686 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_686, 0, x_1); -lean_closure_set(x_686, 1, x_682); -lean_closure_set(x_686, 2, x_2); -lean_closure_set(x_686, 3, x_3); -lean_closure_set(x_686, 4, x_4); -lean_closure_set(x_686, 5, x_684); -lean_closure_set(x_686, 6, x_685); -lean_inc(x_2); -x_687 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_687, 0, x_2); -lean_closure_set(x_687, 1, x_5); -lean_closure_set(x_687, 2, x_678); -lean_closure_set(x_687, 3, x_679); -lean_closure_set(x_687, 4, x_645); -lean_closure_set(x_687, 5, x_680); -x_688 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_682, x_2, x_3, x_4, x_686, x_687, x_6, x_538); -return x_688; -} -block_729: -{ -uint8_t x_691; lean_object* x_692; lean_object* x_693; lean_object* x_694; lean_object* x_695; lean_object* x_696; lean_object* x_697; -lean_dec(x_690); -x_691 = l_Lean_Expr_hasExprMVar(x_4); -x_692 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_693 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_694 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_695 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_695, 0, x_2); -lean_closure_set(x_695, 1, x_4); -lean_closure_set(x_695, 2, x_692); -lean_closure_set(x_695, 3, x_693); -lean_closure_set(x_695, 4, x_646); -lean_closure_set(x_695, 5, x_694); -lean_inc(x_1); -x_696 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_696, 0, x_1); -if (x_691 == 0) -{ -uint8_t x_704; -x_704 = l_Lean_Expr_hasExprMVar(x_5); -if (x_704 == 0) -{ -lean_object* x_705; lean_object* x_706; uint8_t x_707; -x_705 = l_Lean_ConstantInfo_hints(x_540); -lean_dec(x_540); -x_706 = l_Lean_ConstantInfo_hints(x_541); -lean_dec(x_541); -x_707 = l_Lean_ReducibilityHints_lt(x_705, x_706); -if (x_707 == 0) -{ -uint8_t x_708; -x_708 = l_Lean_ReducibilityHints_lt(x_706, x_705); -lean_dec(x_705); -lean_dec(x_706); -if (x_708 == 0) -{ -lean_object* x_709; lean_object* x_710; lean_object* x_711; lean_object* x_712; lean_object* x_713; -x_709 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_695); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_710 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_710, 0, x_1); -lean_closure_set(x_710, 1, x_696); -lean_closure_set(x_710, 2, x_2); -lean_closure_set(x_710, 3, x_3); -lean_closure_set(x_710, 4, x_5); -lean_closure_set(x_710, 5, x_709); -lean_closure_set(x_710, 6, x_695); -lean_inc(x_3); -lean_inc(x_696); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_711 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_711, 0, x_5); -lean_closure_set(x_711, 1, x_692); -lean_closure_set(x_711, 2, x_693); -lean_closure_set(x_711, 3, x_23); -lean_closure_set(x_711, 4, x_645); -lean_closure_set(x_711, 5, x_694); -lean_closure_set(x_711, 6, x_2); -lean_closure_set(x_711, 7, x_4); -lean_closure_set(x_711, 8, x_646); -lean_closure_set(x_711, 9, x_1); -lean_closure_set(x_711, 10, x_696); -lean_closure_set(x_711, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_712 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_712, 0, x_1); -lean_closure_set(x_712, 1, x_696); -lean_closure_set(x_712, 2, x_2); -lean_closure_set(x_712, 3, x_3); -lean_closure_set(x_712, 4, x_4); -lean_closure_set(x_712, 5, x_710); -lean_closure_set(x_712, 6, x_711); -x_713 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_696, x_2, x_3, x_5, x_712, x_695, x_6, x_538); -return x_713; -} -else -{ -lean_object* x_714; lean_object* x_715; lean_object* x_716; lean_object* x_717; lean_object* x_718; lean_object* x_719; -x_714 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_695); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_715 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_715, 0, x_1); -lean_closure_set(x_715, 1, x_696); -lean_closure_set(x_715, 2, x_2); -lean_closure_set(x_715, 3, x_3); -lean_closure_set(x_715, 4, x_5); -lean_closure_set(x_715, 5, x_714); -lean_closure_set(x_715, 6, x_695); -lean_inc(x_3); -lean_inc(x_696); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_716 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_716, 0, x_5); -lean_closure_set(x_716, 1, x_692); -lean_closure_set(x_716, 2, x_693); -lean_closure_set(x_716, 3, x_23); -lean_closure_set(x_716, 4, x_645); -lean_closure_set(x_716, 5, x_694); -lean_closure_set(x_716, 6, x_2); -lean_closure_set(x_716, 7, x_4); -lean_closure_set(x_716, 8, x_646); -lean_closure_set(x_716, 9, x_1); -lean_closure_set(x_716, 10, x_696); -lean_closure_set(x_716, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_717 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_717, 0, x_1); -lean_closure_set(x_717, 1, x_696); -lean_closure_set(x_717, 2, x_2); -lean_closure_set(x_717, 3, x_3); -lean_closure_set(x_717, 4, x_4); -lean_closure_set(x_717, 5, x_715); -lean_closure_set(x_717, 6, x_716); -lean_inc(x_695); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_718 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_718, 0, x_1); -lean_closure_set(x_718, 1, x_696); -lean_closure_set(x_718, 2, x_2); -lean_closure_set(x_718, 3, x_3); -lean_closure_set(x_718, 4, x_5); -lean_closure_set(x_718, 5, x_717); -lean_closure_set(x_718, 6, x_695); -x_719 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_696, x_2, x_3, x_5, x_718, x_695, x_6, x_538); -return x_719; -} -} -else -{ -lean_object* x_720; lean_object* x_721; lean_object* x_722; lean_object* x_723; lean_object* x_724; lean_object* x_725; lean_object* x_726; -lean_dec(x_706); -lean_dec(x_705); -x_720 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_695); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_721 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_721, 0, x_1); -lean_closure_set(x_721, 1, x_696); -lean_closure_set(x_721, 2, x_2); -lean_closure_set(x_721, 3, x_3); -lean_closure_set(x_721, 4, x_5); -lean_closure_set(x_721, 5, x_720); -lean_closure_set(x_721, 6, x_695); -lean_inc(x_3); -lean_inc(x_696); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_645); -lean_inc(x_5); -x_722 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_722, 0, x_5); -lean_closure_set(x_722, 1, x_692); -lean_closure_set(x_722, 2, x_693); -lean_closure_set(x_722, 3, x_23); -lean_closure_set(x_722, 4, x_645); -lean_closure_set(x_722, 5, x_694); -lean_closure_set(x_722, 6, x_2); -lean_closure_set(x_722, 7, x_4); -lean_closure_set(x_722, 8, x_646); -lean_closure_set(x_722, 9, x_1); -lean_closure_set(x_722, 10, x_696); -lean_closure_set(x_722, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_723 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_723, 0, x_1); -lean_closure_set(x_723, 1, x_696); -lean_closure_set(x_723, 2, x_2); -lean_closure_set(x_723, 3, x_3); -lean_closure_set(x_723, 4, x_4); -lean_closure_set(x_723, 5, x_721); -lean_closure_set(x_723, 6, x_722); -lean_inc(x_5); -lean_inc(x_2); -x_724 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_724, 0, x_2); -lean_closure_set(x_724, 1, x_5); -lean_closure_set(x_724, 2, x_692); -lean_closure_set(x_724, 3, x_693); -lean_closure_set(x_724, 4, x_645); -lean_closure_set(x_724, 5, x_694); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_725 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_725, 0, x_1); -lean_closure_set(x_725, 1, x_696); -lean_closure_set(x_725, 2, x_2); -lean_closure_set(x_725, 3, x_3); -lean_closure_set(x_725, 4, x_4); -lean_closure_set(x_725, 5, x_723); -lean_closure_set(x_725, 6, x_724); -x_726 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_696, x_2, x_3, x_5, x_725, x_695, x_6, x_538); -return x_726; -} -} -else -{ -lean_object* x_727; -lean_dec(x_541); -lean_dec(x_540); -x_727 = lean_box(0); -x_697 = x_727; -goto block_703; -} -} -else -{ -lean_object* x_728; -lean_dec(x_541); -lean_dec(x_540); -x_728 = lean_box(0); -x_697 = x_728; -goto block_703; -} -block_703: -{ -lean_object* x_698; lean_object* x_699; lean_object* x_700; lean_object* x_701; lean_object* x_702; -lean_dec(x_697); -x_698 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_695); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_699 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_699, 0, x_1); -lean_closure_set(x_699, 1, x_696); -lean_closure_set(x_699, 2, x_2); -lean_closure_set(x_699, 3, x_3); -lean_closure_set(x_699, 4, x_5); -lean_closure_set(x_699, 5, x_698); -lean_closure_set(x_699, 6, x_695); -lean_inc(x_3); -lean_inc(x_696); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_700 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_700, 0, x_5); -lean_closure_set(x_700, 1, x_692); -lean_closure_set(x_700, 2, x_693); -lean_closure_set(x_700, 3, x_23); -lean_closure_set(x_700, 4, x_645); -lean_closure_set(x_700, 5, x_694); -lean_closure_set(x_700, 6, x_2); -lean_closure_set(x_700, 7, x_4); -lean_closure_set(x_700, 8, x_646); -lean_closure_set(x_700, 9, x_1); -lean_closure_set(x_700, 10, x_696); -lean_closure_set(x_700, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_696); -lean_inc(x_1); -x_701 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_701, 0, x_1); -lean_closure_set(x_701, 1, x_696); -lean_closure_set(x_701, 2, x_2); -lean_closure_set(x_701, 3, x_3); -lean_closure_set(x_701, 4, x_4); -lean_closure_set(x_701, 5, x_699); -lean_closure_set(x_701, 6, x_700); -x_702 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_696, x_2, x_3, x_5, x_701, x_695, x_6, x_538); -return x_702; -} -} -block_767: -{ -lean_dec(x_731); -if (x_664 == 0) -{ -if (x_730 == 0) -{ -uint8_t x_732; -x_732 = l_Lean_Expr_hasExprMVar(x_4); -if (x_732 == 0) -{ -uint8_t x_733; -x_733 = l_Lean_Expr_hasExprMVar(x_5); -if (x_733 == 0) -{ -lean_object* x_734; lean_object* x_735; uint8_t x_736; -x_734 = l_Lean_ConstantInfo_hints(x_540); -lean_dec(x_540); -x_735 = l_Lean_ConstantInfo_hints(x_541); -lean_dec(x_541); -x_736 = l_Lean_ReducibilityHints_lt(x_734, x_735); -if (x_736 == 0) -{ -uint8_t x_737; -x_737 = l_Lean_ReducibilityHints_lt(x_735, x_734); -lean_dec(x_734); -lean_dec(x_735); -if (x_737 == 0) -{ -lean_object* x_738; -x_738 = lean_box(0); -x_652 = x_738; -goto block_662; -} -else -{ -lean_object* x_739; -x_739 = lean_box(0); -x_665 = x_739; -goto block_676; -} -} -else -{ -lean_object* x_740; -lean_dec(x_735); -lean_dec(x_734); -x_740 = lean_box(0); -x_677 = x_740; -goto block_689; -} -} -else -{ -lean_object* x_741; -lean_dec(x_541); -lean_dec(x_540); -x_741 = lean_box(0); -x_652 = x_741; -goto block_662; -} -} -else -{ -lean_object* x_742; -lean_dec(x_541); -lean_dec(x_540); -x_742 = lean_box(0); -x_652 = x_742; -goto block_662; -} -} -else -{ -lean_object* x_743; -x_743 = lean_box(0); -x_690 = x_743; -goto block_729; -} -} -else -{ -if (x_651 == 0) -{ -uint8_t x_744; -x_744 = l_Lean_Expr_hasExprMVar(x_4); -if (x_744 == 0) -{ -uint8_t x_745; -x_745 = l_Lean_Expr_hasExprMVar(x_5); -if (x_745 == 0) -{ -lean_object* x_746; lean_object* x_747; uint8_t x_748; -x_746 = l_Lean_ConstantInfo_hints(x_540); -lean_dec(x_540); -x_747 = l_Lean_ConstantInfo_hints(x_541); -lean_dec(x_541); -x_748 = l_Lean_ReducibilityHints_lt(x_746, x_747); -if (x_748 == 0) -{ -uint8_t x_749; -x_749 = l_Lean_ReducibilityHints_lt(x_747, x_746); -lean_dec(x_746); -lean_dec(x_747); -if (x_749 == 0) -{ -lean_object* x_750; -x_750 = lean_box(0); -x_652 = x_750; -goto block_662; -} -else -{ -lean_object* x_751; -x_751 = lean_box(0); -x_665 = x_751; -goto block_676; -} -} -else -{ -lean_object* x_752; -lean_dec(x_747); -lean_dec(x_746); -x_752 = lean_box(0); -x_677 = x_752; -goto block_689; -} -} -else -{ -lean_object* x_753; -lean_dec(x_541); -lean_dec(x_540); -x_753 = lean_box(0); -x_652 = x_753; -goto block_662; -} -} -else -{ -lean_object* x_754; -lean_dec(x_541); -lean_dec(x_540); -x_754 = lean_box(0); -x_652 = x_754; -goto block_662; -} -} -else -{ -if (x_730 == 0) -{ -uint8_t x_755; -x_755 = l_Lean_Expr_hasExprMVar(x_4); -if (x_755 == 0) -{ -uint8_t x_756; -x_756 = l_Lean_Expr_hasExprMVar(x_5); -if (x_756 == 0) -{ -lean_object* x_757; lean_object* x_758; uint8_t x_759; -x_757 = l_Lean_ConstantInfo_hints(x_540); -lean_dec(x_540); -x_758 = l_Lean_ConstantInfo_hints(x_541); -lean_dec(x_541); -x_759 = l_Lean_ReducibilityHints_lt(x_757, x_758); -if (x_759 == 0) -{ -uint8_t x_760; -x_760 = l_Lean_ReducibilityHints_lt(x_758, x_757); -lean_dec(x_757); -lean_dec(x_758); -if (x_760 == 0) -{ -lean_object* x_761; -x_761 = lean_box(0); -x_652 = x_761; -goto block_662; -} -else -{ -lean_object* x_762; -x_762 = lean_box(0); -x_665 = x_762; -goto block_676; -} -} -else -{ -lean_object* x_763; -lean_dec(x_758); -lean_dec(x_757); -x_763 = lean_box(0); -x_677 = x_763; -goto block_689; -} -} -else -{ -lean_object* x_764; -lean_dec(x_541); -lean_dec(x_540); -x_764 = lean_box(0); -x_652 = x_764; -goto block_662; -} -} -else -{ -lean_object* x_765; -lean_dec(x_541); -lean_dec(x_540); -x_765 = lean_box(0); -x_652 = x_765; -goto block_662; -} -} -else -{ -lean_object* x_766; -x_766 = lean_box(0); -x_690 = x_766; -goto block_729; -} -} +lean_object* x_263; lean_object* x_264; lean_object* x_265; +x_263 = lean_ctor_get(x_253, 0); +x_264 = lean_ctor_get(x_253, 1); +lean_inc(x_264); +lean_inc(x_263); +lean_dec(x_253); +x_265 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_265, 0, x_263); +lean_ctor_set(x_265, 1, x_264); +return x_265; } } } else { -uint8_t x_811; -x_811 = l_Lean_Expr_hasExprMVar(x_4); -if (x_811 == 0) -{ -uint8_t x_812; -x_812 = l_Lean_Expr_hasExprMVar(x_5); -if (x_812 == 0) -{ -lean_object* x_813; lean_object* x_814; uint8_t x_815; -x_813 = l_Lean_ConstantInfo_hints(x_540); -lean_dec(x_540); -x_814 = l_Lean_ConstantInfo_hints(x_541); -lean_dec(x_541); -x_815 = l_Lean_ReducibilityHints_lt(x_813, x_814); -if (x_815 == 0) -{ -uint8_t x_816; -x_816 = l_Lean_ReducibilityHints_lt(x_814, x_813); -lean_dec(x_813); -lean_dec(x_814); -if (x_816 == 0) -{ -lean_object* x_817; lean_object* x_818; lean_object* x_819; lean_object* x_820; lean_object* x_821; lean_object* x_822; lean_object* x_823; lean_object* x_824; lean_object* x_825; -x_817 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_818 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_819 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_820 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_820, 0, x_2); -lean_closure_set(x_820, 1, x_4); -lean_closure_set(x_820, 2, x_817); -lean_closure_set(x_820, 3, x_818); -lean_closure_set(x_820, 4, x_646); -lean_closure_set(x_820, 5, x_819); -lean_inc(x_1); -x_821 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_821, 0, x_1); -x_822 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_821); -lean_inc(x_1); -x_823 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_823, 0, x_1); -lean_closure_set(x_823, 1, x_821); -lean_closure_set(x_823, 2, x_2); -lean_closure_set(x_823, 3, x_3); -lean_closure_set(x_823, 4, x_5); -lean_closure_set(x_823, 5, x_822); -lean_closure_set(x_823, 6, x_820); -lean_inc(x_3); -lean_inc(x_821); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_824 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_824, 0, x_5); -lean_closure_set(x_824, 1, x_817); -lean_closure_set(x_824, 2, x_818); -lean_closure_set(x_824, 3, x_23); -lean_closure_set(x_824, 4, x_645); -lean_closure_set(x_824, 5, x_819); -lean_closure_set(x_824, 6, x_2); -lean_closure_set(x_824, 7, x_4); -lean_closure_set(x_824, 8, x_646); -lean_closure_set(x_824, 9, x_1); -lean_closure_set(x_824, 10, x_821); -lean_closure_set(x_824, 11, x_3); -x_825 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_821, x_2, x_3, x_4, x_823, x_824, x_6, x_538); -return x_825; -} -else -{ -lean_object* x_826; lean_object* x_827; lean_object* x_828; lean_object* x_829; lean_object* x_830; lean_object* x_831; lean_object* x_832; lean_object* x_833; lean_object* x_834; lean_object* x_835; -x_826 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_827 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_828 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_829 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_829, 0, x_2); -lean_closure_set(x_829, 1, x_4); -lean_closure_set(x_829, 2, x_826); -lean_closure_set(x_829, 3, x_827); -lean_closure_set(x_829, 4, x_646); -lean_closure_set(x_829, 5, x_828); -lean_inc(x_1); -x_830 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_830, 0, x_1); -x_831 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_829); -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_830); -lean_inc(x_1); -x_832 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_832, 0, x_1); -lean_closure_set(x_832, 1, x_830); -lean_closure_set(x_832, 2, x_2); -lean_closure_set(x_832, 3, x_3); -lean_closure_set(x_832, 4, x_5); -lean_closure_set(x_832, 5, x_831); -lean_closure_set(x_832, 6, x_829); -lean_inc(x_3); -lean_inc(x_830); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_5); -x_833 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_833, 0, x_5); -lean_closure_set(x_833, 1, x_826); -lean_closure_set(x_833, 2, x_827); -lean_closure_set(x_833, 3, x_23); -lean_closure_set(x_833, 4, x_645); -lean_closure_set(x_833, 5, x_828); -lean_closure_set(x_833, 6, x_2); -lean_closure_set(x_833, 7, x_4); -lean_closure_set(x_833, 8, x_646); -lean_closure_set(x_833, 9, x_1); -lean_closure_set(x_833, 10, x_830); -lean_closure_set(x_833, 11, x_3); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_830); -lean_inc(x_1); -x_834 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_834, 0, x_1); -lean_closure_set(x_834, 1, x_830); -lean_closure_set(x_834, 2, x_2); -lean_closure_set(x_834, 3, x_3); -lean_closure_set(x_834, 4, x_4); -lean_closure_set(x_834, 5, x_832); -lean_closure_set(x_834, 6, x_833); -x_835 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_830, x_2, x_3, x_5, x_834, x_829, x_6, x_538); -return x_835; -} -} -else -{ -lean_object* x_836; lean_object* x_837; lean_object* x_838; lean_object* x_839; lean_object* x_840; lean_object* x_841; lean_object* x_842; lean_object* x_843; lean_object* x_844; lean_object* x_845; lean_object* x_846; -lean_dec(x_814); -lean_dec(x_813); -x_836 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_837 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_838 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_839 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_839, 0, x_2); -lean_closure_set(x_839, 1, x_4); -lean_closure_set(x_839, 2, x_836); -lean_closure_set(x_839, 3, x_837); -lean_closure_set(x_839, 4, x_646); -lean_closure_set(x_839, 5, x_838); -lean_inc(x_1); -x_840 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_840, 0, x_1); -x_841 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_840); -lean_inc(x_1); -x_842 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_842, 0, x_1); -lean_closure_set(x_842, 1, x_840); -lean_closure_set(x_842, 2, x_2); -lean_closure_set(x_842, 3, x_3); -lean_closure_set(x_842, 4, x_5); -lean_closure_set(x_842, 5, x_841); -lean_closure_set(x_842, 6, x_839); -lean_inc(x_3); -lean_inc(x_840); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_645); -lean_inc(x_5); -x_843 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_843, 0, x_5); -lean_closure_set(x_843, 1, x_836); -lean_closure_set(x_843, 2, x_837); -lean_closure_set(x_843, 3, x_23); -lean_closure_set(x_843, 4, x_645); -lean_closure_set(x_843, 5, x_838); -lean_closure_set(x_843, 6, x_2); -lean_closure_set(x_843, 7, x_4); -lean_closure_set(x_843, 8, x_646); -lean_closure_set(x_843, 9, x_1); -lean_closure_set(x_843, 10, x_840); -lean_closure_set(x_843, 11, x_3); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_840); -lean_inc(x_1); -x_844 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_844, 0, x_1); -lean_closure_set(x_844, 1, x_840); -lean_closure_set(x_844, 2, x_2); -lean_closure_set(x_844, 3, x_3); -lean_closure_set(x_844, 4, x_4); -lean_closure_set(x_844, 5, x_842); -lean_closure_set(x_844, 6, x_843); -lean_inc(x_2); -x_845 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__12), 9, 6); -lean_closure_set(x_845, 0, x_2); -lean_closure_set(x_845, 1, x_5); -lean_closure_set(x_845, 2, x_836); -lean_closure_set(x_845, 3, x_837); -lean_closure_set(x_845, 4, x_645); -lean_closure_set(x_845, 5, x_838); -x_846 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_840, x_2, x_3, x_4, x_844, x_845, x_6, x_538); -return x_846; -} -} -else -{ -lean_object* x_847; -lean_dec(x_541); -lean_dec(x_540); -x_847 = lean_box(0); -x_652 = x_847; -goto block_662; -} -} -else -{ -lean_object* x_848; -lean_dec(x_541); -lean_dec(x_540); -x_848 = lean_box(0); -x_652 = x_848; -goto block_662; -} -} -block_662: -{ -lean_object* x_653; lean_object* x_654; lean_object* x_655; lean_object* x_656; lean_object* x_657; lean_object* x_658; lean_object* x_659; lean_object* x_660; lean_object* x_661; -lean_dec(x_652); -x_653 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_654 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_655 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_646); -lean_inc(x_4); -lean_inc(x_2); -x_656 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__9), 9, 6); -lean_closure_set(x_656, 0, x_2); -lean_closure_set(x_656, 1, x_4); -lean_closure_set(x_656, 2, x_653); -lean_closure_set(x_656, 3, x_654); -lean_closure_set(x_656, 4, x_646); -lean_closure_set(x_656, 5, x_655); -lean_inc(x_1); -x_657 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_657, 0, x_1); -x_658 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_657); -lean_inc(x_1); -x_659 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_659, 0, x_1); -lean_closure_set(x_659, 1, x_657); -lean_closure_set(x_659, 2, x_2); -lean_closure_set(x_659, 3, x_3); -lean_closure_set(x_659, 4, x_5); -lean_closure_set(x_659, 5, x_658); -lean_closure_set(x_659, 6, x_656); -lean_inc(x_3); -lean_inc(x_657); -lean_inc(x_1); -lean_inc(x_4); -lean_inc(x_2); -x_660 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__11), 15, 12); -lean_closure_set(x_660, 0, x_5); -lean_closure_set(x_660, 1, x_653); -lean_closure_set(x_660, 2, x_654); -lean_closure_set(x_660, 3, x_23); -lean_closure_set(x_660, 4, x_645); -lean_closure_set(x_660, 5, x_655); -lean_closure_set(x_660, 6, x_2); -lean_closure_set(x_660, 7, x_4); -lean_closure_set(x_660, 8, x_646); -lean_closure_set(x_660, 9, x_1); -lean_closure_set(x_660, 10, x_657); -lean_closure_set(x_660, 11, x_3); -x_661 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_657, x_2, x_3, x_4, x_659, x_660, x_6, x_538); -return x_661; -} -} -else -{ -lean_dec(x_646); -lean_dec(x_645); -switch (lean_obj_tag(x_4)) { -case 4: -{ -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_24); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -if (lean_obj_tag(x_5) == 4) -{ -lean_object* x_849; lean_object* x_850; lean_object* x_851; -x_849 = lean_ctor_get(x_4, 1); -lean_inc(x_849); -lean_dec(x_4); -x_850 = lean_ctor_get(x_5, 1); -lean_inc(x_850); -lean_dec(x_5); -x_851 = l_Lean_Meta_isListLevelDefEq___main(x_849, x_850, x_6, x_538); -if (lean_obj_tag(x_851) == 0) -{ -lean_object* x_852; lean_object* x_853; lean_object* x_854; uint8_t x_855; uint8_t x_856; lean_object* x_857; lean_object* x_858; -x_852 = lean_ctor_get(x_851, 0); -lean_inc(x_852); -x_853 = lean_ctor_get(x_851, 1); -lean_inc(x_853); -if (lean_is_exclusive(x_851)) { - lean_ctor_release(x_851, 0); - lean_ctor_release(x_851, 1); - x_854 = x_851; -} else { - lean_dec_ref(x_851); - x_854 = lean_box(0); -} -x_855 = lean_unbox(x_852); -lean_dec(x_852); -x_856 = l_Bool_toLBool(x_855); -x_857 = lean_box(x_856); -if (lean_is_scalar(x_854)) { - x_858 = lean_alloc_ctor(0, 2, 0); -} else { - x_858 = x_854; -} -lean_ctor_set(x_858, 0, x_857); -lean_ctor_set(x_858, 1, x_853); -return x_858; -} -else -{ -lean_object* x_859; lean_object* x_860; lean_object* x_861; lean_object* x_862; -x_859 = lean_ctor_get(x_851, 0); -lean_inc(x_859); -x_860 = lean_ctor_get(x_851, 1); -lean_inc(x_860); -if (lean_is_exclusive(x_851)) { - lean_ctor_release(x_851, 0); - lean_ctor_release(x_851, 1); - x_861 = x_851; -} else { - lean_dec_ref(x_851); - x_861 = lean_box(0); -} -if (lean_is_scalar(x_861)) { - x_862 = lean_alloc_ctor(1, 2, 0); -} else { - x_862 = x_861; -} -lean_ctor_set(x_862, 0, x_859); -lean_ctor_set(x_862, 1, x_860); -return x_862; -} -} -else -{ -uint8_t x_863; lean_object* x_864; lean_object* x_865; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -x_863 = 0; -x_864 = lean_box(x_863); -x_865 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_865, 0, x_864); -lean_ctor_set(x_865, 1, x_538); -return x_865; -} -} -case 5: -{ -if (lean_obj_tag(x_5) == 5) -{ -lean_object* x_866; uint8_t x_867; -x_866 = lean_ctor_get(x_538, 4); -lean_inc(x_866); -x_867 = lean_ctor_get_uint8(x_866, sizeof(void*)*1); -lean_dec(x_866); -if (x_867 == 0) -{ -uint8_t x_868; -x_868 = 0; -x_557 = x_868; -x_558 = x_538; -goto block_644; -} -else -{ -lean_object* x_869; lean_object* x_870; lean_object* x_871; lean_object* x_872; lean_object* x_873; -x_869 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_870 = l_Lean_Meta_tracer; -x_871 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__4; -x_872 = l___private_Init_Lean_Trace_5__checkTraceOption___rarg(x_869, x_870, x_871); +lean_object* x_266; lean_inc(x_6); -x_873 = lean_apply_2(x_872, x_6, x_538); -if (lean_obj_tag(x_873) == 0) -{ -lean_object* x_874; lean_object* x_875; uint8_t x_876; -x_874 = lean_ctor_get(x_873, 0); -lean_inc(x_874); -x_875 = lean_ctor_get(x_873, 1); -lean_inc(x_875); -lean_dec(x_873); -x_876 = lean_unbox(x_874); -lean_dec(x_874); -x_557 = x_876; -x_558 = x_875; -goto block_644; -} -else -{ -lean_object* x_877; lean_object* x_878; lean_object* x_879; lean_object* x_880; -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_877 = lean_ctor_get(x_873, 0); -lean_inc(x_877); -x_878 = lean_ctor_get(x_873, 1); -lean_inc(x_878); -if (lean_is_exclusive(x_873)) { - lean_ctor_release(x_873, 0); - lean_ctor_release(x_873, 1); - x_879 = x_873; -} else { - lean_dec_ref(x_873); - x_879 = lean_box(0); -} -if (lean_is_scalar(x_879)) { - x_880 = lean_alloc_ctor(1, 2, 0); -} else { - x_880 = x_879; -} -lean_ctor_set(x_880, 0, x_877); -lean_ctor_set(x_880, 1, x_878); -return x_880; -} -} -} -else -{ -uint8_t x_881; lean_object* x_882; lean_object* x_883; -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_881 = 0; -x_882 = lean_box(x_881); -x_883 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_883, 0, x_882); -lean_ctor_set(x_883, 1, x_538); -return x_883; +x_266 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_247); +return x_266; } } default: { -uint8_t x_884; lean_object* x_885; lean_object* x_886; -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_884 = 0; -x_885 = lean_box(x_884); -x_886 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_886, 0, x_885); -lean_ctor_set(x_886, 1, x_538); -return x_886; -} -} -} -block_556: -{ -if (x_542 == 0) -{ -lean_object* x_544; lean_object* x_545; lean_object* x_546; lean_object* x_547; lean_object* x_548; lean_object* x_549; lean_object* x_550; lean_object* x_551; lean_object* x_552; -lean_dec(x_539); -x_544 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_545 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_546 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -lean_inc(x_4); -lean_inc(x_2); -x_547 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___boxed), 9, 6); -lean_closure_set(x_547, 0, x_2); -lean_closure_set(x_547, 1, x_4); -lean_closure_set(x_547, 2, x_541); -lean_closure_set(x_547, 3, x_544); -lean_closure_set(x_547, 4, x_545); -lean_closure_set(x_547, 5, x_546); -lean_inc(x_1); -x_548 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAux), 4, 1); -lean_closure_set(x_548, 0, x_1); -x_549 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3; -lean_inc(x_5); -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_548); -lean_inc(x_1); -x_550 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 7); -lean_closure_set(x_550, 0, x_1); -lean_closure_set(x_550, 1, x_548); -lean_closure_set(x_550, 2, x_2); -lean_closure_set(x_550, 3, x_3); -lean_closure_set(x_550, 4, x_5); -lean_closure_set(x_550, 5, x_549); -lean_closure_set(x_550, 6, x_547); -lean_inc(x_3); -lean_inc(x_548); -lean_inc(x_1); -lean_inc(x_2); -x_551 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__8___boxed), 13, 10); -lean_closure_set(x_551, 0, x_540); -lean_closure_set(x_551, 1, x_544); -lean_closure_set(x_551, 2, x_545); -lean_closure_set(x_551, 3, x_23); -lean_closure_set(x_551, 4, x_546); -lean_closure_set(x_551, 5, x_2); -lean_closure_set(x_551, 6, x_5); -lean_closure_set(x_551, 7, x_1); -lean_closure_set(x_551, 8, x_548); -lean_closure_set(x_551, 9, x_3); -x_552 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_1, x_548, x_2, x_3, x_4, x_550, x_551, x_6, x_543); -return x_552; -} -else -{ -uint8_t x_553; lean_object* x_554; lean_object* x_555; -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_553 = 1; -x_554 = lean_box(x_553); -if (lean_is_scalar(x_539)) { - x_555 = lean_alloc_ctor(0, 2, 0); -} else { - x_555 = x_539; -} -lean_ctor_set(x_555, 0, x_554); -lean_ctor_set(x_555, 1, x_543); -return x_555; -} -} -block_644: -{ -if (x_557 == 0) -{ -lean_object* x_559; lean_object* x_560; lean_object* x_561; lean_object* x_562; lean_object* x_563; lean_object* x_564; lean_object* x_565; lean_object* x_566; lean_object* x_567; uint8_t x_568; lean_object* x_569; lean_object* x_570; lean_object* x_571; -x_559 = lean_ctor_get(x_558, 4); -lean_inc(x_559); -x_560 = lean_ctor_get(x_558, 0); -lean_inc(x_560); -x_561 = lean_ctor_get(x_558, 1); -lean_inc(x_561); -x_562 = lean_ctor_get(x_558, 2); -lean_inc(x_562); -x_563 = lean_ctor_get(x_558, 3); -lean_inc(x_563); -x_564 = lean_ctor_get(x_558, 5); -lean_inc(x_564); -if (lean_is_exclusive(x_558)) { - lean_ctor_release(x_558, 0); - lean_ctor_release(x_558, 1); - lean_ctor_release(x_558, 2); - lean_ctor_release(x_558, 3); - lean_ctor_release(x_558, 4); - lean_ctor_release(x_558, 5); - x_565 = x_558; -} else { - lean_dec_ref(x_558); - x_565 = lean_box(0); -} -x_566 = lean_ctor_get(x_559, 0); -lean_inc(x_566); -if (lean_is_exclusive(x_559)) { - lean_ctor_release(x_559, 0); - x_567 = x_559; -} else { - lean_dec_ref(x_559); - x_567 = lean_box(0); -} -x_568 = 1; -if (lean_is_scalar(x_567)) { - x_569 = lean_alloc_ctor(0, 1, 1); -} else { - x_569 = x_567; -} -lean_ctor_set(x_569, 0, x_566); -lean_ctor_set_uint8(x_569, sizeof(void*)*1, x_568); -if (lean_is_scalar(x_565)) { - x_570 = lean_alloc_ctor(0, 6, 0); -} else { - x_570 = x_565; -} -lean_ctor_set(x_570, 0, x_560); -lean_ctor_set(x_570, 1, x_561); -lean_ctor_set(x_570, 2, x_562); -lean_ctor_set(x_570, 3, x_563); -lean_ctor_set(x_570, 4, x_569); -lean_ctor_set(x_570, 5, x_564); +lean_object* x_267; lean_inc(x_6); -x_571 = l_Lean_Meta_try(x_24, x_6, x_570); -if (lean_obj_tag(x_571) == 0) -{ -lean_object* x_572; lean_object* x_573; lean_object* x_574; lean_object* x_575; lean_object* x_576; lean_object* x_577; lean_object* x_578; lean_object* x_579; lean_object* x_580; lean_object* x_581; lean_object* x_582; uint8_t x_583; lean_object* x_584; lean_object* x_585; uint8_t x_586; -x_572 = lean_ctor_get(x_571, 1); -lean_inc(x_572); -x_573 = lean_ctor_get(x_572, 4); -lean_inc(x_573); -x_574 = lean_ctor_get(x_571, 0); -lean_inc(x_574); -lean_dec(x_571); -x_575 = lean_ctor_get(x_572, 0); -lean_inc(x_575); -x_576 = lean_ctor_get(x_572, 1); -lean_inc(x_576); -x_577 = lean_ctor_get(x_572, 2); -lean_inc(x_577); -x_578 = lean_ctor_get(x_572, 3); -lean_inc(x_578); -x_579 = lean_ctor_get(x_572, 5); -lean_inc(x_579); -if (lean_is_exclusive(x_572)) { - lean_ctor_release(x_572, 0); - lean_ctor_release(x_572, 1); - lean_ctor_release(x_572, 2); - lean_ctor_release(x_572, 3); - lean_ctor_release(x_572, 4); - lean_ctor_release(x_572, 5); - x_580 = x_572; -} else { - lean_dec_ref(x_572); - x_580 = lean_box(0); -} -x_581 = lean_ctor_get(x_573, 0); -lean_inc(x_581); -if (lean_is_exclusive(x_573)) { - lean_ctor_release(x_573, 0); - x_582 = x_573; -} else { - lean_dec_ref(x_573); - x_582 = lean_box(0); -} -x_583 = 0; -if (lean_is_scalar(x_582)) { - x_584 = lean_alloc_ctor(0, 1, 1); -} else { - x_584 = x_582; -} -lean_ctor_set(x_584, 0, x_581); -lean_ctor_set_uint8(x_584, sizeof(void*)*1, x_583); -if (lean_is_scalar(x_580)) { - x_585 = lean_alloc_ctor(0, 6, 0); -} else { - x_585 = x_580; -} -lean_ctor_set(x_585, 0, x_575); -lean_ctor_set(x_585, 1, x_576); -lean_ctor_set(x_585, 2, x_577); -lean_ctor_set(x_585, 3, x_578); -lean_ctor_set(x_585, 4, x_584); -lean_ctor_set(x_585, 5, x_579); -x_586 = lean_unbox(x_574); -lean_dec(x_574); -x_542 = x_586; -x_543 = x_585; -goto block_556; -} -else -{ -lean_object* x_587; lean_object* x_588; lean_object* x_589; lean_object* x_590; lean_object* x_591; lean_object* x_592; lean_object* x_593; lean_object* x_594; lean_object* x_595; lean_object* x_596; lean_object* x_597; lean_object* x_598; uint8_t x_599; lean_object* x_600; lean_object* x_601; lean_object* x_602; -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_587 = lean_ctor_get(x_571, 1); -lean_inc(x_587); -x_588 = lean_ctor_get(x_587, 4); -lean_inc(x_588); -x_589 = lean_ctor_get(x_571, 0); -lean_inc(x_589); -if (lean_is_exclusive(x_571)) { - lean_ctor_release(x_571, 0); - lean_ctor_release(x_571, 1); - x_590 = x_571; -} else { - lean_dec_ref(x_571); - x_590 = lean_box(0); -} -x_591 = lean_ctor_get(x_587, 0); -lean_inc(x_591); -x_592 = lean_ctor_get(x_587, 1); -lean_inc(x_592); -x_593 = lean_ctor_get(x_587, 2); -lean_inc(x_593); -x_594 = lean_ctor_get(x_587, 3); -lean_inc(x_594); -x_595 = lean_ctor_get(x_587, 5); -lean_inc(x_595); -if (lean_is_exclusive(x_587)) { - lean_ctor_release(x_587, 0); - lean_ctor_release(x_587, 1); - lean_ctor_release(x_587, 2); - lean_ctor_release(x_587, 3); - lean_ctor_release(x_587, 4); - lean_ctor_release(x_587, 5); - x_596 = x_587; -} else { - lean_dec_ref(x_587); - x_596 = lean_box(0); -} -x_597 = lean_ctor_get(x_588, 0); -lean_inc(x_597); -if (lean_is_exclusive(x_588)) { - lean_ctor_release(x_588, 0); - x_598 = x_588; -} else { - lean_dec_ref(x_588); - x_598 = lean_box(0); -} -x_599 = 0; -if (lean_is_scalar(x_598)) { - x_600 = lean_alloc_ctor(0, 1, 1); -} else { - x_600 = x_598; -} -lean_ctor_set(x_600, 0, x_597); -lean_ctor_set_uint8(x_600, sizeof(void*)*1, x_599); -if (lean_is_scalar(x_596)) { - x_601 = lean_alloc_ctor(0, 6, 0); -} else { - x_601 = x_596; -} -lean_ctor_set(x_601, 0, x_591); -lean_ctor_set(x_601, 1, x_592); -lean_ctor_set(x_601, 2, x_593); -lean_ctor_set(x_601, 3, x_594); -lean_ctor_set(x_601, 4, x_600); -lean_ctor_set(x_601, 5, x_595); -if (lean_is_scalar(x_590)) { - x_602 = lean_alloc_ctor(1, 2, 0); -} else { - x_602 = x_590; -} -lean_ctor_set(x_602, 0, x_589); -lean_ctor_set(x_602, 1, x_601); -return x_602; -} -} -else -{ -lean_object* x_603; lean_object* x_604; lean_object* x_605; lean_object* x_606; -x_603 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_604 = l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1; -x_605 = l___private_Init_Lean_Trace_2__getResetTraces___rarg(x_603, x_604); -lean_inc(x_6); -x_606 = lean_apply_2(x_605, x_6, x_558); -if (lean_obj_tag(x_606) == 0) -{ -lean_object* x_607; lean_object* x_608; lean_object* x_609; -x_607 = lean_ctor_get(x_606, 0); -lean_inc(x_607); -x_608 = lean_ctor_get(x_606, 1); -lean_inc(x_608); -lean_dec(x_606); -lean_inc(x_6); -x_609 = l_Lean_Meta_try(x_24, x_6, x_608); -if (lean_obj_tag(x_609) == 0) -{ -lean_object* x_610; lean_object* x_611; lean_object* x_612; lean_object* x_613; lean_object* x_614; -x_610 = lean_ctor_get(x_609, 0); -lean_inc(x_610); -x_611 = lean_ctor_get(x_609, 1); -lean_inc(x_611); -lean_dec(x_609); -x_612 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -lean_inc(x_607); -x_613 = l___private_Init_Lean_Trace_1__addNode___rarg(x_604, x_607, x_612); -lean_inc(x_6); -x_614 = lean_apply_2(x_613, x_6, x_611); -if (lean_obj_tag(x_614) == 0) -{ -lean_object* x_615; uint8_t x_616; -lean_dec(x_607); -x_615 = lean_ctor_get(x_614, 1); -lean_inc(x_615); -lean_dec(x_614); -x_616 = lean_unbox(x_610); -lean_dec(x_610); -x_542 = x_616; -x_543 = x_615; -goto block_556; -} -else -{ -lean_object* x_617; lean_object* x_618; lean_object* x_619; lean_object* x_620; -lean_dec(x_610); -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_617 = lean_ctor_get(x_614, 0); -lean_inc(x_617); -x_618 = lean_ctor_get(x_614, 1); -lean_inc(x_618); -lean_dec(x_614); -x_619 = l___private_Init_Lean_Trace_1__addNode___rarg(x_604, x_607, x_612); -x_620 = lean_apply_2(x_619, x_6, x_618); -if (lean_obj_tag(x_620) == 0) -{ -lean_object* x_621; lean_object* x_622; lean_object* x_623; -x_621 = lean_ctor_get(x_620, 1); -lean_inc(x_621); -if (lean_is_exclusive(x_620)) { - lean_ctor_release(x_620, 0); - lean_ctor_release(x_620, 1); - x_622 = x_620; -} else { - lean_dec_ref(x_620); - x_622 = lean_box(0); -} -if (lean_is_scalar(x_622)) { - x_623 = lean_alloc_ctor(1, 2, 0); -} else { - x_623 = x_622; - lean_ctor_set_tag(x_623, 1); -} -lean_ctor_set(x_623, 0, x_617); -lean_ctor_set(x_623, 1, x_621); -return x_623; -} -else -{ -lean_object* x_624; lean_object* x_625; lean_object* x_626; lean_object* x_627; -lean_dec(x_617); -x_624 = lean_ctor_get(x_620, 0); -lean_inc(x_624); -x_625 = lean_ctor_get(x_620, 1); -lean_inc(x_625); -if (lean_is_exclusive(x_620)) { - lean_ctor_release(x_620, 0); - lean_ctor_release(x_620, 1); - x_626 = x_620; -} else { - lean_dec_ref(x_620); - x_626 = lean_box(0); -} -if (lean_is_scalar(x_626)) { - x_627 = lean_alloc_ctor(1, 2, 0); -} else { - x_627 = x_626; -} -lean_ctor_set(x_627, 0, x_624); -lean_ctor_set(x_627, 1, x_625); -return x_627; +x_267 = l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___at___private_Init_Lean_Meta_ExprDefEq_32__isDefEqOnFailure___spec__5(x_6, x_9, x_6, x_3, x_247); +return x_267; } } } else { -lean_object* x_628; lean_object* x_629; lean_object* x_630; lean_object* x_631; lean_object* x_632; -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_628 = lean_ctor_get(x_609, 0); -lean_inc(x_628); -x_629 = lean_ctor_get(x_609, 1); -lean_inc(x_629); -lean_dec(x_609); -x_630 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2; -x_631 = l___private_Init_Lean_Trace_1__addNode___rarg(x_604, x_607, x_630); -x_632 = lean_apply_2(x_631, x_6, x_629); -if (lean_obj_tag(x_632) == 0) -{ -lean_object* x_633; lean_object* x_634; lean_object* x_635; -x_633 = lean_ctor_get(x_632, 1); -lean_inc(x_633); -if (lean_is_exclusive(x_632)) { - lean_ctor_release(x_632, 0); - lean_ctor_release(x_632, 1); - x_634 = x_632; -} else { - lean_dec_ref(x_632); - x_634 = lean_box(0); -} -if (lean_is_scalar(x_634)) { - x_635 = lean_alloc_ctor(1, 2, 0); -} else { - x_635 = x_634; - lean_ctor_set_tag(x_635, 1); -} -lean_ctor_set(x_635, 0, x_628); -lean_ctor_set(x_635, 1, x_633); -return x_635; -} -else -{ -lean_object* x_636; lean_object* x_637; lean_object* x_638; lean_object* x_639; -lean_dec(x_628); -x_636 = lean_ctor_get(x_632, 0); -lean_inc(x_636); -x_637 = lean_ctor_get(x_632, 1); -lean_inc(x_637); -if (lean_is_exclusive(x_632)) { - lean_ctor_release(x_632, 0); - lean_ctor_release(x_632, 1); - x_638 = x_632; -} else { - lean_dec_ref(x_632); - x_638 = lean_box(0); -} -if (lean_is_scalar(x_638)) { - x_639 = lean_alloc_ctor(1, 2, 0); -} else { - x_639 = x_638; -} -lean_ctor_set(x_639, 0, x_636); -lean_ctor_set(x_639, 1, x_637); -return x_639; -} -} -} -else -{ -lean_object* x_640; lean_object* x_641; lean_object* x_642; lean_object* x_643; -lean_dec(x_541); -lean_dec(x_540); -lean_dec(x_539); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_640 = lean_ctor_get(x_606, 0); -lean_inc(x_640); -x_641 = lean_ctor_get(x_606, 1); -lean_inc(x_641); -if (lean_is_exclusive(x_606)) { - lean_ctor_release(x_606, 0); - lean_ctor_release(x_606, 1); - x_642 = x_606; -} else { - lean_dec_ref(x_606); - x_642 = lean_box(0); -} -if (lean_is_scalar(x_642)) { - x_643 = lean_alloc_ctor(1, 2, 0); -} else { - x_643 = x_642; -} -lean_ctor_set(x_643, 0, x_640); -lean_ctor_set(x_643, 1, x_641); -return x_643; -} -} -} -} -} -} -else -{ -lean_object* x_887; lean_object* x_888; lean_object* x_889; lean_object* x_890; -lean_dec(x_510); -lean_dec(x_24); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_887 = lean_ctor_get(x_512, 0); -lean_inc(x_887); -x_888 = lean_ctor_get(x_512, 1); -lean_inc(x_888); -if (lean_is_exclusive(x_512)) { - lean_ctor_release(x_512, 0); - lean_ctor_release(x_512, 1); - x_889 = x_512; -} else { - lean_dec_ref(x_512); - x_889 = lean_box(0); -} -if (lean_is_scalar(x_889)) { - x_890 = lean_alloc_ctor(1, 2, 0); -} else { - x_890 = x_889; -} -lean_ctor_set(x_890, 0, x_887); -lean_ctor_set(x_890, 1, x_888); -return x_890; -} -} -} -else -{ -uint8_t x_891; -lean_dec(x_24); +lean_object* x_268; lean_object* x_269; lean_dec(x_9); lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_891 = !lean_is_exclusive(x_25); -if (x_891 == 0) -{ -return x_25; +x_268 = lean_box(x_246); +if (lean_is_scalar(x_11)) { + x_269 = lean_alloc_ctor(0, 2, 0); +} else { + x_269 = x_11; +} +lean_ctor_set(x_269, 0, x_268); +lean_ctor_set(x_269, 1, x_247); +return x_269; +} +} +} +} } else { -lean_object* x_892; lean_object* x_893; lean_object* x_894; -x_892 = lean_ctor_get(x_25, 0); -x_893 = lean_ctor_get(x_25, 1); -lean_inc(x_893); -lean_inc(x_892); -lean_dec(x_25); -x_894 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_894, 0, x_892); -lean_ctor_set(x_894, 1, x_893); -return x_894; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -uint8_t x_6; lean_object* x_7; -x_6 = lean_unbox(x_3); +uint8_t x_337; +lean_dec(x_6); lean_dec(x_3); -x_7 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__1(x_1, x_2, x_6, x_4, x_5); lean_dec(x_2); lean_dec(x_1); -return x_7; +x_337 = !lean_is_exclusive(x_8); +if (x_337 == 0) +{ +return x_8; +} +else +{ +lean_object* x_338; lean_object* x_339; lean_object* x_340; +x_338 = lean_ctor_get(x_8, 0); +x_339 = lean_ctor_get(x_8, 1); +lean_inc(x_339); +lean_inc(x_338); +lean_dec(x_8); +x_340 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_340, 0, x_338); +lean_ctor_set(x_340, 1, x_339); +return x_340; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +} +else +{ +uint8_t x_341; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_341 = !lean_is_exclusive(x_5); +if (x_341 == 0) +{ +return x_5; +} +else +{ +lean_object* x_342; lean_object* x_343; lean_object* x_344; +x_342 = lean_ctor_get(x_5, 0); +x_343 = lean_ctor_get(x_5, 1); +lean_inc(x_343); +lean_inc(x_342); +lean_dec(x_5); +x_344 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_344, 0, x_342); +lean_ctor_set(x_344, 1, x_343); +return x_344; +} +} +} +} +lean_object* _init_l_Lean_Meta_isExprDefEqAuxImpl___closed__1() { _start: { -lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_3); -return x_10; +lean_object* x_1; +x_1 = lean_mk_string("step"); +return x_1; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* _init_l_Lean_Meta_isExprDefEqAuxImpl___closed__2() { _start: { -lean_object* x_10; -x_10 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_3); -return x_10; +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4; +x_2 = l_Lean_Meta_isExprDefEqAuxImpl___closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* _init_l_Lean_Meta_isExprDefEqAuxImpl___closed__3() { _start: { +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; +x_2 = l_Lean_Meta_isExprDefEqAuxImpl___closed__2; +x_3 = l_Lean_Name_append___main(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_Meta_isExprDefEqAuxImpl(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_56; uint8_t x_57; +x_56 = lean_ctor_get(x_4, 4); +lean_inc(x_56); +x_57 = lean_ctor_get_uint8(x_56, sizeof(void*)*1); +lean_dec(x_56); +if (x_57 == 0) +{ +x_5 = x_4; +goto block_55; +} +else +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; uint8_t x_61; +x_58 = l_Lean_Meta_isExprDefEqAuxImpl___closed__3; +x_59 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_58, x_3, x_4); +x_60 = lean_ctor_get(x_59, 0); +lean_inc(x_60); +x_61 = lean_unbox(x_60); +lean_dec(x_60); +if (x_61 == 0) +{ +lean_object* x_62; +x_62 = lean_ctor_get(x_59, 1); +lean_inc(x_62); +lean_dec(x_59); +x_5 = x_62; +goto block_55; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_63 = lean_ctor_get(x_59, 1); +lean_inc(x_63); +lean_dec(x_59); +lean_inc(x_1); +x_64 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_64, 0, x_1); +x_65 = l_Lean_Meta_isLevelDefEqAux___main___closed__8; +x_66 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_66, 0, x_64); +lean_ctor_set(x_66, 1, x_65); +lean_inc(x_2); +x_67 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_67, 0, x_2); +x_68 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_68, 0, x_66); +lean_ctor_set(x_68, 1, x_67); +x_69 = l_Lean_Meta_isExprDefEqAuxImpl___closed__2; +x_70 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_69, x_68, x_3, x_63); +x_71 = lean_ctor_get(x_70, 1); +lean_inc(x_71); +lean_dec(x_70); +x_5 = x_71; +goto block_55; +} +} +block_55: +{ lean_object* x_6; -x_6 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__4(x_1, x_2, x_3, x_4, x_5); +lean_inc(x_3); +lean_inc(x_2); +lean_inc(x_1); +x_6 = l___private_Init_Lean_Meta_ExprDefEq_27__isDefEqQuick___main(x_1, x_2, x_3, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_unbox(x_7); +lean_dec(x_7); +switch (x_8) { +case 0: +{ +uint8_t x_9; lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_9 = !lean_is_exclusive(x_6); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_6, 0); +lean_dec(x_10); +x_11 = 0; +x_12 = lean_box(x_11); +lean_ctor_set(x_6, 0, x_12); return x_6; } +else +{ +lean_object* x_13; uint8_t x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_6, 1); +lean_inc(x_13); +lean_dec(x_6); +x_14 = 0; +x_15 = lean_box(x_14); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_13); +return x_16; } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +} +case 1: +{ +uint8_t x_17; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_17 = !lean_is_exclusive(x_6); +if (x_17 == 0) +{ +lean_object* x_18; uint8_t x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_6, 0); +lean_dec(x_18); +x_19 = 1; +x_20 = lean_box(x_19); +lean_ctor_set(x_6, 0, x_20); +return x_6; +} +else +{ +lean_object* x_21; uint8_t x_22; lean_object* x_23; lean_object* x_24; +x_21 = lean_ctor_get(x_6, 1); +lean_inc(x_21); +lean_dec(x_6); +x_22 = 1; +x_23 = lean_box(x_22); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_23); +lean_ctor_set(x_24, 1, x_21); +return x_24; +} +} +default: +{ +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_6, 1); +lean_inc(x_25); +lean_dec(x_6); +lean_inc(x_3); +lean_inc(x_2); +lean_inc(x_1); +x_26 = l___private_Init_Lean_Meta_ExprDefEq_28__isDefEqProofIrrel(x_1, x_2, x_3, x_25); +if (lean_obj_tag(x_26) == 0) +{ +lean_object* x_27; uint8_t x_28; +x_27 = lean_ctor_get(x_26, 0); +lean_inc(x_27); +x_28 = lean_unbox(x_27); +lean_dec(x_27); +switch (x_28) { +case 0: +{ +uint8_t x_29; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_26); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_26, 0); +lean_dec(x_30); +x_31 = 0; +x_32 = lean_box(x_31); +lean_ctor_set(x_26, 0, x_32); +return x_26; +} +else +{ +lean_object* x_33; uint8_t x_34; lean_object* x_35; lean_object* x_36; +x_33 = lean_ctor_get(x_26, 1); +lean_inc(x_33); +lean_dec(x_26); +x_34 = 0; +x_35 = lean_box(x_34); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_33); +return x_36; +} +} +case 1: +{ +uint8_t x_37; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_37 = !lean_is_exclusive(x_26); +if (x_37 == 0) +{ +lean_object* x_38; uint8_t x_39; lean_object* x_40; +x_38 = lean_ctor_get(x_26, 0); +lean_dec(x_38); +x_39 = 1; +x_40 = lean_box(x_39); +lean_ctor_set(x_26, 0, x_40); +return x_26; +} +else +{ +lean_object* x_41; uint8_t x_42; lean_object* x_43; lean_object* x_44; +x_41 = lean_ctor_get(x_26, 1); +lean_inc(x_41); +lean_dec(x_26); +x_42 = 1; +x_43 = lean_box(x_42); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_41); +return x_44; +} +} +default: +{ +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_26, 1); +lean_inc(x_45); +lean_dec(x_26); +x_46 = l___private_Init_Lean_Meta_ExprDefEq_30__isDefEqWHNF___at_Lean_Meta_isExprDefEqAuxImpl___spec__2(x_1, x_2, x_3, x_45); +return x_46; +} +} +} +else +{ +uint8_t x_47; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_47 = !lean_is_exclusive(x_26); +if (x_47 == 0) +{ +return x_26; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_26, 0); +x_49 = lean_ctor_get(x_26, 1); +lean_inc(x_49); +lean_inc(x_48); +lean_dec(x_26); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +return x_50; +} +} +} +} +} +else +{ +uint8_t x_51; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_51 = !lean_is_exclusive(x_6); +if (x_51 == 0) +{ +return x_6; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_6, 0); +x_53 = lean_ctor_get(x_6, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_6); +x_54 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} +} +} +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { uint8_t x_7; lean_object* x_8; x_7 = lean_unbox(x_4); lean_dec(x_4); -x_8 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__5(x_1, x_2, x_3, x_7, x_5, x_6); +x_8 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEqAuxImpl___spec__1___lambda__1(x_1, x_2, x_3, x_7, x_5, x_6); return x_8; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* _init_l_Lean_Meta_setIsExprDefEqAuxRef___closed__1() { _start: { -lean_object* x_7; -x_7 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__6(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_4); -return x_7; +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_isExprDefEqAuxImpl), 4, 0); +return x_1; } } -lean_object* l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +lean_object* l_Lean_Meta_setIsExprDefEqAuxRef(lean_object* x_1) { _start: { -lean_object* x_14; -x_14 = l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__8(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); -lean_dec(x_1); -return x_14; +lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_2 = l_Lean_Meta_isExprDefEqAuxRef; +x_3 = l_Lean_Meta_setIsExprDefEqAuxRef___closed__1; +x_4 = lean_io_ref_set(x_2, x_3, x_1); +return x_4; } } lean_object* initialize_Init_Lean_Meta_WHNF(lean_object*); @@ -19105,8 +32310,8 @@ lean_dec_ref(res); res = initialize_Init_Lean_Meta_Offset(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___closed__1); +l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___closed__1 = _init_l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___closed__1(); +lean_mark_persistent(l_Lean_Meta_try___at___private_Init_Lean_Meta_ExprDefEq_1__isDefEqEta___spec__1___closed__1); l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__1 = _init_l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__1(); lean_mark_persistent(l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__1); l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__2 = _init_l_Lean_Meta_CheckAssignment_Lean_MonadCache___closed__2(); @@ -19117,80 +32322,95 @@ l_Lean_Meta_CheckAssignment_Lean_MonadCache = _init_l_Lean_Meta_CheckAssignment_ lean_mark_persistent(l_Lean_Meta_CheckAssignment_Lean_MonadCache); l_Lean_Meta_CheckAssignment_check___main___closed__1 = _init_l_Lean_Meta_CheckAssignment_check___main___closed__1(); lean_mark_persistent(l_Lean_Meta_CheckAssignment_check___main___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__2 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__2); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__3 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__3); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__4 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__4(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__4); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__5 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__5(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__5); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__6); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__7 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__7(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__7); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__8 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__8(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__8); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__9 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__9(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__9); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__10); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__11 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__11(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__11); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__12 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__12(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__12); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__13 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__13(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__13); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__14 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__14(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__14); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__15); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__16 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__16(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__16); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__17 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__17(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__17); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__18 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__18(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__18); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__19 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__19(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__19); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__20 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__20(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__20); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__21 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__21(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__21); -l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__22 = _init_l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__22(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_8__checkAssignmentFailure___closed__22); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__1); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__2 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__2); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__3 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__3); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__4); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__5 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__5); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__6); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__7 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__7(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__7); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__8 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__8(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__8); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__9 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__9(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__9); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__10); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__11 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__11(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__11); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__12 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__12(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__12); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__13 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__13(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__13); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__14 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__14(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__14); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__15); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__16 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__16(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__16); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__17 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__17(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__17); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__18 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__18(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__18); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__19 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__19(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__19); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__20 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__20(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__20); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__21 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__21(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__21); +l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__22 = _init_l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__22(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_10__checkAssignmentFailure___closed__22); l_Lean_Meta_checkAssignment___closed__1 = _init_l_Lean_Meta_checkAssignment___closed__1(); lean_mark_persistent(l_Lean_Meta_checkAssignment___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__2 = _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__2); -l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3 = _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__3); -l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4 = _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__4); -l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__5 = _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__5(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__5); -l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__6 = _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__6(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__6); -l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7 = _init_l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_14__processAssignmentAux___main___closed__7); -l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__2___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__3___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___lambda__7___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__1); -l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2 = _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__2); -l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3 = _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__3); -l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__4 = _init_l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__4(); -lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_19__isDefEqDelta___closed__4); +l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__1); +l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2 = _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__2); +l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3 = _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__3); +l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__4 = _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__4); +l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__5 = _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__5); +l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6 = _init_l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_17__processAssignmentAux___main___closed__6); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__2___closed__1); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__3___closed__1); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___lambda__7___closed__1); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__1); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__2 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__2); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__3); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__4); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__5 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__5); +l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__6 = _init_l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_21__isDefEqDelta___closed__6); +l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___closed__1 = _init_l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_ExprDefEq_31__unstuckMVar___closed__1); +l_Lean_Meta_isExprDefEqAuxImpl___closed__1 = _init_l_Lean_Meta_isExprDefEqAuxImpl___closed__1(); +lean_mark_persistent(l_Lean_Meta_isExprDefEqAuxImpl___closed__1); +l_Lean_Meta_isExprDefEqAuxImpl___closed__2 = _init_l_Lean_Meta_isExprDefEqAuxImpl___closed__2(); +lean_mark_persistent(l_Lean_Meta_isExprDefEqAuxImpl___closed__2); +l_Lean_Meta_isExprDefEqAuxImpl___closed__3 = _init_l_Lean_Meta_isExprDefEqAuxImpl___closed__3(); +lean_mark_persistent(l_Lean_Meta_isExprDefEqAuxImpl___closed__3); +l_Lean_Meta_setIsExprDefEqAuxRef___closed__1 = _init_l_Lean_Meta_setIsExprDefEqAuxRef___closed__1(); +lean_mark_persistent(l_Lean_Meta_setIsExprDefEqAuxRef___closed__1); +res = l_Lean_Meta_setIsExprDefEqAuxRef(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/library/Init/Lean/Meta/FunInfo.c b/stage0/library/Init/Lean/Meta/FunInfo.c index cce090c5e0..c9017d795f 100644 --- a/stage0/library/Init/Lean/Meta/FunInfo.c +++ b/stage0/library/Init/Lean/Meta/FunInfo.c @@ -15,94 +15,108 @@ extern "C" { #endif lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__5(lean_object*, size_t, size_t, lean_object*, lean_object*); lean_object* l_PersistentHashMap_find___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1___boxed(lean_object*, lean_object*); -lean_object* l_Lean_Meta_collectDeps(lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); size_t l_USize_add(size_t, size_t); -lean_object* l_Nat_foldMAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); size_t l_Lean_Meta_TransparencyMode_hash(uint8_t); lean_object* lean_nat_div(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isPropAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClassExpensive___main(lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(lean_object*, lean_object*, lean_object*); extern size_t l_PersistentHashMap_insertAux___main___rarg___closed__2; -lean_object* l_PersistentHashMap_find___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_qsortAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_4__collectDeps(lean_object*, lean_object*); +lean_object* l_Lean_Meta_isClassQuick___main(lean_object*, lean_object*, lean_object*); size_t l_USize_sub(size_t, size_t); extern lean_object* l_Array_empty___closed__1; +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__7(size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__3(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); -extern lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; +lean_object* l_Lean_Meta_getFunInfo(lean_object*, lean_object*, lean_object*); size_t l_USize_shiftRight(size_t, size_t); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_InfoCacheKey_Hashable___boxed(lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_4__collectDeps___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__2___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfoAux(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fget(lean_object*, lean_object*); +lean_object* lean_expr_instantiate_rev_range(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_eq(lean_object*, lean_object*); size_t l_Option_hash___at_Lean_Meta_InfoCacheKey_Hashable___spec__1(lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_2__whenHasVar___rarg___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_find___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(lean_object*, lean_object*); lean_object* lean_nat_sub(lean_object*, lean_object*); +lean_object* l_Array_indexOfAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__1(lean_object*, lean_object*, lean_object*); lean_object* lean_array_swap(lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfoNArgsAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_indexOfAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___spec__1(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_LocalDecl_binderInfo(lean_object*); extern lean_object* l_PersistentHashMap_insertAux___main___rarg___closed__3; size_t l_Lean_Expr_hash(lean_object*); lean_object* l___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_InfoCacheKey_HasBeq___boxed(lean_object*, lean_object*); lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__2(lean_object*, size_t, lean_object*); -lean_object* l_Array_indexOfAux___main___at_Lean_Meta_collectDepsAux___main___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_qsortAux___main___at_Lean_Meta_collectDeps___spec__1(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Meta_TransparencyMode_beq(uint8_t, uint8_t); -lean_object* l_PersistentHashMap_insert___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_collectDepsAux(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_mkFreshId___rarg(lean_object*); size_t l_USize_mul(size_t, size_t); -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_contains___at_Lean_Meta_collectDepsAux___main___spec__2___boxed(lean_object*, lean_object*); +uint8_t l_Lean_Expr_isForall(lean_object*); +lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_mkFVar(lean_object*); +uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux(lean_object*, lean_object*, lean_object*); size_t l_USize_land(size_t, size_t); -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_collectDepsAux___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_qsortAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__1(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___boxed(lean_object*, lean_object*); lean_object* l_Lean_LocalDecl_type(lean_object*); -lean_object* l_Lean_Meta_collectDepsAux___main(lean_object*, lean_object*, lean_object*); +lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); uint8_t l_Lean_BinderInfo_beq(uint8_t, uint8_t); uint8_t lean_expr_eqv(lean_object*, lean_object*); -lean_object* l_Lean_Meta_usingDefault(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_insertAtCollisionNodeAux___main___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__6(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_le(lean_object*, lean_object*); uint8_t l_USize_decLe(size_t, size_t); -lean_object* l_Lean_Meta_inferTypeAuxAux___main(lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l_Array_contains___at_Lean_Meta_collectDepsAux___main___spec__2(lean_object*, lean_object*); -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___spec__1___boxed(lean_object*, lean_object*, lean_object*); -uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_collectDepsAux___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_2__whenHasVar___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_2__whenHasVar(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___spec__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_getFunInfoNArgs(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_getCollisionNodeSize___rarg(lean_object*); extern lean_object* l_Lean_Expr_Inhabited; -lean_object* l_Array_indexOfAux___main___at_Lean_Meta_collectDepsAux___main___spec__1___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_whenHasVar(lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2___closed__1; size_t lean_usize_mix_hash(size_t, size_t); lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__1; lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__2; -lean_object* l_Lean_Meta_whenHasVar___rarg___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_whenHasVar___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_contains___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__2___boxed(lean_object*, lean_object*); extern lean_object* l_Nat_Inhabited; -lean_object* l_Lean_Meta_collectDepsAux___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___boxed(lean_object*, lean_object*); -lean_object* l_Array_qsortAux___main___at_Lean_Meta_collectDeps___spec__1___boxed(lean_object*, lean_object*, lean_object*); lean_object* lean_usize_to_nat(size_t); -lean_object* l_Lean_Meta_collectDepsAux___main___boxed(lean_object*, lean_object*, lean_object*); +uint8_t l_Array_contains___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__2(lean_object*, lean_object*); +lean_object* l_Lean_Meta_isProp(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_hasFVar(lean_object*); -lean_object* l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfoAuxAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_collectDeps___boxed(lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_mkCollisionNode___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_forallBoundedTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(lean_object*, lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*); @@ -1558,7 +1572,7 @@ _start: lean_object* x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; x_6 = lean_ctor_get(x_4, 0); lean_inc(x_6); -x_7 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 4); +x_7 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 5); lean_dec(x_6); x_8 = lean_ctor_get(x_5, 2); lean_inc(x_8); @@ -1832,7 +1846,7 @@ x_8 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_FunInfo return x_8; } } -lean_object* l_Lean_Meta_whenHasVar___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_FunInfo_2__whenHasVar___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { uint8_t x_4; @@ -1850,24 +1864,24 @@ return x_5; } } } -lean_object* l_Lean_Meta_whenHasVar(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_FunInfo_2__whenHasVar(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_whenHasVar___rarg___boxed), 3, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_FunInfo_2__whenHasVar___rarg___boxed), 3, 0); return x_2; } } -lean_object* l_Lean_Meta_whenHasVar___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_FunInfo_2__whenHasVar___rarg___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Lean_Meta_whenHasVar___rarg(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_FunInfo_2__whenHasVar___rarg(x_1, x_2, x_3); lean_dec(x_1); return x_4; } } -lean_object* l_Array_indexOfAux___main___at_Lean_Meta_collectDepsAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Array_indexOfAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; uint8_t x_5; @@ -1906,7 +1920,7 @@ return x_12; } } } -uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_collectDepsAux___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +uint8_t l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { uint8_t x_6; @@ -1941,18 +1955,18 @@ return x_9; } } } -uint8_t l_Array_contains___at_Lean_Meta_collectDepsAux___main___spec__2(lean_object* x_1, lean_object* x_2) { +uint8_t l_Array_contains___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__2(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; lean_object* x_4; uint8_t x_5; x_3 = lean_array_get_size(x_1); x_4 = lean_unsigned_to_nat(0u); -x_5 = l_Array_anyRangeMAux___main___at_Lean_Meta_collectDepsAux___main___spec__3(x_1, x_2, x_1, x_3, x_4); +x_5 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__3(x_1, x_2, x_1, x_3, x_4); lean_dec(x_3); return x_5; } } -lean_object* l_Lean_Meta_collectDepsAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { switch (lean_obj_tag(x_2)) { @@ -1960,7 +1974,7 @@ case 1: { lean_object* x_4; lean_object* x_5; x_4 = lean_unsigned_to_nat(0u); -x_5 = l_Array_indexOfAux___main___at_Lean_Meta_collectDepsAux___main___spec__1(x_1, x_2, x_4); +x_5 = l_Array_indexOfAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__1(x_1, x_2, x_4); if (lean_obj_tag(x_5) == 0) { return x_3; @@ -1971,7 +1985,7 @@ lean_object* x_6; uint8_t x_7; x_6 = lean_ctor_get(x_5, 0); lean_inc(x_6); lean_dec(x_5); -x_7 = l_Array_contains___at_Lean_Meta_collectDepsAux___main___spec__2(x_3, x_6); +x_7 = l_Array_contains___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__2(x_3, x_6); if (x_7 == 0) { lean_object* x_8; @@ -1998,7 +2012,7 @@ return x_3; else { lean_object* x_12; -x_12 = l_Lean_Meta_collectDepsAux___main(x_1, x_9, x_3); +x_12 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_9, x_3); x_2 = x_10; x_3 = x_12; goto _start; @@ -2017,7 +2031,7 @@ return x_3; else { lean_object* x_17; -x_17 = l_Lean_Meta_collectDepsAux___main(x_1, x_14, x_3); +x_17 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_14, x_3); x_2 = x_15; x_3 = x_17; goto _start; @@ -2036,7 +2050,7 @@ return x_3; else { lean_object* x_22; -x_22 = l_Lean_Meta_collectDepsAux___main(x_1, x_19, x_3); +x_22 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_19, x_3); x_2 = x_20; x_3 = x_22; goto _start; @@ -2056,8 +2070,8 @@ return x_3; else { lean_object* x_28; lean_object* x_29; -x_28 = l_Lean_Meta_collectDepsAux___main(x_1, x_24, x_3); -x_29 = l_Lean_Meta_collectDepsAux___main(x_1, x_25, x_28); +x_28 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_24, x_3); +x_29 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_25, x_28); x_2 = x_26; x_3 = x_29; goto _start; @@ -2084,21 +2098,21 @@ return x_3; } } } -lean_object* l_Array_indexOfAux___main___at_Lean_Meta_collectDepsAux___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Array_indexOfAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Array_indexOfAux___main___at_Lean_Meta_collectDepsAux___main___spec__1(x_1, x_2, x_3); +x_4 = l_Array_indexOfAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__1(x_1, x_2, x_3); lean_dec(x_2); lean_dec(x_1); return x_4; } } -lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_collectDepsAux___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { uint8_t x_6; lean_object* x_7; -x_6 = l_Array_anyRangeMAux___main___at_Lean_Meta_collectDepsAux___main___spec__3(x_1, x_2, x_3, x_4, x_5); +x_6 = l_Array_anyRangeMAux___main___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__3(x_1, x_2, x_3, x_4, x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); @@ -2107,46 +2121,46 @@ x_7 = lean_box(x_6); return x_7; } } -lean_object* l_Array_contains___at_Lean_Meta_collectDepsAux___main___spec__2___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l_Array_contains___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__2___boxed(lean_object* x_1, lean_object* x_2) { _start: { uint8_t x_3; lean_object* x_4; -x_3 = l_Array_contains___at_Lean_Meta_collectDepsAux___main___spec__2(x_1, x_2); +x_3 = l_Array_contains___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__2(x_1, x_2); lean_dec(x_2); lean_dec(x_1); x_4 = lean_box(x_3); return x_4; } } -lean_object* l_Lean_Meta_collectDepsAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Lean_Meta_collectDepsAux___main(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_2, x_3); lean_dec(x_2); lean_dec(x_1); return x_4; } } -lean_object* l_Lean_Meta_collectDepsAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Lean_Meta_collectDepsAux___main(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_2, x_3); return x_4; } } -lean_object* l_Lean_Meta_collectDepsAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Lean_Meta_collectDepsAux(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux(x_1, x_2, x_3); lean_dec(x_2); lean_dec(x_1); return x_4; } } -lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { uint8_t x_6; @@ -2194,7 +2208,7 @@ goto _start; } } } -lean_object* l_Array_qsortAux___main___at_Lean_Meta_collectDeps___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Array_qsortAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; uint8_t x_13; @@ -2248,7 +2262,7 @@ if (x_23 == 0) lean_object* x_24; lean_dec(x_16); lean_inc_n(x_2, 2); -x_24 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2(x_3, x_19, x_17, x_2, x_2); +x_24 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2(x_3, x_19, x_17, x_2, x_2); lean_dec(x_19); x_4 = x_24; goto block_12; @@ -2261,7 +2275,7 @@ x_25 = lean_array_swap(x_17, x_16, x_3); lean_dec(x_16); x_26 = lean_array_get(x_18, x_25, x_3); lean_inc_n(x_2, 2); -x_27 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2(x_3, x_26, x_25, x_2, x_2); +x_27 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2(x_3, x_26, x_25, x_2, x_2); lean_dec(x_26); x_4 = x_27; goto block_12; @@ -2281,7 +2295,7 @@ if (x_31 == 0) lean_object* x_32; lean_dec(x_16); lean_inc_n(x_2, 2); -x_32 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2(x_3, x_30, x_28, x_2, x_2); +x_32 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2(x_3, x_30, x_28, x_2, x_2); lean_dec(x_30); x_4 = x_32; goto block_12; @@ -2294,7 +2308,7 @@ x_33 = lean_array_swap(x_28, x_16, x_3); lean_dec(x_16); x_34 = lean_array_get(x_18, x_33, x_3); lean_inc_n(x_2, 2); -x_35 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2(x_3, x_34, x_33, x_2, x_2); +x_35 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2(x_3, x_34, x_33, x_2, x_2); lean_dec(x_34); x_4 = x_35; goto block_12; @@ -2314,7 +2328,7 @@ x_7 = lean_nat_dec_le(x_3, x_5); if (x_7 == 0) { lean_object* x_8; lean_object* x_9; lean_object* x_10; -x_8 = l_Array_qsortAux___main___at_Lean_Meta_collectDeps___spec__1(x_6, x_2, x_5); +x_8 = l_Array_qsortAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__1(x_6, x_2, x_5); x_9 = lean_unsigned_to_nat(1u); x_10 = lean_nat_add(x_5, x_9); lean_dec(x_5); @@ -2331,52 +2345,52 @@ return x_6; } } } -lean_object* l_Lean_Meta_collectDeps(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Init_Lean_Meta_FunInfo_4__collectDeps(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; x_3 = l_Array_empty___closed__1; -x_4 = l_Lean_Meta_collectDepsAux___main(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main(x_1, x_2, x_3); x_5 = lean_array_get_size(x_4); x_6 = lean_unsigned_to_nat(1u); x_7 = lean_nat_sub(x_5, x_6); lean_dec(x_5); x_8 = lean_unsigned_to_nat(0u); -x_9 = l_Array_qsortAux___main___at_Lean_Meta_collectDeps___spec__1(x_4, x_8, x_7); +x_9 = l_Array_qsortAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__1(x_4, x_8, x_7); lean_dec(x_7); return x_9; } } -lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at_Lean_Meta_collectDeps___spec__2(x_1, x_2, x_3, x_4, x_5); +x_6 = l___private_Init_Data_Array_QSort_1__partitionAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__2(x_1, x_2, x_3, x_4, x_5); lean_dec(x_2); lean_dec(x_1); return x_6; } } -lean_object* l_Array_qsortAux___main___at_Lean_Meta_collectDeps___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Array_qsortAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Array_qsortAux___main___at_Lean_Meta_collectDeps___spec__1(x_1, x_2, x_3); +x_4 = l_Array_qsortAux___main___at___private_Init_Lean_Meta_FunInfo_4__collectDeps___spec__1(x_1, x_2, x_3); lean_dec(x_3); return x_4; } } -lean_object* l_Lean_Meta_collectDeps___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Init_Lean_Meta_FunInfo_4__collectDeps___boxed(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; -x_3 = l_Lean_Meta_collectDeps(x_1, x_2); +x_3 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_2); lean_dec(x_2); lean_dec(x_1); return x_3; } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; uint8_t x_5; @@ -2410,7 +2424,7 @@ x_18 = lean_nat_add(x_2, x_17); if (x_15 == 0) { uint8_t x_19; -x_19 = l_Array_contains___at_Lean_Meta_collectDepsAux___main___spec__2(x_1, x_2); +x_19 = l_Array_contains___at___private_Init_Lean_Meta_FunInfo_3__collectDepsAux___main___spec__2(x_1, x_2); if (x_19 == 0) { lean_object* x_20; lean_object* x_21; @@ -2456,7 +2470,7 @@ goto _start; } } } -lean_object* l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; lean_object* x_4; uint8_t x_5; @@ -2467,7 +2481,7 @@ lean_dec(x_3); if (x_5 == 0) { lean_object* x_6; -x_6 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___spec__1(x_2, x_4, x_1); +x_6 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___spec__1(x_2, x_4, x_1); return x_6; } else @@ -2476,174 +2490,170 @@ return x_1; } } } -lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___spec__1(x_1, x_2, x_3); +x_4 = l_Array_umapMAux___main___at___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___spec__1(x_1, x_2, x_3); lean_dec(x_1); return x_4; } } -lean_object* l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps___boxed(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; -x_3 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_1, x_2); +x_3 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_1, x_2); lean_dec(x_2); return x_3; } } -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = l_Lean_Expr_Inhabited; -x_8 = lean_array_get(x_7, x_1, x_3); +lean_object* x_7; uint8_t x_8; +x_7 = lean_unsigned_to_nat(0u); +x_8 = lean_nat_dec_eq(x_3, x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_9 = lean_unsigned_to_nat(1u); +x_10 = lean_nat_sub(x_3, x_9); +lean_dec(x_3); +x_11 = lean_nat_sub(x_2, x_10); +x_12 = lean_nat_sub(x_11, x_9); +lean_dec(x_11); +x_13 = l_Lean_Expr_Inhabited; +x_14 = lean_array_get(x_13, x_1, x_12); +lean_dec(x_12); lean_inc(x_5); -x_9 = l_Lean_Meta_getFVarLocalDecl(x_8, x_5, x_6); -lean_dec(x_8); -if (lean_obj_tag(x_9) == 0) +x_15 = l_Lean_Meta_getFVarLocalDecl(x_14, x_5, x_6); +lean_dec(x_14); +if (lean_obj_tag(x_15) == 0) { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -x_11 = lean_ctor_get(x_9, 1); -lean_inc(x_11); -lean_dec(x_9); -x_12 = l_Lean_LocalDecl_type(x_10); -lean_inc(x_12); -x_13 = l_Lean_Meta_isPropAux(x_2, x_12, x_5, x_11); -if (lean_obj_tag(x_13) == 0) -{ -uint8_t x_14; -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; uint8_t x_19; uint8_t x_20; uint8_t x_21; uint8_t x_22; uint8_t x_23; lean_object* x_24; uint8_t x_25; lean_object* x_26; -x_15 = lean_ctor_get(x_13, 0); -x_16 = l_Lean_Meta_collectDeps(x_1, x_12); -lean_dec(x_12); -x_17 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_4, x_16); -x_18 = l_Lean_LocalDecl_binderInfo(x_10); -lean_dec(x_10); -x_19 = 1; -x_20 = l_Lean_BinderInfo_beq(x_18, x_19); -x_21 = 3; -x_22 = l_Lean_BinderInfo_beq(x_18, x_21); -x_23 = 0; -x_24 = lean_alloc_ctor(0, 1, 4); -lean_ctor_set(x_24, 0, x_16); -lean_ctor_set_uint8(x_24, sizeof(void*)*1, x_20); -lean_ctor_set_uint8(x_24, sizeof(void*)*1 + 1, x_22); -x_25 = lean_unbox(x_15); +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); lean_dec(x_15); -lean_ctor_set_uint8(x_24, sizeof(void*)*1 + 2, x_25); -lean_ctor_set_uint8(x_24, sizeof(void*)*1 + 3, x_23); -x_26 = lean_array_push(x_17, x_24); -lean_ctor_set(x_13, 0, x_26); -return x_13; +x_18 = l_Lean_LocalDecl_type(x_16); +lean_inc(x_5); +lean_inc(x_18); +x_19 = l_Lean_Meta_isProp(x_18, x_5, x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; uint8_t x_27; uint8_t x_28; uint8_t x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_19, 1); +lean_inc(x_21); +lean_dec(x_19); +x_22 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_18); +lean_dec(x_18); +x_23 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_4, x_22); +x_24 = l_Lean_LocalDecl_binderInfo(x_16); +lean_dec(x_16); +x_25 = 1; +x_26 = l_Lean_BinderInfo_beq(x_24, x_25); +x_27 = 3; +x_28 = l_Lean_BinderInfo_beq(x_24, x_27); +x_29 = 0; +x_30 = lean_alloc_ctor(0, 1, 4); +lean_ctor_set(x_30, 0, x_22); +lean_ctor_set_uint8(x_30, sizeof(void*)*1, x_26); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 1, x_28); +x_31 = lean_unbox(x_20); +lean_dec(x_20); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 2, x_31); +lean_ctor_set_uint8(x_30, sizeof(void*)*1 + 3, x_29); +x_32 = lean_array_push(x_23, x_30); +x_3 = x_10; +x_4 = x_32; +x_6 = x_21; +goto _start; } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; uint8_t x_32; uint8_t x_33; uint8_t x_34; uint8_t x_35; uint8_t x_36; lean_object* x_37; uint8_t x_38; lean_object* x_39; lean_object* x_40; -x_27 = lean_ctor_get(x_13, 0); -x_28 = lean_ctor_get(x_13, 1); -lean_inc(x_28); -lean_inc(x_27); -lean_dec(x_13); -x_29 = l_Lean_Meta_collectDeps(x_1, x_12); -lean_dec(x_12); -x_30 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_4, x_29); -x_31 = l_Lean_LocalDecl_binderInfo(x_10); +uint8_t x_34; +lean_dec(x_18); +lean_dec(x_16); lean_dec(x_10); -x_32 = 1; -x_33 = l_Lean_BinderInfo_beq(x_31, x_32); -x_34 = 3; -x_35 = l_Lean_BinderInfo_beq(x_31, x_34); -x_36 = 0; -x_37 = lean_alloc_ctor(0, 1, 4); -lean_ctor_set(x_37, 0, x_29); -lean_ctor_set_uint8(x_37, sizeof(void*)*1, x_33); -lean_ctor_set_uint8(x_37, sizeof(void*)*1 + 1, x_35); -x_38 = lean_unbox(x_27); -lean_dec(x_27); -lean_ctor_set_uint8(x_37, sizeof(void*)*1 + 2, x_38); -lean_ctor_set_uint8(x_37, sizeof(void*)*1 + 3, x_36); -x_39 = lean_array_push(x_30, x_37); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_39); -lean_ctor_set(x_40, 1, x_28); -return x_40; -} -} -else -{ -uint8_t x_41; -lean_dec(x_12); -lean_dec(x_10); -lean_dec(x_4); -x_41 = !lean_is_exclusive(x_13); -if (x_41 == 0) -{ -return x_13; -} -else -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_42 = lean_ctor_get(x_13, 0); -x_43 = lean_ctor_get(x_13, 1); -lean_inc(x_43); -lean_inc(x_42); -lean_dec(x_13); -x_44 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_44, 0, x_42); -lean_ctor_set(x_44, 1, x_43); -return x_44; -} -} -} -else -{ -uint8_t x_45; lean_dec(x_5); lean_dec(x_4); -lean_dec(x_2); -x_45 = !lean_is_exclusive(x_9); -if (x_45 == 0) +x_34 = !lean_is_exclusive(x_19); +if (x_34 == 0) { -return x_9; +return x_19; } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_46 = lean_ctor_get(x_9, 0); -x_47 = lean_ctor_get(x_9, 1); -lean_inc(x_47); -lean_inc(x_46); -lean_dec(x_9); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_46); -lean_ctor_set(x_48, 1, x_47); -return x_48; +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_19, 0); +x_36 = lean_ctor_get(x_19, 1); +lean_inc(x_36); +lean_inc(x_35); +lean_dec(x_19); +x_37 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_37, 0, x_35); +lean_ctor_set(x_37, 1, x_36); +return x_37; } } } +else +{ +uint8_t x_38; +lean_dec(x_10); +lean_dec(x_5); +lean_dec(x_4); +x_38 = !lean_is_exclusive(x_15); +if (x_38 == 0) +{ +return x_15; } -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_15, 0); +x_40 = lean_ctor_get(x_15, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_15); +x_41 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_41, 0, x_39); +lean_ctor_set(x_41, 1, x_40); +return x_41; +} +} +} +else +{ +lean_object* x_42; +lean_dec(x_5); +lean_dec(x_3); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_4); +lean_ctor_set(x_42, 1, x_6); +return x_42; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -lean_inc(x_3); -x_7 = lean_alloc_closure((void*)(l_Lean_Meta_getFunInfoAuxAux___lambda__1___boxed), 6, 2); -lean_closure_set(x_7, 0, x_3); -lean_closure_set(x_7, 1, x_1); -x_8 = lean_array_get_size(x_3); -x_9 = l_Array_empty___closed__1; -lean_inc(x_8); -x_10 = l_Nat_foldMAux___main___rarg(x_2, x_7, x_8, x_8, x_9); +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_4); +x_9 = lean_nat_dec_lt(x_5, x_8); lean_dec(x_8); -x_11 = lean_apply_2(x_10, x_5, x_6); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_5); +x_10 = l_Array_empty___closed__1; +lean_inc(x_2); +x_11 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1(x_1, x_2, x_2, x_10, x_6, x_7); +lean_dec(x_2); if (lean_obj_tag(x_11) == 0) { uint8_t x_12; @@ -2652,9 +2662,8 @@ if (x_12 == 0) { lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; x_13 = lean_ctor_get(x_11, 0); -x_14 = l_Lean_Meta_collectDeps(x_3, x_4); -lean_dec(x_3); -x_15 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_13, x_14); +x_14 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_3); +x_15 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_13, x_14); x_16 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_16, 0, x_15); lean_ctor_set(x_16, 1, x_14); @@ -2669,9 +2678,8 @@ x_18 = lean_ctor_get(x_11, 1); lean_inc(x_18); lean_inc(x_17); lean_dec(x_11); -x_19 = l_Lean_Meta_collectDeps(x_3, x_4); -lean_dec(x_3); -x_20 = l___private_Init_Lean_Meta_FunInfo_2__updateHasFwdDeps(x_17, x_19); +x_19 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_3); +x_20 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_17, x_19); x_21 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_21, 0, x_20); lean_ctor_set(x_21, 1, x_19); @@ -2684,7 +2692,6 @@ return x_22; else { uint8_t x_23; -lean_dec(x_3); x_23 = !lean_is_exclusive(x_11); if (x_23 == 0) { @@ -2705,320 +2712,2221 @@ return x_26; } } } +else +{ +lean_object* x_27; lean_object* x_28; +x_27 = lean_array_fget(x_4, x_5); +lean_inc(x_6); +x_28 = l_Lean_Meta_getFVarLocalDecl(x_27, x_6, x_7); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = l_Lean_LocalDecl_type(x_29); +lean_dec(x_29); +lean_inc(x_6); +lean_inc(x_31); +x_32 = l_Lean_Meta_isClassQuick___main(x_31, x_6, x_30); +if (lean_obj_tag(x_32) == 0) +{ +lean_object* x_33; +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +switch (lean_obj_tag(x_33)) { +case 0: +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +lean_dec(x_31); +lean_dec(x_27); +x_34 = lean_ctor_get(x_32, 1); +lean_inc(x_34); +lean_dec(x_32); +x_35 = lean_unsigned_to_nat(1u); +x_36 = lean_nat_add(x_5, x_35); +lean_dec(x_5); +x_5 = x_36; +x_7 = x_34; +goto _start; } -lean_object* l_Lean_Meta_getFunInfoAuxAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +case 1: +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; +lean_dec(x_31); +x_38 = lean_ctor_get(x_32, 1); +lean_inc(x_38); +lean_dec(x_32); +x_39 = lean_ctor_get(x_33, 0); +lean_inc(x_39); +lean_dec(x_33); +x_40 = lean_unsigned_to_nat(1u); +x_41 = lean_nat_add(x_5, x_40); +lean_dec(x_5); +x_42 = !lean_is_exclusive(x_6); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_43 = lean_ctor_get(x_6, 2); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_27); +x_45 = lean_array_push(x_43, x_44); +lean_ctor_set(x_6, 2, x_45); +x_5 = x_41; +x_7 = x_38; +goto _start; +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_47 = lean_ctor_get(x_6, 0); +x_48 = lean_ctor_get(x_6, 1); +x_49 = lean_ctor_get(x_6, 2); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_dec(x_6); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_39); +lean_ctor_set(x_50, 1, x_27); +x_51 = lean_array_push(x_49, x_50); +x_52 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_48); +lean_ctor_set(x_52, 2, x_51); +x_5 = x_41; +x_6 = x_52; +x_7 = x_38; +goto _start; +} +} +default: +{ +lean_object* x_54; lean_object* x_55; +x_54 = lean_ctor_get(x_32, 1); +lean_inc(x_54); +lean_dec(x_32); +lean_inc(x_6); +x_55 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_54); +if (lean_obj_tag(x_55) == 0) +{ +lean_object* x_56; +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; +lean_dec(x_27); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = lean_unsigned_to_nat(1u); +x_59 = lean_nat_add(x_5, x_58); +lean_dec(x_5); +x_5 = x_59; +x_7 = x_57; +goto _start; +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; +x_61 = lean_ctor_get(x_55, 1); +lean_inc(x_61); +lean_dec(x_55); +x_62 = lean_ctor_get(x_56, 0); +lean_inc(x_62); +lean_dec(x_56); +x_63 = lean_unsigned_to_nat(1u); +x_64 = lean_nat_add(x_5, x_63); +lean_dec(x_5); +x_65 = !lean_is_exclusive(x_6); +if (x_65 == 0) +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_66 = lean_ctor_get(x_6, 2); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_27); +x_68 = lean_array_push(x_66, x_67); +lean_ctor_set(x_6, 2, x_68); +x_5 = x_64; +x_7 = x_61; +goto _start; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_70 = lean_ctor_get(x_6, 0); +x_71 = lean_ctor_get(x_6, 1); +x_72 = lean_ctor_get(x_6, 2); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_6); +x_73 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_73, 0, x_62); +lean_ctor_set(x_73, 1, x_27); +x_74 = lean_array_push(x_72, x_73); +x_75 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_75, 0, x_70); +lean_ctor_set(x_75, 1, x_71); +lean_ctor_set(x_75, 2, x_74); +x_5 = x_64; +x_6 = x_75; +x_7 = x_61; +goto _start; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_27); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_55); +if (x_77 == 0) +{ +return x_55; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_55, 0); +x_79 = lean_ctor_get(x_55, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_55); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_31); +lean_dec(x_27); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_81 = !lean_is_exclusive(x_32); +if (x_81 == 0) +{ +return x_32; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_32, 0); +x_83 = lean_ctor_get(x_32, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_32); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +else +{ +uint8_t x_85; +lean_dec(x_27); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_85 = !lean_is_exclusive(x_28); +if (x_85 == 0) +{ +return x_28; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_28, 0); +x_87 = lean_ctor_get(x_28, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_28); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { -lean_object* x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_6 = lean_ctor_get(x_4, 0); -lean_inc(x_6); -x_7 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 4); +uint8_t x_10; +x_10 = l_Lean_Expr_isForall(x_7); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +lean_dec(x_7); lean_dec(x_6); -x_8 = lean_ctor_get(x_5, 2); +lean_dec(x_5); +x_11 = l_Array_empty___closed__1; +lean_inc(x_2); +x_12 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1(x_1, x_2, x_2, x_11, x_8, x_9); +lean_dec(x_2); +if (lean_obj_tag(x_12) == 0) +{ +uint8_t x_13; +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_14 = lean_ctor_get(x_12, 0); +x_15 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_3); +lean_dec(x_1); +x_16 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_14, x_15); +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_16); +lean_ctor_set(x_17, 1, x_15); +lean_ctor_set(x_12, 0, x_17); +return x_12; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_18 = lean_ctor_get(x_12, 0); +x_19 = lean_ctor_get(x_12, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_12); +x_20 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_3); +lean_dec(x_1); +x_21 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_18, x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_20); +x_23 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_23, 0, x_22); +lean_ctor_set(x_23, 1, x_19); +return x_23; +} +} +else +{ +uint8_t x_24; +lean_dec(x_1); +x_24 = !lean_is_exclusive(x_12); +if (x_24 == 0) +{ +return x_12; +} +else +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_12, 0); +x_26 = lean_ctor_get(x_12, 1); +lean_inc(x_26); +lean_inc(x_25); +lean_dec(x_12); +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; +} +} +} +else +{ +lean_object* x_28; +x_28 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__3(x_4, x_5, x_6, x_1, x_2, x_7, x_8, x_9); +return x_28; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; lean_inc(x_8); -x_9 = lean_ctor_get(x_8, 1); -lean_inc(x_9); -lean_dec(x_8); +x_13 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_13, 0, x_8); +x_14 = lean_box(x_1); lean_inc(x_3); lean_inc(x_2); -x_10 = lean_alloc_ctor(0, 2, 1); -lean_ctor_set(x_10, 0, x_2); -lean_ctor_set(x_10, 1, x_3); -lean_ctor_set_uint8(x_10, sizeof(void*)*2, x_7); -x_11 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__2; -x_12 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__1; -lean_inc(x_10); -x_13 = l_PersistentHashMap_find___rarg(x_11, x_12, x_9, x_10); -lean_dec(x_9); -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; -lean_inc(x_1); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 1); -lean_closure_set(x_14, 0, x_1); +lean_inc(x_8); +lean_inc(x_7); lean_inc(x_4); -lean_inc(x_14); -x_15 = l_Lean_Meta_inferTypeAuxAux___main(x_14, x_2, x_4, x_5); -if (lean_obj_tag(x_15) == 0) +x_15 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___lambda__1___boxed), 9, 6); +lean_closure_set(x_15, 0, x_4); +lean_closure_set(x_15, 1, x_7); +lean_closure_set(x_15, 2, x_8); +lean_closure_set(x_15, 3, x_14); +lean_closure_set(x_15, 4, x_2); +lean_closure_set(x_15, 5, x_3); +x_16 = lean_array_get_size(x_9); +x_17 = lean_nat_dec_lt(x_10, x_16); +lean_dec(x_16); +if (x_17 == 0) { -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_16 = lean_ctor_get(x_15, 0); -lean_inc(x_16); -x_17 = lean_ctor_get(x_15, 1); -lean_inc(x_17); +lean_object* x_18; +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_18 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_13, x_15, x_11, x_12); +return x_18; +} +else +{ +lean_object* x_19; lean_object* x_20; lean_dec(x_15); -x_18 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_19 = lean_alloc_closure((void*)(l_Lean_Meta_getFunInfoAuxAux___lambda__2___boxed), 6, 2); -lean_closure_set(x_19, 0, x_1); -lean_closure_set(x_19, 1, x_18); -x_20 = l_Lean_Meta_forallBoundedTelescope___rarg(x_14, x_16, x_3, x_19, x_4, x_17); +lean_dec(x_13); +x_19 = lean_array_fget(x_9, x_10); +lean_inc(x_11); +x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_11, x_12); if (lean_obj_tag(x_20) == 0) { -lean_object* x_21; lean_object* x_22; uint8_t x_23; -x_21 = lean_ctor_get(x_20, 1); +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_21 = lean_ctor_get(x_20, 0); lean_inc(x_21); -x_22 = lean_ctor_get(x_21, 2); +x_22 = lean_ctor_get(x_20, 1); lean_inc(x_22); -x_23 = !lean_is_exclusive(x_20); +lean_dec(x_20); +x_23 = l_Lean_LocalDecl_type(x_21); +lean_dec(x_21); +lean_inc(x_11); +lean_inc(x_23); +x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_11, x_22); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +switch (lean_obj_tag(x_25)) { +case 0: +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +lean_dec(x_23); +lean_dec(x_19); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_10, x_27); +lean_dec(x_10); +x_10 = x_28; +x_12 = x_26; +goto _start; +} +case 1: +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_dec(x_23); +x_30 = lean_ctor_get(x_24, 1); +lean_inc(x_30); +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 0); +lean_inc(x_31); +lean_dec(x_25); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_10, x_32); +lean_dec(x_10); +x_34 = !lean_is_exclusive(x_11); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_11, 2); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_31); +lean_ctor_set(x_36, 1, x_19); +x_37 = lean_array_push(x_35, x_36); +lean_ctor_set(x_11, 2, x_37); +x_10 = x_33; +x_12 = x_30; +goto _start; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_39 = lean_ctor_get(x_11, 0); +x_40 = lean_ctor_get(x_11, 1); +x_41 = lean_ctor_get(x_11, 2); +lean_inc(x_41); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_11); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_31); +lean_ctor_set(x_42, 1, x_19); +x_43 = lean_array_push(x_41, x_42); +x_44 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_40); +lean_ctor_set(x_44, 2, x_43); +x_10 = x_33; +x_11 = x_44; +x_12 = x_30; +goto _start; +} +} +default: +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_24, 1); +lean_inc(x_46); +lean_dec(x_24); +lean_inc(x_11); +x_47 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_46); +if (lean_obj_tag(x_47) == 0) +{ +lean_object* x_48; +x_48 = lean_ctor_get(x_47, 0); +lean_inc(x_48); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_19); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +lean_dec(x_47); +x_50 = lean_unsigned_to_nat(1u); +x_51 = lean_nat_add(x_10, x_50); +lean_dec(x_10); +x_10 = x_51; +x_12 = x_49; +goto _start; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; +x_53 = lean_ctor_get(x_47, 1); +lean_inc(x_53); +lean_dec(x_47); +x_54 = lean_ctor_get(x_48, 0); +lean_inc(x_54); +lean_dec(x_48); +x_55 = lean_unsigned_to_nat(1u); +x_56 = lean_nat_add(x_10, x_55); +lean_dec(x_10); +x_57 = !lean_is_exclusive(x_11); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_11, 2); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_19); +x_60 = lean_array_push(x_58, x_59); +lean_ctor_set(x_11, 2, x_60); +x_10 = x_56; +x_12 = x_53; +goto _start; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_62 = lean_ctor_get(x_11, 0); +x_63 = lean_ctor_get(x_11, 1); +x_64 = lean_ctor_get(x_11, 2); +lean_inc(x_64); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_11); +x_65 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_65, 0, x_54); +lean_ctor_set(x_65, 1, x_19); +x_66 = lean_array_push(x_64, x_65); +x_67 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_63); +lean_ctor_set(x_67, 2, x_66); +x_10 = x_56; +x_11 = x_67; +x_12 = x_53; +goto _start; +} +} +} +else +{ +uint8_t x_69; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_69 = !lean_is_exclusive(x_47); +if (x_69 == 0) +{ +return x_47; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_47, 0); +x_71 = lean_ctor_get(x_47, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_47); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_23); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_73 = !lean_is_exclusive(x_24); +if (x_73 == 0) +{ +return x_24; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_24, 0); +x_75 = lean_ctor_get(x_24, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_24); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_20); +if (x_77 == 0) +{ +return x_20; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_20, 0); +x_79 = lean_ctor_get(x_20, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_20); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_4); +x_9 = lean_nat_dec_lt(x_5, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_5); +x_10 = l_Array_empty___closed__1; +lean_inc(x_2); +x_11 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1(x_1, x_2, x_2, x_10, x_6, x_7); +lean_dec(x_2); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); +x_14 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_3); +x_15 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_13, x_14); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_14); +lean_ctor_set(x_11, 0, x_16); +return x_11; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_11); +x_19 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_1, x_3); +x_20 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_17, x_19); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_20); +lean_ctor_set(x_21, 1, x_19); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; +} +} +else +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_11); if (x_23 == 0) { -lean_object* x_24; lean_object* x_25; uint8_t x_26; -x_24 = lean_ctor_get(x_20, 0); -x_25 = lean_ctor_get(x_20, 1); -lean_dec(x_25); -x_26 = !lean_is_exclusive(x_21); -if (x_26 == 0) -{ -lean_object* x_27; uint8_t x_28; -x_27 = lean_ctor_get(x_21, 2); -lean_dec(x_27); -x_28 = !lean_is_exclusive(x_22); -if (x_28 == 0) -{ -lean_object* x_29; lean_object* x_30; -x_29 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -x_30 = l_PersistentHashMap_insert___rarg(x_11, x_12, x_29, x_10, x_24); -lean_ctor_set(x_22, 1, x_30); -return x_20; +return x_11; } else { -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_31 = lean_ctor_get(x_22, 0); -x_32 = lean_ctor_get(x_22, 1); -lean_inc(x_32); +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +else +{ +lean_object* x_27; lean_object* x_28; +x_27 = lean_array_fget(x_4, x_5); +lean_inc(x_6); +x_28 = l_Lean_Meta_getFVarLocalDecl(x_27, x_6, x_7); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = l_Lean_LocalDecl_type(x_29); +lean_dec(x_29); +lean_inc(x_6); lean_inc(x_31); -lean_dec(x_22); -lean_inc(x_24); -x_33 = l_PersistentHashMap_insert___rarg(x_11, x_12, x_32, x_10, x_24); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_31); -lean_ctor_set(x_34, 1, x_33); -lean_ctor_set(x_21, 2, x_34); -return x_20; +x_32 = l_Lean_Meta_isClassQuick___main(x_31, x_6, x_30); +if (lean_obj_tag(x_32) == 0) +{ +lean_object* x_33; +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +switch (lean_obj_tag(x_33)) { +case 0: +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; +lean_dec(x_31); +lean_dec(x_27); +x_34 = lean_ctor_get(x_32, 1); +lean_inc(x_34); +lean_dec(x_32); +x_35 = lean_unsigned_to_nat(1u); +x_36 = lean_nat_add(x_5, x_35); +lean_dec(x_5); +x_5 = x_36; +x_7 = x_34; +goto _start; +} +case 1: +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; +lean_dec(x_31); +x_38 = lean_ctor_get(x_32, 1); +lean_inc(x_38); +lean_dec(x_32); +x_39 = lean_ctor_get(x_33, 0); +lean_inc(x_39); +lean_dec(x_33); +x_40 = lean_unsigned_to_nat(1u); +x_41 = lean_nat_add(x_5, x_40); +lean_dec(x_5); +x_42 = !lean_is_exclusive(x_6); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; +x_43 = lean_ctor_get(x_6, 2); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_39); +lean_ctor_set(x_44, 1, x_27); +x_45 = lean_array_push(x_43, x_44); +lean_ctor_set(x_6, 2, x_45); +x_5 = x_41; +x_7 = x_38; +goto _start; +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_47 = lean_ctor_get(x_6, 0); +x_48 = lean_ctor_get(x_6, 1); +x_49 = lean_ctor_get(x_6, 2); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_dec(x_6); +x_50 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_50, 0, x_39); +lean_ctor_set(x_50, 1, x_27); +x_51 = lean_array_push(x_49, x_50); +x_52 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_52, 0, x_47); +lean_ctor_set(x_52, 1, x_48); +lean_ctor_set(x_52, 2, x_51); +x_5 = x_41; +x_6 = x_52; +x_7 = x_38; +goto _start; +} +} +default: +{ +lean_object* x_54; lean_object* x_55; +x_54 = lean_ctor_get(x_32, 1); +lean_inc(x_54); +lean_dec(x_32); +lean_inc(x_6); +x_55 = l_Lean_Meta_isClassExpensive___main(x_31, x_6, x_54); +if (lean_obj_tag(x_55) == 0) +{ +lean_object* x_56; +x_56 = lean_ctor_get(x_55, 0); +lean_inc(x_56); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; +lean_dec(x_27); +x_57 = lean_ctor_get(x_55, 1); +lean_inc(x_57); +lean_dec(x_55); +x_58 = lean_unsigned_to_nat(1u); +x_59 = lean_nat_add(x_5, x_58); +lean_dec(x_5); +x_5 = x_59; +x_7 = x_57; +goto _start; +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; +x_61 = lean_ctor_get(x_55, 1); +lean_inc(x_61); +lean_dec(x_55); +x_62 = lean_ctor_get(x_56, 0); +lean_inc(x_62); +lean_dec(x_56); +x_63 = lean_unsigned_to_nat(1u); +x_64 = lean_nat_add(x_5, x_63); +lean_dec(x_5); +x_65 = !lean_is_exclusive(x_6); +if (x_65 == 0) +{ +lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_66 = lean_ctor_get(x_6, 2); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_27); +x_68 = lean_array_push(x_66, x_67); +lean_ctor_set(x_6, 2, x_68); +x_5 = x_64; +x_7 = x_61; +goto _start; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_70 = lean_ctor_get(x_6, 0); +x_71 = lean_ctor_get(x_6, 1); +x_72 = lean_ctor_get(x_6, 2); +lean_inc(x_72); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_6); +x_73 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_73, 0, x_62); +lean_ctor_set(x_73, 1, x_27); +x_74 = lean_array_push(x_72, x_73); +x_75 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_75, 0, x_70); +lean_ctor_set(x_75, 1, x_71); +lean_ctor_set(x_75, 2, x_74); +x_5 = x_64; +x_6 = x_75; +x_7 = x_61; +goto _start; +} } } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_35 = lean_ctor_get(x_21, 0); -x_36 = lean_ctor_get(x_21, 1); -x_37 = lean_ctor_get(x_21, 3); -x_38 = lean_ctor_get(x_21, 4); -x_39 = lean_ctor_get(x_21, 5); +uint8_t x_77; +lean_dec(x_27); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_55); +if (x_77 == 0) +{ +return x_55; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_55, 0); +x_79 = lean_ctor_get(x_55, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_55); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_31); +lean_dec(x_27); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_81 = !lean_is_exclusive(x_32); +if (x_81 == 0) +{ +return x_32; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_32, 0); +x_83 = lean_ctor_get(x_32, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_32); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +else +{ +uint8_t x_85; +lean_dec(x_27); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_85 = !lean_is_exclusive(x_28); +if (x_85 == 0) +{ +return x_28; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_28, 0); +x_87 = lean_ctor_get(x_28, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_28); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__3(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +if (lean_obj_tag(x_6) == 7) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_22 = lean_ctor_get(x_6, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_6, 1); +lean_inc(x_23); +x_24 = lean_ctor_get(x_6, 2); +lean_inc(x_24); +x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); +lean_dec(x_6); +x_26 = lean_array_get_size(x_4); +lean_inc(x_4); +x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); +lean_dec(x_26); +lean_dec(x_23); +x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = (uint8_t)((x_25 << 24) >> 61); +lean_inc(x_29); +x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); +x_33 = l_Lean_mkFVar(x_29); +x_34 = lean_array_push(x_4, x_33); +if (lean_obj_tag(x_2) == 0) +{ +x_3 = x_32; +x_4 = x_34; +x_6 = x_24; +x_8 = x_30; +goto _start; +} +else +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_2, 0); +lean_inc(x_36); +x_37 = lean_array_get_size(x_34); +x_38 = lean_nat_dec_lt(x_37, x_36); +lean_dec(x_36); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +lean_dec(x_2); +lean_inc(x_34); +x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); +lean_dec(x_24); +x_40 = !lean_is_exclusive(x_7); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_7, 1); +lean_dec(x_41); +lean_ctor_set(x_7, 1, x_32); +x_42 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_34, x_37, x_39, x_34, x_5, x_7, x_30); +lean_dec(x_39); +lean_dec(x_34); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_7, 0); +x_44 = lean_ctor_get(x_7, 2); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_7); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_32); +lean_ctor_set(x_45, 2, x_44); +x_46 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_34, x_37, x_39, x_34, x_5, x_45, x_30); +lean_dec(x_39); +lean_dec(x_34); +return x_46; +} +} +else +{ +lean_dec(x_37); +x_3 = x_32; +x_4 = x_34; +x_6 = x_24; +x_8 = x_30; +goto _start; +} +} +} +else +{ +lean_object* x_48; +x_48 = lean_box(0); +x_9 = x_48; +goto block_21; +} +block_21: +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +lean_dec(x_9); +x_10 = lean_array_get_size(x_4); +lean_inc(x_4); +x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); +x_12 = !lean_is_exclusive(x_7); +if (x_12 == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_7, 1); +lean_dec(x_13); +lean_inc(x_3); +lean_ctor_set(x_7, 1, x_3); +if (x_1 == 0) +{ +lean_object* x_14; +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_4, x_10, x_11, x_4, x_5, x_7, x_8); +lean_dec(x_11); +lean_dec(x_4); +return x_14; +} +else +{ +lean_object* x_15; +lean_inc(x_5); +lean_inc(x_4); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_7, 0); +x_17 = lean_ctor_get(x_7, 2); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_7); +lean_inc(x_3); +x_18 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_3); +lean_ctor_set(x_18, 2, x_17); +if (x_1 == 0) +{ +lean_object* x_19; +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_19 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_4, x_10, x_11, x_4, x_5, x_18, x_8); +lean_dec(x_11); +lean_dec(x_4); +return x_19; +} +else +{ +lean_object* x_20; +lean_inc(x_5); +lean_inc(x_4); +x_20 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_20; +} +} +} +} +} +lean_object* _init_l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2___closed__1() { +_start: +{ +lean_object* x_1; lean_object* x_2; +x_1 = l_Array_empty___closed__1; +x_2 = lean_array_get_size(x_1); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +lean_inc(x_1); +x_5 = l_Lean_Meta_whnf(x_1, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +x_8 = l_Lean_Expr_isForall(x_6); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; +lean_dec(x_6); +lean_dec(x_2); +x_9 = l_Array_empty___closed__1; +x_10 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2___closed__1; +x_11 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1(x_9, x_10, x_10, x_9, x_3, x_7); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); +x_14 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_9, x_1); +lean_dec(x_1); +x_15 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_13, x_14); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_14); +lean_ctor_set(x_11, 0, x_16); +return x_11; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_11); +x_19 = l___private_Init_Lean_Meta_FunInfo_4__collectDeps(x_9, x_1); +lean_dec(x_1); +x_20 = l___private_Init_Lean_Meta_FunInfo_5__updateHasFwdDeps(x_17, x_19); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_20); +lean_ctor_set(x_21, 1, x_19); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; +} +} +else +{ +uint8_t x_23; +lean_dec(x_1); +x_23 = !lean_is_exclusive(x_11); +if (x_23 == 0) +{ +return x_11; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +else +{ +lean_object* x_27; lean_object* x_28; uint8_t x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +lean_dec(x_1); +x_27 = lean_ctor_get(x_7, 2); +lean_inc(x_27); +x_28 = lean_ctor_get(x_3, 1); +lean_inc(x_28); +x_29 = 1; +x_30 = l_Array_empty___closed__1; +x_31 = lean_unsigned_to_nat(0u); +x_32 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__3(x_29, x_2, x_28, x_30, x_31, x_6, x_3, x_7); +if (lean_obj_tag(x_32) == 0) +{ +uint8_t x_33; +x_33 = !lean_is_exclusive(x_32); +if (x_33 == 0) +{ +lean_object* x_34; uint8_t x_35; +x_34 = lean_ctor_get(x_32, 1); +x_35 = !lean_is_exclusive(x_34); +if (x_35 == 0) +{ +lean_object* x_36; +x_36 = lean_ctor_get(x_34, 2); +lean_dec(x_36); +lean_ctor_set(x_34, 2, x_27); +return x_32; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_37 = lean_ctor_get(x_34, 0); +x_38 = lean_ctor_get(x_34, 1); +x_39 = lean_ctor_get(x_34, 3); +x_40 = lean_ctor_get(x_34, 4); +x_41 = lean_ctor_get(x_34, 5); +lean_inc(x_41); +lean_inc(x_40); lean_inc(x_39); lean_inc(x_38); lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_dec(x_21); -x_40 = lean_ctor_get(x_22, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_22, 1); -lean_inc(x_41); -if (lean_is_exclusive(x_22)) { - lean_ctor_release(x_22, 0); - lean_ctor_release(x_22, 1); - x_42 = x_22; -} else { - lean_dec_ref(x_22); - x_42 = lean_box(0); -} -lean_inc(x_24); -x_43 = l_PersistentHashMap_insert___rarg(x_11, x_12, x_41, x_10, x_24); -if (lean_is_scalar(x_42)) { - x_44 = lean_alloc_ctor(0, 2, 0); -} else { - x_44 = x_42; -} -lean_ctor_set(x_44, 0, x_40); -lean_ctor_set(x_44, 1, x_43); -x_45 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_45, 0, x_35); -lean_ctor_set(x_45, 1, x_36); -lean_ctor_set(x_45, 2, x_44); -lean_ctor_set(x_45, 3, x_37); -lean_ctor_set(x_45, 4, x_38); -lean_ctor_set(x_45, 5, x_39); -lean_ctor_set(x_20, 1, x_45); -return x_20; +lean_dec(x_34); +x_42 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_38); +lean_ctor_set(x_42, 2, x_27); +lean_ctor_set(x_42, 3, x_39); +lean_ctor_set(x_42, 4, x_40); +lean_ctor_set(x_42, 5, x_41); +lean_ctor_set(x_32, 1, x_42); +return x_32; } } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_46 = lean_ctor_get(x_20, 0); +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_43 = lean_ctor_get(x_32, 1); +x_44 = lean_ctor_get(x_32, 0); +lean_inc(x_43); +lean_inc(x_44); +lean_dec(x_32); +x_45 = lean_ctor_get(x_43, 0); +lean_inc(x_45); +x_46 = lean_ctor_get(x_43, 1); lean_inc(x_46); -lean_dec(x_20); -x_47 = lean_ctor_get(x_21, 0); +x_47 = lean_ctor_get(x_43, 3); lean_inc(x_47); -x_48 = lean_ctor_get(x_21, 1); +x_48 = lean_ctor_get(x_43, 4); lean_inc(x_48); -x_49 = lean_ctor_get(x_21, 3); +x_49 = lean_ctor_get(x_43, 5); lean_inc(x_49); -x_50 = lean_ctor_get(x_21, 4); -lean_inc(x_50); -x_51 = lean_ctor_get(x_21, 5); -lean_inc(x_51); -if (lean_is_exclusive(x_21)) { - lean_ctor_release(x_21, 0); - lean_ctor_release(x_21, 1); - lean_ctor_release(x_21, 2); - lean_ctor_release(x_21, 3); - lean_ctor_release(x_21, 4); - lean_ctor_release(x_21, 5); - x_52 = x_21; +if (lean_is_exclusive(x_43)) { + lean_ctor_release(x_43, 0); + lean_ctor_release(x_43, 1); + lean_ctor_release(x_43, 2); + lean_ctor_release(x_43, 3); + lean_ctor_release(x_43, 4); + lean_ctor_release(x_43, 5); + x_50 = x_43; } else { - lean_dec_ref(x_21); - x_52 = lean_box(0); + lean_dec_ref(x_43); + x_50 = lean_box(0); } -x_53 = lean_ctor_get(x_22, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_22, 1); -lean_inc(x_54); -if (lean_is_exclusive(x_22)) { - lean_ctor_release(x_22, 0); - lean_ctor_release(x_22, 1); - x_55 = x_22; +if (lean_is_scalar(x_50)) { + x_51 = lean_alloc_ctor(0, 6, 0); } else { - lean_dec_ref(x_22); + x_51 = x_50; +} +lean_ctor_set(x_51, 0, x_45); +lean_ctor_set(x_51, 1, x_46); +lean_ctor_set(x_51, 2, x_27); +lean_ctor_set(x_51, 3, x_47); +lean_ctor_set(x_51, 4, x_48); +lean_ctor_set(x_51, 5, x_49); +x_52 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_52, 0, x_44); +lean_ctor_set(x_52, 1, x_51); +return x_52; +} +} +else +{ +uint8_t x_53; +x_53 = !lean_is_exclusive(x_32); +if (x_53 == 0) +{ +lean_object* x_54; uint8_t x_55; +x_54 = lean_ctor_get(x_32, 1); +x_55 = !lean_is_exclusive(x_54); +if (x_55 == 0) +{ +lean_object* x_56; +x_56 = lean_ctor_get(x_54, 2); +lean_dec(x_56); +lean_ctor_set(x_54, 2, x_27); +return x_32; +} +else +{ +lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_57 = lean_ctor_get(x_54, 0); +x_58 = lean_ctor_get(x_54, 1); +x_59 = lean_ctor_get(x_54, 3); +x_60 = lean_ctor_get(x_54, 4); +x_61 = lean_ctor_get(x_54, 5); +lean_inc(x_61); +lean_inc(x_60); +lean_inc(x_59); +lean_inc(x_58); +lean_inc(x_57); +lean_dec(x_54); +x_62 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_62, 0, x_57); +lean_ctor_set(x_62, 1, x_58); +lean_ctor_set(x_62, 2, x_27); +lean_ctor_set(x_62, 3, x_59); +lean_ctor_set(x_62, 4, x_60); +lean_ctor_set(x_62, 5, x_61); +lean_ctor_set(x_32, 1, x_62); +return x_32; +} +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_63 = lean_ctor_get(x_32, 1); +x_64 = lean_ctor_get(x_32, 0); +lean_inc(x_63); +lean_inc(x_64); +lean_dec(x_32); +x_65 = lean_ctor_get(x_63, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_63, 1); +lean_inc(x_66); +x_67 = lean_ctor_get(x_63, 3); +lean_inc(x_67); +x_68 = lean_ctor_get(x_63, 4); +lean_inc(x_68); +x_69 = lean_ctor_get(x_63, 5); +lean_inc(x_69); +if (lean_is_exclusive(x_63)) { + lean_ctor_release(x_63, 0); + lean_ctor_release(x_63, 1); + lean_ctor_release(x_63, 2); + lean_ctor_release(x_63, 3); + lean_ctor_release(x_63, 4); + lean_ctor_release(x_63, 5); + x_70 = x_63; +} else { + lean_dec_ref(x_63); + x_70 = lean_box(0); +} +if (lean_is_scalar(x_70)) { + x_71 = lean_alloc_ctor(0, 6, 0); +} else { + x_71 = x_70; +} +lean_ctor_set(x_71, 0, x_65); +lean_ctor_set(x_71, 1, x_66); +lean_ctor_set(x_71, 2, x_27); +lean_ctor_set(x_71, 3, x_67); +lean_ctor_set(x_71, 4, x_68); +lean_ctor_set(x_71, 5, x_69); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_64); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_73 = !lean_is_exclusive(x_5); +if (x_73 == 0) +{ +return x_5; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_5, 0); +x_75 = lean_ctor_get(x_5, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_5); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_5 = lean_ctor_get(x_3, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_3, 1); +lean_inc(x_6); +x_7 = lean_ctor_get(x_3, 2); +lean_inc(x_7); +x_8 = !lean_is_exclusive(x_5); +if (x_8 == 0) +{ +lean_object* x_9; uint8_t x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_9 = lean_ctor_get(x_5, 0); +x_10 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 5); +x_11 = lean_ctor_get(x_4, 2); +lean_inc(x_11); +x_12 = lean_ctor_get(x_11, 1); +lean_inc(x_12); +lean_dec(x_11); +lean_inc(x_2); +lean_inc(x_1); +x_13 = lean_alloc_ctor(0, 2, 1); +lean_ctor_set(x_13, 0, x_1); +lean_ctor_set(x_13, 1, x_2); +lean_ctor_set_uint8(x_13, sizeof(void*)*2, x_10); +x_14 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(x_12, x_13); +lean_dec(x_12); +if (lean_obj_tag(x_14) == 0) +{ +lean_object* x_15; uint8_t x_16; +lean_inc(x_3); +x_15 = l_Lean_Meta_inferType(x_1, x_3, x_4); +x_16 = !lean_is_exclusive(x_3); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_3, 2); +lean_dec(x_17); +x_18 = lean_ctor_get(x_3, 1); +lean_dec(x_18); +x_19 = lean_ctor_get(x_3, 0); +lean_dec(x_19); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_20; lean_object* x_21; uint8_t x_22; lean_object* x_23; +x_20 = lean_ctor_get(x_15, 0); +lean_inc(x_20); +x_21 = lean_ctor_get(x_15, 1); +lean_inc(x_21); +lean_dec(x_15); +x_22 = 1; +lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 5, x_22); +x_23 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_20, x_2, x_3, x_21); +if (lean_obj_tag(x_23) == 0) +{ +lean_object* x_24; lean_object* x_25; uint8_t x_26; +x_24 = lean_ctor_get(x_23, 1); +lean_inc(x_24); +x_25 = lean_ctor_get(x_24, 2); +lean_inc(x_25); +x_26 = !lean_is_exclusive(x_23); +if (x_26 == 0) +{ +lean_object* x_27; lean_object* x_28; uint8_t x_29; +x_27 = lean_ctor_get(x_23, 0); +x_28 = lean_ctor_get(x_23, 1); +lean_dec(x_28); +x_29 = !lean_is_exclusive(x_24); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_24, 2); +lean_dec(x_30); +x_31 = !lean_is_exclusive(x_25); +if (x_31 == 0) +{ +lean_object* x_32; lean_object* x_33; +x_32 = lean_ctor_get(x_25, 1); +lean_inc(x_27); +x_33 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_32, x_13, x_27); +lean_ctor_set(x_25, 1, x_33); +return x_23; +} +else +{ +lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_34 = lean_ctor_get(x_25, 0); +x_35 = lean_ctor_get(x_25, 1); +lean_inc(x_35); +lean_inc(x_34); +lean_dec(x_25); +lean_inc(x_27); +x_36 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_35, x_13, x_27); +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_34); +lean_ctor_set(x_37, 1, x_36); +lean_ctor_set(x_24, 2, x_37); +return x_23; +} +} +else +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_38 = lean_ctor_get(x_24, 0); +x_39 = lean_ctor_get(x_24, 1); +x_40 = lean_ctor_get(x_24, 3); +x_41 = lean_ctor_get(x_24, 4); +x_42 = lean_ctor_get(x_24, 5); +lean_inc(x_42); +lean_inc(x_41); +lean_inc(x_40); +lean_inc(x_39); +lean_inc(x_38); +lean_dec(x_24); +x_43 = lean_ctor_get(x_25, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_25, 1); +lean_inc(x_44); +if (lean_is_exclusive(x_25)) { + lean_ctor_release(x_25, 0); + lean_ctor_release(x_25, 1); + x_45 = x_25; +} else { + lean_dec_ref(x_25); + x_45 = lean_box(0); +} +lean_inc(x_27); +x_46 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_44, x_13, x_27); +if (lean_is_scalar(x_45)) { + x_47 = lean_alloc_ctor(0, 2, 0); +} else { + x_47 = x_45; +} +lean_ctor_set(x_47, 0, x_43); +lean_ctor_set(x_47, 1, x_46); +x_48 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_48, 0, x_38); +lean_ctor_set(x_48, 1, x_39); +lean_ctor_set(x_48, 2, x_47); +lean_ctor_set(x_48, 3, x_40); +lean_ctor_set(x_48, 4, x_41); +lean_ctor_set(x_48, 5, x_42); +lean_ctor_set(x_23, 1, x_48); +return x_23; +} +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +x_49 = lean_ctor_get(x_23, 0); +lean_inc(x_49); +lean_dec(x_23); +x_50 = lean_ctor_get(x_24, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_24, 1); +lean_inc(x_51); +x_52 = lean_ctor_get(x_24, 3); +lean_inc(x_52); +x_53 = lean_ctor_get(x_24, 4); +lean_inc(x_53); +x_54 = lean_ctor_get(x_24, 5); +lean_inc(x_54); +if (lean_is_exclusive(x_24)) { + lean_ctor_release(x_24, 0); + lean_ctor_release(x_24, 1); + lean_ctor_release(x_24, 2); + lean_ctor_release(x_24, 3); + lean_ctor_release(x_24, 4); + lean_ctor_release(x_24, 5); + x_55 = x_24; +} else { + lean_dec_ref(x_24); x_55 = lean_box(0); } -lean_inc(x_46); -x_56 = l_PersistentHashMap_insert___rarg(x_11, x_12, x_54, x_10, x_46); +x_56 = lean_ctor_get(x_25, 0); +lean_inc(x_56); +x_57 = lean_ctor_get(x_25, 1); +lean_inc(x_57); +if (lean_is_exclusive(x_25)) { + lean_ctor_release(x_25, 0); + lean_ctor_release(x_25, 1); + x_58 = x_25; +} else { + lean_dec_ref(x_25); + x_58 = lean_box(0); +} +lean_inc(x_49); +x_59 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_57, x_13, x_49); +if (lean_is_scalar(x_58)) { + x_60 = lean_alloc_ctor(0, 2, 0); +} else { + x_60 = x_58; +} +lean_ctor_set(x_60, 0, x_56); +lean_ctor_set(x_60, 1, x_59); if (lean_is_scalar(x_55)) { - x_57 = lean_alloc_ctor(0, 2, 0); + x_61 = lean_alloc_ctor(0, 6, 0); } else { - x_57 = x_55; + x_61 = x_55; } -lean_ctor_set(x_57, 0, x_53); -lean_ctor_set(x_57, 1, x_56); -if (lean_is_scalar(x_52)) { - x_58 = lean_alloc_ctor(0, 6, 0); -} else { - x_58 = x_52; -} -lean_ctor_set(x_58, 0, x_47); -lean_ctor_set(x_58, 1, x_48); -lean_ctor_set(x_58, 2, x_57); -lean_ctor_set(x_58, 3, x_49); -lean_ctor_set(x_58, 4, x_50); -lean_ctor_set(x_58, 5, x_51); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_46); -lean_ctor_set(x_59, 1, x_58); -return x_59; +lean_ctor_set(x_61, 0, x_50); +lean_ctor_set(x_61, 1, x_51); +lean_ctor_set(x_61, 2, x_60); +lean_ctor_set(x_61, 3, x_52); +lean_ctor_set(x_61, 4, x_53); +lean_ctor_set(x_61, 5, x_54); +x_62 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_62, 0, x_49); +lean_ctor_set(x_62, 1, x_61); +return x_62; } } else { -uint8_t x_60; -lean_dec(x_10); -x_60 = !lean_is_exclusive(x_20); -if (x_60 == 0) +uint8_t x_63; +lean_dec(x_13); +x_63 = !lean_is_exclusive(x_23); +if (x_63 == 0) { -return x_20; +return x_23; } else { -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_20, 0); -x_62 = lean_ctor_get(x_20, 1); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_20); -x_63 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_63, 0, x_61); -lean_ctor_set(x_63, 1, x_62); -return x_63; +lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_64 = lean_ctor_get(x_23, 0); +x_65 = lean_ctor_get(x_23, 1); +lean_inc(x_65); +lean_inc(x_64); +lean_dec(x_23); +x_66 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_66, 0, x_64); +lean_ctor_set(x_66, 1, x_65); +return x_66; } } } else { -uint8_t x_64; -lean_dec(x_14); -lean_dec(x_10); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_64 = !lean_is_exclusive(x_15); -if (x_64 == 0) +uint8_t x_67; +lean_free_object(x_3); +lean_dec(x_13); +lean_free_object(x_5); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +x_67 = !lean_is_exclusive(x_15); +if (x_67 == 0) { return x_15; } else { -lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_65 = lean_ctor_get(x_15, 0); -x_66 = lean_ctor_get(x_15, 1); -lean_inc(x_66); -lean_inc(x_65); +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_15, 0); +x_69 = lean_ctor_get(x_15, 1); +lean_inc(x_69); +lean_inc(x_68); lean_dec(x_15); -x_67 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_67, 0, x_65); -lean_ctor_set(x_67, 1, x_66); -return x_67; +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; } } } else { -lean_object* x_68; lean_object* x_69; -lean_dec(x_10); -lean_dec(x_4); +lean_dec(x_3); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_71; lean_object* x_72; uint8_t x_73; lean_object* x_74; lean_object* x_75; +x_71 = lean_ctor_get(x_15, 0); +lean_inc(x_71); +x_72 = lean_ctor_get(x_15, 1); +lean_inc(x_72); +lean_dec(x_15); +x_73 = 1; +lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 5, x_73); +x_74 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_74, 0, x_5); +lean_ctor_set(x_74, 1, x_6); +lean_ctor_set(x_74, 2, x_7); +x_75 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_71, x_2, x_74, x_72); +if (lean_obj_tag(x_75) == 0) +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_76 = lean_ctor_get(x_75, 1); +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 2); +lean_inc(x_77); +x_78 = lean_ctor_get(x_75, 0); +lean_inc(x_78); +if (lean_is_exclusive(x_75)) { + lean_ctor_release(x_75, 0); + lean_ctor_release(x_75, 1); + x_79 = x_75; +} else { + lean_dec_ref(x_75); + x_79 = lean_box(0); +} +x_80 = lean_ctor_get(x_76, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_76, 1); +lean_inc(x_81); +x_82 = lean_ctor_get(x_76, 3); +lean_inc(x_82); +x_83 = lean_ctor_get(x_76, 4); +lean_inc(x_83); +x_84 = lean_ctor_get(x_76, 5); +lean_inc(x_84); +if (lean_is_exclusive(x_76)) { + lean_ctor_release(x_76, 0); + lean_ctor_release(x_76, 1); + lean_ctor_release(x_76, 2); + lean_ctor_release(x_76, 3); + lean_ctor_release(x_76, 4); + lean_ctor_release(x_76, 5); + x_85 = x_76; +} else { + lean_dec_ref(x_76); + x_85 = lean_box(0); +} +x_86 = lean_ctor_get(x_77, 0); +lean_inc(x_86); +x_87 = lean_ctor_get(x_77, 1); +lean_inc(x_87); +if (lean_is_exclusive(x_77)) { + lean_ctor_release(x_77, 0); + lean_ctor_release(x_77, 1); + x_88 = x_77; +} else { + lean_dec_ref(x_77); + x_88 = lean_box(0); +} +lean_inc(x_78); +x_89 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_87, x_13, x_78); +if (lean_is_scalar(x_88)) { + x_90 = lean_alloc_ctor(0, 2, 0); +} else { + x_90 = x_88; +} +lean_ctor_set(x_90, 0, x_86); +lean_ctor_set(x_90, 1, x_89); +if (lean_is_scalar(x_85)) { + x_91 = lean_alloc_ctor(0, 6, 0); +} else { + x_91 = x_85; +} +lean_ctor_set(x_91, 0, x_80); +lean_ctor_set(x_91, 1, x_81); +lean_ctor_set(x_91, 2, x_90); +lean_ctor_set(x_91, 3, x_82); +lean_ctor_set(x_91, 4, x_83); +lean_ctor_set(x_91, 5, x_84); +if (lean_is_scalar(x_79)) { + x_92 = lean_alloc_ctor(0, 2, 0); +} else { + x_92 = x_79; +} +lean_ctor_set(x_92, 0, x_78); +lean_ctor_set(x_92, 1, x_91); +return x_92; +} +else +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; +lean_dec(x_13); +x_93 = lean_ctor_get(x_75, 0); +lean_inc(x_93); +x_94 = lean_ctor_get(x_75, 1); +lean_inc(x_94); +if (lean_is_exclusive(x_75)) { + lean_ctor_release(x_75, 0); + lean_ctor_release(x_75, 1); + x_95 = x_75; +} else { + lean_dec_ref(x_75); + x_95 = lean_box(0); +} +if (lean_is_scalar(x_95)) { + x_96 = lean_alloc_ctor(1, 2, 0); +} else { + x_96 = x_95; +} +lean_ctor_set(x_96, 0, x_93); +lean_ctor_set(x_96, 1, x_94); +return x_96; +} +} +else +{ +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +lean_dec(x_13); +lean_free_object(x_5); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +x_97 = lean_ctor_get(x_15, 0); +lean_inc(x_97); +x_98 = lean_ctor_get(x_15, 1); +lean_inc(x_98); +if (lean_is_exclusive(x_15)) { + lean_ctor_release(x_15, 0); + lean_ctor_release(x_15, 1); + x_99 = x_15; +} else { + lean_dec_ref(x_15); + x_99 = lean_box(0); +} +if (lean_is_scalar(x_99)) { + x_100 = lean_alloc_ctor(1, 2, 0); +} else { + x_100 = x_99; +} +lean_ctor_set(x_100, 0, x_97); +lean_ctor_set(x_100, 1, x_98); +return x_100; +} +} +} +else +{ +lean_object* x_101; lean_object* x_102; +lean_dec(x_13); +lean_free_object(x_5); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_68 = lean_ctor_get(x_13, 0); -lean_inc(x_68); -lean_dec(x_13); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_5); -return x_69; +x_101 = lean_ctor_get(x_14, 0); +lean_inc(x_101); +lean_dec(x_14); +x_102 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_102, 0, x_101); +lean_ctor_set(x_102, 1, x_4); +return x_102; +} +} +else +{ +lean_object* x_103; uint8_t x_104; uint8_t x_105; uint8_t x_106; uint8_t x_107; uint8_t x_108; uint8_t x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_103 = lean_ctor_get(x_5, 0); +x_104 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); +x_105 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); +x_106 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); +x_107 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); +x_108 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); +x_109 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 5); +lean_inc(x_103); +lean_dec(x_5); +x_110 = lean_ctor_get(x_4, 2); +lean_inc(x_110); +x_111 = lean_ctor_get(x_110, 1); +lean_inc(x_111); +lean_dec(x_110); +lean_inc(x_2); +lean_inc(x_1); +x_112 = lean_alloc_ctor(0, 2, 1); +lean_ctor_set(x_112, 0, x_1); +lean_ctor_set(x_112, 1, x_2); +lean_ctor_set_uint8(x_112, sizeof(void*)*2, x_109); +x_113 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__1(x_111, x_112); +lean_dec(x_111); +if (lean_obj_tag(x_113) == 0) +{ +lean_object* x_114; lean_object* x_115; +lean_inc(x_3); +x_114 = l_Lean_Meta_inferType(x_1, x_3, x_4); +if (lean_is_exclusive(x_3)) { + lean_ctor_release(x_3, 0); + lean_ctor_release(x_3, 1); + lean_ctor_release(x_3, 2); + x_115 = x_3; +} else { + lean_dec_ref(x_3); + x_115 = lean_box(0); +} +if (lean_obj_tag(x_114) == 0) +{ +lean_object* x_116; lean_object* x_117; uint8_t x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_116 = lean_ctor_get(x_114, 0); +lean_inc(x_116); +x_117 = lean_ctor_get(x_114, 1); +lean_inc(x_117); +lean_dec(x_114); +x_118 = 1; +x_119 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_119, 0, x_103); +lean_ctor_set_uint8(x_119, sizeof(void*)*1, x_104); +lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 1, x_105); +lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 2, x_106); +lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 3, x_107); +lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 4, x_108); +lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 5, x_118); +if (lean_is_scalar(x_115)) { + x_120 = lean_alloc_ctor(0, 3, 0); +} else { + x_120 = x_115; +} +lean_ctor_set(x_120, 0, x_119); +lean_ctor_set(x_120, 1, x_6); +lean_ctor_set(x_120, 2, x_7); +x_121 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2(x_116, x_2, x_120, x_117); +if (lean_obj_tag(x_121) == 0) +{ +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_122 = lean_ctor_get(x_121, 1); +lean_inc(x_122); +x_123 = lean_ctor_get(x_122, 2); +lean_inc(x_123); +x_124 = lean_ctor_get(x_121, 0); +lean_inc(x_124); +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_125 = x_121; +} else { + lean_dec_ref(x_121); + x_125 = lean_box(0); +} +x_126 = lean_ctor_get(x_122, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_122, 1); +lean_inc(x_127); +x_128 = lean_ctor_get(x_122, 3); +lean_inc(x_128); +x_129 = lean_ctor_get(x_122, 4); +lean_inc(x_129); +x_130 = lean_ctor_get(x_122, 5); +lean_inc(x_130); +if (lean_is_exclusive(x_122)) { + lean_ctor_release(x_122, 0); + lean_ctor_release(x_122, 1); + lean_ctor_release(x_122, 2); + lean_ctor_release(x_122, 3); + lean_ctor_release(x_122, 4); + lean_ctor_release(x_122, 5); + x_131 = x_122; +} else { + lean_dec_ref(x_122); + x_131 = lean_box(0); +} +x_132 = lean_ctor_get(x_123, 0); +lean_inc(x_132); +x_133 = lean_ctor_get(x_123, 1); +lean_inc(x_133); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + x_134 = x_123; +} else { + lean_dec_ref(x_123); + x_134 = lean_box(0); +} +lean_inc(x_124); +x_135 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4(x_133, x_112, x_124); +if (lean_is_scalar(x_134)) { + x_136 = lean_alloc_ctor(0, 2, 0); +} else { + x_136 = x_134; +} +lean_ctor_set(x_136, 0, x_132); +lean_ctor_set(x_136, 1, x_135); +if (lean_is_scalar(x_131)) { + x_137 = lean_alloc_ctor(0, 6, 0); +} else { + x_137 = x_131; +} +lean_ctor_set(x_137, 0, x_126); +lean_ctor_set(x_137, 1, x_127); +lean_ctor_set(x_137, 2, x_136); +lean_ctor_set(x_137, 3, x_128); +lean_ctor_set(x_137, 4, x_129); +lean_ctor_set(x_137, 5, x_130); +if (lean_is_scalar(x_125)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_125; +} +lean_ctor_set(x_138, 0, x_124); +lean_ctor_set(x_138, 1, x_137); +return x_138; +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; +lean_dec(x_112); +x_139 = lean_ctor_get(x_121, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_121, 1); +lean_inc(x_140); +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_141 = x_121; +} else { + lean_dec_ref(x_121); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(1, 2, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_139); +lean_ctor_set(x_142, 1, x_140); +return x_142; +} +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; +lean_dec(x_115); +lean_dec(x_112); +lean_dec(x_103); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_2); +x_143 = lean_ctor_get(x_114, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_114, 1); +lean_inc(x_144); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_145 = x_114; +} else { + lean_dec_ref(x_114); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(1, 2, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_143); +lean_ctor_set(x_146, 1, x_144); +return x_146; +} +} +else +{ +lean_object* x_147; lean_object* x_148; +lean_dec(x_112); +lean_dec(x_103); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_147 = lean_ctor_get(x_113, 0); +lean_inc(x_147); +lean_dec(x_113); +x_148 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_148, 0, x_147); +lean_ctor_set(x_148, 1, x_4); +return x_148; } } } -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +} +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; -x_7 = l_Lean_Meta_getFunInfoAuxAux___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); +x_7 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__1(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_2); lean_dec(x_1); return x_7; } } -lean_object* l_Lean_Meta_getFunInfoAuxAux___lambda__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_7; -x_7 = l_Lean_Meta_getFunInfoAuxAux___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6); +lean_object* x_8; +x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7); lean_dec(x_4); -return x_7; +lean_dec(x_3); +lean_dec(x_1); +return x_8; } } -lean_object* l_Lean_Meta_getFunInfoAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: +{ +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_4); +lean_dec(x_4); +x_11 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___lambda__1(x_1, x_2, x_3, x_10, x_5, x_6, x_7, x_8, x_9); +lean_dec(x_3); +return x_11; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +uint8_t x_13; lean_object* x_14; +x_13 = lean_unbox(x_1); +lean_dec(x_1); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__5(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); +lean_dec(x_9); +lean_dec(x_6); +lean_dec(x_5); +return x_14; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__6(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_1); +lean_dec(x_1); +x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__3(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_10; +} +} +lean_object* l_Lean_Meta_getFunInfo(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = lean_box(0); +x_5 = l___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux(x_1, x_4, x_2, x_3); +return x_5; +} +} +lean_object* l_Lean_Meta_getFunInfoNArgs(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; lean_object* x_6; -x_5 = lean_box(0); -x_6 = l_Lean_Meta_getFunInfoAuxAux(x_1, x_2, x_5, x_3, x_4); +x_5 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_5, 0, x_2); +x_6 = l___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux(x_1, x_5, x_3, x_4); return x_6; } } -lean_object* l_Lean_Meta_getFunInfoNArgsAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; lean_object* x_7; -x_6 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_6, 0, x_3); -x_7 = l_Lean_Meta_getFunInfoAuxAux(x_1, x_2, x_6, x_4, x_5); -return x_7; -} -} lean_object* initialize_Init_Lean_Meta_Basic(lean_object*); lean_object* initialize_Init_Lean_Meta_InferType(lean_object*); static bool _G_initialized = false; @@ -3036,6 +4944,8 @@ l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfo lean_mark_persistent(l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__1); l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__2 = _init_l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__2(); lean_mark_persistent(l_PersistentHashMap_insert___at___private_Init_Lean_Meta_FunInfo_1__checkFunInfoCache___spec__4___closed__2); +l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2___closed__1 = _init_l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at___private_Init_Lean_Meta_FunInfo_6__getFunInfoAux___spec__2___closed__1); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/library/Init/Lean/Meta/InferType.c b/stage0/library/Init/Lean/Meta/InferType.c index d5d1b91e08..2440a1aad9 100644 --- a/stage0/library/Init/Lean/Meta/InferType.c +++ b/stage0/library/Init/Lean/Meta/InferType.c @@ -13,487 +13,491 @@ #ifdef __cplusplus extern "C" { #endif -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); size_t l_USize_add(size_t, size_t); lean_object* l_Lean_Level_normalize___main(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__12___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__11(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__29___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkSort(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___lambda__1(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_unreachable_x21___rarg(lean_object*); -lean_object* l_Lean_Meta_isPropAux(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__21(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -extern lean_object* l_EIO_Monad___closed__1; +lean_object* l_Lean_Meta_isClassExpensive___main(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_14__isPropQuick(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkForall(lean_object*, lean_object*, lean_object*, lean_object*); extern size_t l_PersistentHashMap_insertAux___main___rarg___closed__2; lean_object* lean_local_ctx_mk_let_decl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuick(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentHashMap_find___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isClassQuick___main(lean_object*, lean_object*, lean_object*); size_t l_USize_sub(size_t, size_t); extern lean_object* l_Array_empty___closed__1; -extern lean_object* l_Lean_ExprStructEq_Hashable; -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___at_Lean_Meta_inferTypeAux___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__26(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(lean_object*); +lean_object* l_Lean_Meta_setInferTypeRef(lean_object*); +lean_object* l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateLevelMVars(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_Monad___rarg(lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_instantiate1(lean_object*, lean_object*); lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_12__isPropQuickApp(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); -lean_object* l_Lean_Meta_getLevelAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; lean_object* lean_environment_find(lean_object*, lean_object*); extern lean_object* l_Lean_Expr_getAppArgs___closed__1; -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_8__inferFVarType(lean_object*, lean_object*, lean_object*); size_t l_USize_shiftRight(size_t, size_t); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__25(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_9__checkInferTypeCache(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__7(size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuickApp(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_2__inferConstType___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__5(lean_object*, size_t, size_t, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuickApp___main(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___at_Lean_Meta_inferTypeAux___spec__30(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main___boxed(lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l___private_Init_Lean_Meta_InferType_11__isAlwaysZero(lean_object*); +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_metavar_ctx_find_decl(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_7__inferMVarType(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__29(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_inferTypeAux___spec__5(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Literal_type(lean_object*); lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__2___boxed(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkLevelIMax(lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fget(lean_object*, lean_object*); lean_object* l_Lean_mkProj(lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_3__inferProjType___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_expr_instantiate_rev_range(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_eq(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__23(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_nat_sub(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_1__inferAppType___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___boxed(lean_object*); lean_object* l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Expr_2__mkAppRangeAux___main(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_array_fset(lean_object*, lean_object*, lean_object*); lean_object* l_List_lengthAux___main___rarg(lean_object*, lean_object*); lean_object* lean_instantiate_type_lparams(lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__32___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_inferTypeRef; extern lean_object* l_PersistentHashMap_insertAux___main___rarg___closed__3; size_t l_Lean_Expr_hash(lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___boxed(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__23___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__14(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__9___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_2__inferConstType(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__26___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentHashMap_insert___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__2(uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferTypeImpl(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_10__inferTypeAux___main(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_10__inferTypeAux(lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_findAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__2(lean_object*, size_t, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___lambda__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshId___rarg(lean_object*); size_t l_USize_mul(size_t, size_t); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_setInferTypeRef___closed__1; lean_object* l___private_Init_Lean_Expr_3__getAppArgsAux___main(lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_isForall(lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__31(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkFVar(lean_object*); uint8_t l_Lean_Expr_Data_binderInfo(uint64_t); -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_insertAtCollisionNodeAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__6(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkLevelMVar(lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_12__isPropQuickApp___main(lean_object*, lean_object*, lean_object*, lean_object*); size_t l_USize_land(size_t, size_t); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___lambda__1(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__11___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_LocalDecl_type(lean_object*); lean_object* l_Lean_ConstantInfo_lparams(lean_object*); -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_local_ctx_mk_local_decl(lean_object*, lean_object*, lean_object*, lean_object*, uint8_t); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__27___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_assignExprMVar(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__32(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkLevelSucc(lean_object*); -lean_object* l_Lean_Meta_usingDefault(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_inferTypeAux___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_expr_equal(lean_object*, lean_object*); uint8_t l_USize_decLe(size_t, size_t); -lean_object* l_Lean_Meta_inferTypeAuxAux___main(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnfUsingDefault(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__5(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_1__inferAppType___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Bool_toLBool(uint8_t); lean_object* l___private_Init_Lean_Meta_InferType_6__withLocalDecl___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__17(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuick___main(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_lambdaTelescope___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t l___private_Init_Lean_Meta_InferType_10__isAlwaysZero(lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__12(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_lambdaTelescope___at_Lean_Meta_inferTypeAux___spec__3(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_getLevel(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType(lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_io_ref_set(lean_object*, lean_object*, lean_object*); lean_object* l_PersistentHashMap_getCollisionNodeSize___rarg(lean_object*); lean_object* l_PersistentHashMap_findAtAux___main___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Expr_hasLooseBVars(lean_object*); extern lean_object* l_Lean_Expr_Inhabited; lean_object* lean_mk_array(lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferTypeAux(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__9(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_3__inferProjType___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_6__withLocalDecl(lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_6__withLocalDecl___rarg(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_inferTypeAuxAux(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__14___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_14__isPropQuick___main(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_InferType_7__inferMVarType___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Meta_isClassQuick___main___closed__1; lean_object* l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1___boxed(lean_object*, lean_object*); -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__16(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main___boxed(lean_object*); lean_object* lean_usize_to_nat(size_t); -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__6(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isProp(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_local_ctx_find(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkConst(lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__27(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__13(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__25___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(lean_object*); lean_object* l_PersistentHashMap_mkCollisionNode___rarg(lean_object*, lean_object*, lean_object*, lean_object*); -uint8_t lean_is_class(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___at_Lean_Meta_inferTypeAux___spec__15(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_inferTypeAux___spec__19(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*); -extern lean_object* l_Lean_ExprStructEq_HasBeq; -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_1__inferAppType___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_8 = lean_ctor_get(x_5, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_5, 1); -lean_inc(x_9); +lean_object* x_8; uint8_t x_9; +x_8 = lean_unsigned_to_nat(0u); +x_9 = lean_nat_dec_eq(x_4, x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_sub(x_4, x_10); +lean_dec(x_4); +x_21 = lean_nat_sub(x_3, x_11); +x_22 = lean_nat_sub(x_21, x_10); +lean_dec(x_21); +x_23 = lean_ctor_get(x_5, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_5, 1); +lean_inc(x_24); if (lean_is_exclusive(x_5)) { lean_ctor_release(x_5, 0); lean_ctor_release(x_5, 1); - x_10 = x_5; + x_25 = x_5; } else { lean_dec_ref(x_5); - x_10 = lean_box(0); + x_25 = lean_box(0); } -if (lean_obj_tag(x_9) == 7) +if (lean_obj_tag(x_24) == 7) { -lean_object* x_38; lean_object* x_39; lean_object* x_40; -lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_38 = lean_ctor_get(x_9, 2); -lean_inc(x_38); -lean_dec(x_9); -x_39 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_39, 0, x_8); -lean_ctor_set(x_39, 1, x_38); -x_40 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_40, 0, x_39); -lean_ctor_set(x_40, 1, x_7); -return x_40; +lean_object* x_52; lean_object* x_53; lean_object* x_54; +lean_dec(x_25); +lean_dec(x_22); +x_52 = lean_ctor_get(x_24, 2); +lean_inc(x_52); +lean_dec(x_24); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_23); +lean_ctor_set(x_53, 1, x_52); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_53); +lean_ctor_set(x_54, 1, x_7); +x_12 = x_54; +goto block_20; } else { -lean_object* x_41; -x_41 = lean_box(0); -x_11 = x_41; -goto block_37; +lean_object* x_55; +x_55 = lean_box(0); +x_26 = x_55; +goto block_51; } -block_37: +block_20: { -lean_object* x_12; lean_object* x_13; +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 1); +lean_inc(x_14); +lean_dec(x_12); +x_4 = x_11; +x_5 = x_13; +x_7 = x_14; +goto _start; +} +else +{ +uint8_t x_16; lean_dec(x_11); -lean_inc(x_1); -x_12 = lean_expr_instantiate_rev_range(x_9, x_8, x_4, x_1); -lean_dec(x_8); -lean_dec(x_9); -lean_inc(x_6); -x_13 = lean_apply_3(x_2, x_12, x_6, x_7); -if (lean_obj_tag(x_13) == 0) +lean_dec(x_6); +lean_dec(x_2); +lean_dec(x_1); +x_16 = !lean_is_exclusive(x_12); +if (x_16 == 0) { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +return x_12; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_12, 0); +x_18 = lean_ctor_get(x_12, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_12); +x_19 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +} +} +block_51: +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_26); +lean_inc(x_2); +x_27 = lean_expr_instantiate_rev_range(x_24, x_23, x_22, x_2); +lean_dec(x_23); +lean_dec(x_24); +lean_inc(x_6); +x_28 = l_Lean_Meta_whnf(x_27, x_6, x_7); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +if (lean_is_exclusive(x_28)) { + lean_ctor_release(x_28, 0); + lean_ctor_release(x_28, 1); + x_31 = x_28; +} else { + lean_dec_ref(x_28); + x_31 = lean_box(0); +} +if (lean_obj_tag(x_29) == 7) +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; +lean_dec(x_31); +x_43 = lean_ctor_get(x_29, 2); +lean_inc(x_43); +lean_dec(x_29); +if (lean_is_scalar(x_25)) { + x_44 = lean_alloc_ctor(0, 2, 0); +} else { + x_44 = x_25; +} +lean_ctor_set(x_44, 0, x_22); +lean_ctor_set(x_44, 1, x_43); +x_45 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_45, 0, x_44); +lean_ctor_set(x_45, 1, x_30); +x_12 = x_45; +goto block_20; +} +else +{ +lean_object* x_46; +lean_dec(x_29); +lean_dec(x_25); +x_46 = lean_box(0); +x_32 = x_46; +goto block_42; +} +block_42: +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +lean_dec(x_32); +x_33 = lean_ctor_get(x_30, 0); +lean_inc(x_33); +x_34 = lean_ctor_get(x_30, 1); +lean_inc(x_34); +x_35 = lean_ctor_get(x_6, 1); +lean_inc(x_35); +x_36 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_36, 0, x_33); +lean_ctor_set(x_36, 1, x_34); +lean_ctor_set(x_36, 2, x_35); +lean_inc(x_1); +x_37 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_22, x_2, x_8, x_1); +x_38 = l_Lean_Expr_Inhabited; +x_39 = lean_array_get(x_38, x_2, x_22); +lean_dec(x_22); +x_40 = lean_alloc_ctor(5, 3, 0); +lean_ctor_set(x_40, 0, x_37); +lean_ctor_set(x_40, 1, x_39); +lean_ctor_set(x_40, 2, x_36); +if (lean_is_scalar(x_31)) { + x_41 = lean_alloc_ctor(1, 2, 0); +} else { + x_41 = x_31; + lean_ctor_set_tag(x_41, 1); +} +lean_ctor_set(x_41, 0, x_40); +lean_ctor_set(x_41, 1, x_30); +x_12 = x_41; +goto block_20; +} +} +else +{ +uint8_t x_47; +lean_dec(x_25); +lean_dec(x_22); +x_47 = !lean_is_exclusive(x_28); +if (x_47 == 0) +{ +x_12 = x_28; +goto block_20; +} +else +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_28, 0); +x_49 = lean_ctor_get(x_28, 1); +lean_inc(x_49); +lean_inc(x_48); +lean_dec(x_28); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_48); +lean_ctor_set(x_50, 1, x_49); +x_12 = x_50; +goto block_20; +} +} +} +} +else +{ +lean_object* x_56; +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_56 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_56, 0, x_5); +lean_ctor_set(x_56, 1, x_7); +return x_56; +} +} +} +lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +lean_inc(x_1); +x_5 = l_Lean_Meta_inferType(x_1, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +x_8 = lean_unsigned_to_nat(0u); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_6); +x_10 = lean_array_get_size(x_2); +lean_inc(x_10); +lean_inc(x_2); +x_11 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_1__inferAppType___spec__1(x_1, x_2, x_10, x_10, x_9, x_3, x_7); +if (lean_obj_tag(x_11) == 0) +{ +uint8_t x_12; +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_11, 0); x_14 = lean_ctor_get(x_13, 0); lean_inc(x_14); x_15 = lean_ctor_get(x_13, 1); lean_inc(x_15); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - x_16 = x_13; -} else { - lean_dec_ref(x_13); - x_16 = lean_box(0); -} -if (lean_obj_tag(x_14) == 7) -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -lean_dec(x_16); -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_1); -x_29 = lean_ctor_get(x_14, 2); -lean_inc(x_29); +lean_dec(x_13); +x_16 = lean_expr_instantiate_rev_range(x_15, x_14, x_10, x_2); +lean_dec(x_10); lean_dec(x_14); -if (lean_is_scalar(x_10)) { - x_30 = lean_alloc_ctor(0, 2, 0); -} else { - x_30 = x_10; -} -lean_ctor_set(x_30, 0, x_4); -lean_ctor_set(x_30, 1, x_29); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_30); -lean_ctor_set(x_31, 1, x_15); -return x_31; +lean_dec(x_15); +lean_ctor_set(x_11, 0, x_16); +return x_11; } else { -lean_object* x_32; -lean_dec(x_14); -lean_dec(x_10); -x_32 = lean_box(0); -x_17 = x_32; -goto block_28; -} -block_28: -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_17); -x_18 = lean_ctor_get(x_15, 0); +lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_17 = lean_ctor_get(x_11, 0); +x_18 = lean_ctor_get(x_11, 1); lean_inc(x_18); -x_19 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_11); +x_19 = lean_ctor_get(x_17, 0); lean_inc(x_19); -x_20 = lean_ctor_get(x_6, 1); +x_20 = lean_ctor_get(x_17, 1); lean_inc(x_20); -lean_dec(x_6); -x_21 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_21, 0, x_18); -lean_ctor_set(x_21, 1, x_19); -lean_ctor_set(x_21, 2, x_20); -x_22 = lean_unsigned_to_nat(0u); -x_23 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_4, x_1, x_22, x_3); -x_24 = l_Lean_Expr_Inhabited; -x_25 = lean_array_get(x_24, x_1, x_4); -lean_dec(x_4); -lean_dec(x_1); -x_26 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_26, 0, x_23); -lean_ctor_set(x_26, 1, x_25); -lean_ctor_set(x_26, 2, x_21); -if (lean_is_scalar(x_16)) { - x_27 = lean_alloc_ctor(1, 2, 0); -} else { - x_27 = x_16; - lean_ctor_set_tag(x_27, 1); -} -lean_ctor_set(x_27, 0, x_26); -lean_ctor_set(x_27, 1, x_15); -return x_27; -} -} -else -{ -uint8_t x_33; +lean_dec(x_17); +x_21 = lean_expr_instantiate_rev_range(x_20, x_19, x_10, x_2); lean_dec(x_10); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_33 = !lean_is_exclusive(x_13); -if (x_33 == 0) -{ -return x_13; -} -else -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_13, 0); -x_35 = lean_ctor_get(x_13, 1); -lean_inc(x_35); -lean_inc(x_34); -lean_dec(x_13); -x_36 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_36, 0, x_34); -lean_ctor_set(x_36, 1, x_35); -return x_36; -} -} -} -} -} -lean_object* _init_l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1() { -_start: -{ -lean_object* x_1; lean_object* x_2; -x_1 = l_EIO_Monad___closed__1; -x_2 = l_ReaderT_Monad___rarg(x_1); -return x_2; -} -} -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -lean_inc(x_5); -lean_inc(x_3); -x_7 = lean_apply_3(x_2, x_3, x_5, x_6); -if (lean_obj_tag(x_7) == 0) -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; -x_8 = lean_ctor_get(x_7, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_7, 1); -lean_inc(x_9); -lean_dec(x_7); -lean_inc(x_4); -x_10 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_InferType_1__inferAppType___lambda__1), 7, 3); -lean_closure_set(x_10, 0, x_4); -lean_closure_set(x_10, 1, x_1); -lean_closure_set(x_10, 2, x_3); -x_11 = lean_unsigned_to_nat(0u); -x_12 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_12, 0, x_11); -lean_ctor_set(x_12, 1, x_8); -x_13 = lean_array_get_size(x_4); -x_14 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -lean_inc(x_13); -x_15 = l_Nat_foldMAux___main___rarg(x_14, x_10, x_13, x_13, x_12); -x_16 = lean_apply_2(x_15, x_5, x_9); -if (lean_obj_tag(x_16) == 0) -{ -uint8_t x_17; -x_17 = !lean_is_exclusive(x_16); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_18 = lean_ctor_get(x_16, 0); -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_18, 1); -lean_inc(x_20); -lean_dec(x_18); -x_21 = lean_expr_instantiate_rev_range(x_20, x_19, x_13, x_4); -lean_dec(x_13); lean_dec(x_19); lean_dec(x_20); -lean_ctor_set(x_16, 0, x_21); -return x_16; +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_18); +return x_22; +} } else { -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_22 = lean_ctor_get(x_16, 0); -x_23 = lean_ctor_get(x_16, 1); -lean_inc(x_23); -lean_inc(x_22); -lean_dec(x_16); -x_24 = lean_ctor_get(x_22, 0); -lean_inc(x_24); -x_25 = lean_ctor_get(x_22, 1); +uint8_t x_23; +lean_dec(x_10); +lean_dec(x_2); +x_23 = !lean_is_exclusive(x_11); +if (x_23 == 0) +{ +return x_11; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_11, 0); +x_25 = lean_ctor_get(x_11, 1); lean_inc(x_25); -lean_dec(x_22); -x_26 = lean_expr_instantiate_rev_range(x_25, x_24, x_13, x_4); -lean_dec(x_13); -lean_dec(x_24); -lean_dec(x_25); -x_27 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_27, 0, x_26); -lean_ctor_set(x_27, 1, x_23); -return x_27; -} -} -else -{ -uint8_t x_28; -lean_dec(x_13); -lean_dec(x_4); -x_28 = !lean_is_exclusive(x_16); -if (x_28 == 0) -{ -return x_16; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_16, 0); -x_30 = lean_ctor_get(x_16, 1); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_16); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; +lean_inc(x_24); +lean_dec(x_11); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; } } } else { -uint8_t x_32; -lean_dec(x_5); -lean_dec(x_4); +uint8_t x_27; lean_dec(x_3); +lean_dec(x_2); lean_dec(x_1); -x_32 = !lean_is_exclusive(x_7); -if (x_32 == 0) +x_27 = !lean_is_exclusive(x_5); +if (x_27 == 0) { -return x_7; +return x_5; } else { -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_7, 0); -x_34 = lean_ctor_get(x_7, 1); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_7); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_33); -lean_ctor_set(x_35, 1, x_34); -return x_35; +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_5, 0); +x_29 = lean_ctor_get(x_5, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_5); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; } } } } +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_1__inferAppType___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_1__inferAppType___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_3); +return x_8; +} +} lean_object* l___private_Init_Lean_Meta_InferType_2__inferConstType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -580,97 +584,73 @@ lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_3__inferProjType___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_9; -lean_inc(x_7); -x_9 = lean_apply_3(x_1, x_6, x_7, x_8); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -if (lean_obj_tag(x_10) == 7) -{ -uint8_t x_11; -lean_dec(x_7); -lean_dec(x_3); -x_11 = !lean_is_exclusive(x_9); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; uint8_t x_14; -x_12 = lean_ctor_get(x_9, 0); -lean_dec(x_12); -x_13 = lean_ctor_get(x_10, 2); -lean_inc(x_13); -lean_dec(x_10); -x_14 = l_Lean_Expr_hasLooseBVars(x_13); -if (x_14 == 0) +lean_object* x_9; uint8_t x_10; +x_9 = lean_unsigned_to_nat(0u); +x_10 = lean_nat_dec_eq(x_5, x_9); +if (x_10 == 0) { +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_11 = lean_unsigned_to_nat(1u); +x_12 = lean_nat_sub(x_5, x_11); lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -lean_ctor_set(x_9, 0, x_13); -return x_9; -} -else -{ -lean_object* x_15; lean_object* x_16; -x_15 = l_Lean_mkProj(x_2, x_5, x_4); -x_16 = lean_expr_instantiate1(x_13, x_15); -lean_dec(x_15); +x_13 = lean_nat_sub(x_4, x_12); +x_14 = lean_nat_sub(x_13, x_11); lean_dec(x_13); -lean_ctor_set(x_9, 0, x_16); -return x_9; -} -} -else +lean_inc(x_7); +x_15 = l_Lean_Meta_whnf(x_6, x_7, x_8); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +if (lean_obj_tag(x_16) == 7) { lean_object* x_17; lean_object* x_18; uint8_t x_19; -x_17 = lean_ctor_get(x_9, 1); +x_17 = lean_ctor_get(x_15, 1); lean_inc(x_17); -lean_dec(x_9); -x_18 = lean_ctor_get(x_10, 2); +lean_dec(x_15); +x_18 = lean_ctor_get(x_16, 2); lean_inc(x_18); -lean_dec(x_10); +lean_dec(x_16); x_19 = l_Lean_Expr_hasLooseBVars(x_18); if (x_19 == 0) { -lean_object* x_20; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_20 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_17); -return x_20; +lean_dec(x_14); +x_5 = x_12; +x_6 = x_18; +x_8 = x_17; +goto _start; } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_21 = l_Lean_mkProj(x_2, x_5, x_4); +lean_object* x_21; lean_object* x_22; +lean_inc(x_3); +lean_inc(x_1); +x_21 = l_Lean_mkProj(x_1, x_14, x_3); x_22 = lean_expr_instantiate1(x_18, x_21); lean_dec(x_21); lean_dec(x_18); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_17); -return x_23; -} +x_5 = x_12; +x_6 = x_22; +x_8 = x_17; +goto _start; } } else { uint8_t x_24; -lean_dec(x_10); -lean_dec(x_5); -x_24 = !lean_is_exclusive(x_9); +lean_dec(x_16); +lean_dec(x_14); +lean_dec(x_12); +x_24 = !lean_is_exclusive(x_15); if (x_24 == 0) { lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_25 = lean_ctor_get(x_9, 1); -x_26 = lean_ctor_get(x_9, 0); +x_25 = lean_ctor_get(x_15, 1); +x_26 = lean_ctor_get(x_15, 0); lean_dec(x_26); x_27 = lean_ctor_get(x_25, 0); lean_inc(x_27); @@ -684,20 +664,20 @@ lean_ctor_set(x_30, 0, x_27); lean_ctor_set(x_30, 1, x_28); lean_ctor_set(x_30, 2, x_29); x_31 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_31, 0, x_2); -lean_ctor_set(x_31, 1, x_3); -lean_ctor_set(x_31, 2, x_4); +lean_ctor_set(x_31, 0, x_1); +lean_ctor_set(x_31, 1, x_2); +lean_ctor_set(x_31, 2, x_3); lean_ctor_set(x_31, 3, x_30); -lean_ctor_set_tag(x_9, 1); -lean_ctor_set(x_9, 0, x_31); -return x_9; +lean_ctor_set_tag(x_15, 1); +lean_ctor_set(x_15, 0, x_31); +return x_15; } else { lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_32 = lean_ctor_get(x_9, 1); +x_32 = lean_ctor_get(x_15, 1); lean_inc(x_32); -lean_dec(x_9); +lean_dec(x_15); x_33 = lean_ctor_get(x_32, 0); lean_inc(x_33); x_34 = lean_ctor_get(x_32, 1); @@ -710,9 +690,9 @@ lean_ctor_set(x_36, 0, x_33); lean_ctor_set(x_36, 1, x_34); lean_ctor_set(x_36, 2, x_35); x_37 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_37, 0, x_2); -lean_ctor_set(x_37, 1, x_3); -lean_ctor_set(x_37, 2, x_4); +lean_ctor_set(x_37, 0, x_1); +lean_ctor_set(x_37, 1, x_2); +lean_ctor_set(x_37, 2, x_3); lean_ctor_set(x_37, 3, x_36); x_38 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_38, 0, x_37); @@ -724,24 +704,25 @@ return x_38; else { uint8_t x_39; +lean_dec(x_14); +lean_dec(x_12); lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_39 = !lean_is_exclusive(x_9); +lean_dec(x_1); +x_39 = !lean_is_exclusive(x_15); if (x_39 == 0) { -return x_9; +return x_15; } else { lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_40 = lean_ctor_get(x_9, 0); -x_41 = lean_ctor_get(x_9, 1); +x_40 = lean_ctor_get(x_15, 0); +x_41 = lean_ctor_get(x_15, 1); lean_inc(x_41); lean_inc(x_40); -lean_dec(x_9); +lean_dec(x_15); x_42 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_42, 0, x_40); lean_ctor_set(x_42, 1, x_41); @@ -749,800 +730,826 @@ return x_42; } } } +else +{ +lean_object* x_43; +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_6); +lean_ctor_set(x_43, 1, x_8); +return x_43; } -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +} +} +lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_8; -lean_inc(x_2); -lean_inc(x_6); -lean_inc(x_5); -x_8 = lean_apply_3(x_2, x_5, x_6, x_7); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -x_10 = lean_ctor_get(x_8, 1); -lean_inc(x_10); -lean_dec(x_8); -lean_inc(x_1); -lean_inc(x_6); -x_11 = lean_apply_3(x_1, x_9, x_6, x_10); -if (lean_obj_tag(x_11) == 0) -{ -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_13 = lean_ctor_get(x_11, 1); -x_14 = lean_ctor_get(x_11, 0); -x_15 = lean_ctor_get(x_13, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_13, 1); -lean_inc(x_16); -x_17 = l_Lean_Expr_getAppFn___main(x_14); -if (lean_obj_tag(x_17) == 4) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_17, 1); -lean_inc(x_19); -lean_dec(x_17); -lean_inc(x_15); -x_20 = lean_environment_find(x_15, x_18); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_2); -lean_dec(x_1); -x_21 = lean_ctor_get(x_6, 1); -lean_inc(x_21); -lean_dec(x_6); -x_22 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_22, 0, x_15); -lean_ctor_set(x_22, 1, x_16); -lean_ctor_set(x_22, 2, x_21); -x_23 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_23, 0, x_3); -lean_ctor_set(x_23, 1, x_4); -lean_ctor_set(x_23, 2, x_5); -lean_ctor_set(x_23, 3, x_22); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_23); -return x_11; -} -else -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_20, 0); -lean_inc(x_24); -lean_dec(x_20); -if (lean_obj_tag(x_24) == 5) -{ -lean_object* x_25; lean_object* x_26; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -lean_dec(x_24); -x_26 = lean_ctor_get(x_25, 4); -lean_inc(x_26); -if (lean_obj_tag(x_26) == 0) -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_25); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_2); -lean_dec(x_1); -x_27 = lean_ctor_get(x_6, 1); -lean_inc(x_27); -lean_dec(x_6); -x_28 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_28, 0, x_15); -lean_ctor_set(x_28, 1, x_16); -lean_ctor_set(x_28, 2, x_27); -x_29 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_29, 0, x_3); -lean_ctor_set(x_29, 1, x_4); -lean_ctor_set(x_29, 2, x_5); -lean_ctor_set(x_29, 3, x_28); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_29); -return x_11; -} -else -{ -lean_object* x_30; -x_30 = lean_ctor_get(x_26, 1); -lean_inc(x_30); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; uint8_t x_41; -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(0u); -x_34 = l_Lean_Expr_getAppNumArgsAux___main(x_14, x_33); -x_35 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_34); -x_36 = lean_mk_array(x_34, x_35); -x_37 = lean_unsigned_to_nat(1u); -x_38 = lean_nat_sub(x_34, x_37); -lean_dec(x_34); -x_39 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_14, x_36, x_38); -x_40 = lean_array_get_size(x_39); -x_41 = lean_nat_dec_eq(x_31, x_40); -lean_dec(x_40); -lean_dec(x_31); -if (x_41 == 0) -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; -lean_dec(x_39); -lean_dec(x_32); -lean_dec(x_19); -lean_dec(x_2); -lean_dec(x_1); -x_42 = lean_ctor_get(x_6, 1); -lean_inc(x_42); -lean_dec(x_6); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_15); -lean_ctor_set(x_43, 1, x_16); -lean_ctor_set(x_43, 2, x_42); -x_44 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_44, 0, x_3); -lean_ctor_set(x_44, 1, x_4); -lean_ctor_set(x_44, 2, x_5); -lean_ctor_set(x_44, 3, x_43); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_44); -return x_11; -} -else -{ -lean_object* x_45; -lean_inc(x_32); -lean_inc(x_15); -x_45 = lean_environment_find(x_15, x_32); -if (lean_obj_tag(x_45) == 0) -{ -lean_object* x_46; lean_object* x_47; lean_object* x_48; -lean_dec(x_39); -lean_dec(x_32); -lean_dec(x_19); -lean_dec(x_2); -lean_dec(x_1); -x_46 = lean_ctor_get(x_6, 1); -lean_inc(x_46); -lean_dec(x_6); -x_47 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_47, 0, x_15); -lean_ctor_set(x_47, 1, x_16); -lean_ctor_set(x_47, 2, x_46); -x_48 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_48, 0, x_3); -lean_ctor_set(x_48, 1, x_4); -lean_ctor_set(x_48, 2, x_5); -lean_ctor_set(x_48, 3, x_47); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_48); -return x_11; -} -else -{ -lean_object* x_49; lean_object* x_50; -lean_dec(x_45); -lean_dec(x_16); -lean_dec(x_15); -lean_free_object(x_11); -x_49 = l_Lean_mkConst(x_32, x_19); -lean_inc(x_6); -lean_inc(x_1); -x_50 = l___private_Init_Lean_Meta_InferType_1__inferAppType(x_1, x_2, x_49, x_39, x_6, x_13); -if (lean_obj_tag(x_50) == 0) -{ -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_51 = lean_ctor_get(x_50, 0); -lean_inc(x_51); -x_52 = lean_ctor_get(x_50, 1); -lean_inc(x_52); -lean_dec(x_50); -lean_inc(x_5); +lean_object* x_6; lean_inc(x_4); lean_inc(x_3); -lean_inc(x_1); -x_53 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_InferType_3__inferProjType___lambda__1), 8, 4); -lean_closure_set(x_53, 0, x_1); -lean_closure_set(x_53, 1, x_3); -lean_closure_set(x_53, 2, x_4); -lean_closure_set(x_53, 3, x_5); -x_54 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; +x_6 = l_Lean_Meta_inferType(x_3, x_4, x_5); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); lean_inc(x_4); -x_55 = l_Nat_foldMAux___main___rarg(x_54, x_53, x_4, x_4, x_51); -lean_inc(x_6); -x_56 = lean_apply_2(x_55, x_6, x_52); -if (lean_obj_tag(x_56) == 0) +x_9 = l_Lean_Meta_whnf(x_7, x_4, x_8); +if (lean_obj_tag(x_9) == 0) { -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_56, 0); -lean_inc(x_57); -x_58 = lean_ctor_get(x_56, 1); -lean_inc(x_58); -lean_dec(x_56); -lean_inc(x_6); -x_59 = lean_apply_3(x_1, x_57, x_6, x_58); -if (lean_obj_tag(x_59) == 0) +uint8_t x_10; +x_10 = !lean_is_exclusive(x_9); +if (x_10 == 0) { -lean_object* x_60; -x_60 = lean_ctor_get(x_59, 0); -lean_inc(x_60); -if (lean_obj_tag(x_60) == 7) +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_11 = lean_ctor_get(x_9, 1); +x_12 = lean_ctor_get(x_9, 0); +x_13 = lean_ctor_get(x_11, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_11, 1); +lean_inc(x_14); +x_15 = l_Lean_Expr_getAppFn___main(x_12); +if (lean_obj_tag(x_15) == 4) { -uint8_t x_61; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -x_61 = !lean_is_exclusive(x_59); -if (x_61 == 0) +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +lean_inc(x_13); +x_18 = lean_environment_find(x_13, x_16); +if (lean_obj_tag(x_18) == 0) { -lean_object* x_62; lean_object* x_63; -x_62 = lean_ctor_get(x_59, 0); -lean_dec(x_62); -x_63 = lean_ctor_get(x_60, 1); -lean_inc(x_63); -lean_dec(x_60); -lean_ctor_set(x_59, 0, x_63); -return x_59; -} -else -{ -lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_64 = lean_ctor_get(x_59, 1); -lean_inc(x_64); -lean_dec(x_59); -x_65 = lean_ctor_get(x_60, 1); -lean_inc(x_65); -lean_dec(x_60); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_66, 1, x_64); -return x_66; -} -} -else -{ -uint8_t x_67; -lean_dec(x_60); -x_67 = !lean_is_exclusive(x_59); -if (x_67 == 0) -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_68 = lean_ctor_get(x_59, 1); -x_69 = lean_ctor_get(x_59, 0); -lean_dec(x_69); -x_70 = lean_ctor_get(x_68, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_68, 1); -lean_inc(x_71); -x_72 = lean_ctor_get(x_6, 1); -lean_inc(x_72); -lean_dec(x_6); -x_73 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_73, 0, x_70); -lean_ctor_set(x_73, 1, x_71); -lean_ctor_set(x_73, 2, x_72); -x_74 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_74, 0, x_3); -lean_ctor_set(x_74, 1, x_4); -lean_ctor_set(x_74, 2, x_5); -lean_ctor_set(x_74, 3, x_73); -lean_ctor_set_tag(x_59, 1); -lean_ctor_set(x_59, 0, x_74); -return x_59; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_75 = lean_ctor_get(x_59, 1); -lean_inc(x_75); -lean_dec(x_59); -x_76 = lean_ctor_get(x_75, 0); -lean_inc(x_76); -x_77 = lean_ctor_get(x_75, 1); -lean_inc(x_77); -x_78 = lean_ctor_get(x_6, 1); -lean_inc(x_78); -lean_dec(x_6); -x_79 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_79, 0, x_76); -lean_ctor_set(x_79, 1, x_77); -lean_ctor_set(x_79, 2, x_78); -x_80 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_80, 0, x_3); -lean_ctor_set(x_80, 1, x_4); -lean_ctor_set(x_80, 2, x_5); -lean_ctor_set(x_80, 3, x_79); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_75); -return x_81; -} -} -} -else -{ -uint8_t x_82; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -x_82 = !lean_is_exclusive(x_59); -if (x_82 == 0) -{ -return x_59; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_59, 0); -x_84 = lean_ctor_get(x_59, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_59); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; -} -} -} -else -{ -uint8_t x_86; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_86 = !lean_is_exclusive(x_56); -if (x_86 == 0) -{ -return x_56; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_56, 0); -x_88 = lean_ctor_get(x_56, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_56); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} -} -} -else -{ -uint8_t x_90; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_90 = !lean_is_exclusive(x_50); -if (x_90 == 0) -{ -return x_50; -} -else -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_50, 0); -x_92 = lean_ctor_get(x_50, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_50); -x_93 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -return x_93; -} -} -} -} -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -lean_dec(x_30); -lean_dec(x_26); -lean_dec(x_25); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_2); -lean_dec(x_1); -x_94 = lean_ctor_get(x_6, 1); -lean_inc(x_94); -lean_dec(x_6); -x_95 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_95, 0, x_15); -lean_ctor_set(x_95, 1, x_16); -lean_ctor_set(x_95, 2, x_94); -x_96 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_96, 0, x_3); -lean_ctor_set(x_96, 1, x_4); -lean_ctor_set(x_96, 2, x_5); -lean_ctor_set(x_96, 3, x_95); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_96); -return x_11; -} -} -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_14); -lean_dec(x_2); -lean_dec(x_1); -x_97 = lean_ctor_get(x_6, 1); -lean_inc(x_97); -lean_dec(x_6); -x_98 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_98, 0, x_15); -lean_ctor_set(x_98, 1, x_16); -lean_ctor_set(x_98, 2, x_97); -x_99 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_99, 0, x_3); -lean_ctor_set(x_99, 1, x_4); -lean_ctor_set(x_99, 2, x_5); -lean_ctor_set(x_99, 3, x_98); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_99); -return x_11; -} -} -} -else -{ -lean_object* x_100; lean_object* x_101; lean_object* x_102; +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_dec(x_17); +lean_dec(x_12); +x_19 = lean_ctor_get(x_4, 1); +lean_inc(x_19); +lean_dec(x_4); +x_20 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_20, 0, x_13); +lean_ctor_set(x_20, 1, x_14); +lean_ctor_set(x_20, 2, x_19); +x_21 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_21, 0, x_1); +lean_ctor_set(x_21, 1, x_2); +lean_ctor_set(x_21, 2, x_3); +lean_ctor_set(x_21, 3, x_20); +lean_ctor_set_tag(x_9, 1); +lean_ctor_set(x_9, 0, x_21); +return x_9; +} +else +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_18, 0); +lean_inc(x_22); +lean_dec(x_18); +if (lean_obj_tag(x_22) == 5) +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +lean_dec(x_22); +x_24 = lean_ctor_get(x_23, 4); +lean_inc(x_24); +if (lean_obj_tag(x_24) == 0) +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_dec(x_23); +lean_dec(x_17); +lean_dec(x_12); +x_25 = lean_ctor_get(x_4, 1); +lean_inc(x_25); +lean_dec(x_4); +x_26 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_26, 0, x_13); +lean_ctor_set(x_26, 1, x_14); +lean_ctor_set(x_26, 2, x_25); +x_27 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_27, 0, x_1); +lean_ctor_set(x_27, 1, x_2); +lean_ctor_set(x_27, 2, x_3); +lean_ctor_set(x_27, 3, x_26); +lean_ctor_set_tag(x_9, 1); +lean_ctor_set(x_9, 0, x_27); +return x_9; +} +else +{ +lean_object* x_28; +x_28 = lean_ctor_get(x_24, 1); +lean_inc(x_28); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t x_39; +x_29 = lean_ctor_get(x_23, 1); +lean_inc(x_29); +lean_dec(x_23); +x_30 = lean_ctor_get(x_24, 0); +lean_inc(x_30); +lean_dec(x_24); +x_31 = lean_unsigned_to_nat(0u); +x_32 = l_Lean_Expr_getAppNumArgsAux___main(x_12, x_31); +x_33 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_32); +x_34 = lean_mk_array(x_32, x_33); +x_35 = lean_unsigned_to_nat(1u); +x_36 = lean_nat_sub(x_32, x_35); +lean_dec(x_32); +x_37 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_12, x_34, x_36); +x_38 = lean_array_get_size(x_37); +x_39 = lean_nat_dec_eq(x_29, x_38); +lean_dec(x_38); +lean_dec(x_29); +if (x_39 == 0) +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; +lean_dec(x_37); +lean_dec(x_30); +lean_dec(x_17); +x_40 = lean_ctor_get(x_4, 1); +lean_inc(x_40); +lean_dec(x_4); +x_41 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_41, 0, x_13); +lean_ctor_set(x_41, 1, x_14); +lean_ctor_set(x_41, 2, x_40); +x_42 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_42, 0, x_1); +lean_ctor_set(x_42, 1, x_2); +lean_ctor_set(x_42, 2, x_3); +lean_ctor_set(x_42, 3, x_41); +lean_ctor_set_tag(x_9, 1); +lean_ctor_set(x_9, 0, x_42); +return x_9; +} +else +{ +lean_object* x_43; +lean_inc(x_30); +lean_inc(x_13); +x_43 = lean_environment_find(x_13, x_30); +if (lean_obj_tag(x_43) == 0) +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +lean_dec(x_37); +lean_dec(x_30); +lean_dec(x_17); +x_44 = lean_ctor_get(x_4, 1); +lean_inc(x_44); +lean_dec(x_4); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_13); +lean_ctor_set(x_45, 1, x_14); +lean_ctor_set(x_45, 2, x_44); +x_46 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_46, 0, x_1); +lean_ctor_set(x_46, 1, x_2); +lean_ctor_set(x_46, 2, x_3); +lean_ctor_set(x_46, 3, x_45); +lean_ctor_set_tag(x_9, 1); +lean_ctor_set(x_9, 0, x_46); +return x_9; +} +else +{ +lean_object* x_47; lean_object* x_48; +lean_dec(x_43); lean_dec(x_14); +lean_dec(x_13); +lean_free_object(x_9); +x_47 = l_Lean_mkConst(x_30, x_17); +lean_inc(x_4); +x_48 = l___private_Init_Lean_Meta_InferType_1__inferAppType(x_47, x_37, x_4, x_11); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +x_50 = lean_ctor_get(x_48, 1); +lean_inc(x_50); +lean_dec(x_48); +lean_inc(x_4); +lean_inc(x_3); +lean_inc_n(x_2, 2); +lean_inc(x_1); +x_51 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_3__inferProjType___spec__1(x_1, x_2, x_3, x_2, x_2, x_49, x_4, x_50); +if (lean_obj_tag(x_51) == 0) +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_51, 0); +lean_inc(x_52); +x_53 = lean_ctor_get(x_51, 1); +lean_inc(x_53); +lean_dec(x_51); +lean_inc(x_4); +x_54 = l_Lean_Meta_whnf(x_52, x_4, x_53); +if (lean_obj_tag(x_54) == 0) +{ +lean_object* x_55; +x_55 = lean_ctor_get(x_54, 0); +lean_inc(x_55); +if (lean_obj_tag(x_55) == 7) +{ +uint8_t x_56; +lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_100 = lean_ctor_get(x_6, 1); +x_56 = !lean_is_exclusive(x_54); +if (x_56 == 0) +{ +lean_object* x_57; lean_object* x_58; +x_57 = lean_ctor_get(x_54, 0); +lean_dec(x_57); +x_58 = lean_ctor_get(x_55, 1); +lean_inc(x_58); +lean_dec(x_55); +lean_ctor_set(x_54, 0, x_58); +return x_54; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_54, 1); +lean_inc(x_59); +lean_dec(x_54); +x_60 = lean_ctor_get(x_55, 1); +lean_inc(x_60); +lean_dec(x_55); +x_61 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_61, 0, x_60); +lean_ctor_set(x_61, 1, x_59); +return x_61; +} +} +else +{ +uint8_t x_62; +lean_dec(x_55); +x_62 = !lean_is_exclusive(x_54); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_63 = lean_ctor_get(x_54, 1); +x_64 = lean_ctor_get(x_54, 0); +lean_dec(x_64); +x_65 = lean_ctor_get(x_63, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_63, 1); +lean_inc(x_66); +x_67 = lean_ctor_get(x_4, 1); +lean_inc(x_67); +lean_dec(x_4); +x_68 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_68, 0, x_65); +lean_ctor_set(x_68, 1, x_66); +lean_ctor_set(x_68, 2, x_67); +x_69 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_69, 0, x_1); +lean_ctor_set(x_69, 1, x_2); +lean_ctor_set(x_69, 2, x_3); +lean_ctor_set(x_69, 3, x_68); +lean_ctor_set_tag(x_54, 1); +lean_ctor_set(x_54, 0, x_69); +return x_54; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_70 = lean_ctor_get(x_54, 1); +lean_inc(x_70); +lean_dec(x_54); +x_71 = lean_ctor_get(x_70, 0); +lean_inc(x_71); +x_72 = lean_ctor_get(x_70, 1); +lean_inc(x_72); +x_73 = lean_ctor_get(x_4, 1); +lean_inc(x_73); +lean_dec(x_4); +x_74 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_74, 0, x_71); +lean_ctor_set(x_74, 1, x_72); +lean_ctor_set(x_74, 2, x_73); +x_75 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_75, 0, x_1); +lean_ctor_set(x_75, 1, x_2); +lean_ctor_set(x_75, 2, x_3); +lean_ctor_set(x_75, 3, x_74); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_75); +lean_ctor_set(x_76, 1, x_70); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_77 = !lean_is_exclusive(x_54); +if (x_77 == 0) +{ +return x_54; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_54, 0); +x_79 = lean_ctor_get(x_54, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_54); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_81 = !lean_is_exclusive(x_51); +if (x_81 == 0) +{ +return x_51; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_51, 0); +x_83 = lean_ctor_get(x_51, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_51); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +else +{ +uint8_t x_85; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_85 = !lean_is_exclusive(x_48); +if (x_85 == 0) +{ +return x_48; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_48, 0); +x_87 = lean_ctor_get(x_48, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_48); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +} +} +else +{ +lean_object* x_89; lean_object* x_90; lean_object* x_91; +lean_dec(x_28); +lean_dec(x_24); +lean_dec(x_23); +lean_dec(x_17); +lean_dec(x_12); +x_89 = lean_ctor_get(x_4, 1); +lean_inc(x_89); +lean_dec(x_4); +x_90 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_90, 0, x_13); +lean_ctor_set(x_90, 1, x_14); +lean_ctor_set(x_90, 2, x_89); +x_91 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_91, 0, x_1); +lean_ctor_set(x_91, 1, x_2); +lean_ctor_set(x_91, 2, x_3); +lean_ctor_set(x_91, 3, x_90); +lean_ctor_set_tag(x_9, 1); +lean_ctor_set(x_9, 0, x_91); +return x_9; +} +} +} +else +{ +lean_object* x_92; lean_object* x_93; lean_object* x_94; +lean_dec(x_22); +lean_dec(x_17); +lean_dec(x_12); +x_92 = lean_ctor_get(x_4, 1); +lean_inc(x_92); +lean_dec(x_4); +x_93 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_93, 0, x_13); +lean_ctor_set(x_93, 1, x_14); +lean_ctor_set(x_93, 2, x_92); +x_94 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_94, 0, x_1); +lean_ctor_set(x_94, 1, x_2); +lean_ctor_set(x_94, 2, x_3); +lean_ctor_set(x_94, 3, x_93); +lean_ctor_set_tag(x_9, 1); +lean_ctor_set(x_9, 0, x_94); +return x_9; +} +} +} +else +{ +lean_object* x_95; lean_object* x_96; lean_object* x_97; +lean_dec(x_15); +lean_dec(x_12); +x_95 = lean_ctor_get(x_4, 1); +lean_inc(x_95); +lean_dec(x_4); +x_96 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_96, 0, x_13); +lean_ctor_set(x_96, 1, x_14); +lean_ctor_set(x_96, 2, x_95); +x_97 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_97, 0, x_1); +lean_ctor_set(x_97, 1, x_2); +lean_ctor_set(x_97, 2, x_3); +lean_ctor_set(x_97, 3, x_96); +lean_ctor_set_tag(x_9, 1); +lean_ctor_set(x_9, 0, x_97); +return x_9; +} +} +else +{ +lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_98 = lean_ctor_get(x_9, 1); +x_99 = lean_ctor_get(x_9, 0); +lean_inc(x_98); +lean_inc(x_99); +lean_dec(x_9); +x_100 = lean_ctor_get(x_98, 0); lean_inc(x_100); -lean_dec(x_6); -x_101 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_101, 0, x_15); -lean_ctor_set(x_101, 1, x_16); -lean_ctor_set(x_101, 2, x_100); -x_102 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_102, 0, x_3); -lean_ctor_set(x_102, 1, x_4); -lean_ctor_set(x_102, 2, x_5); -lean_ctor_set(x_102, 3, x_101); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_102); -return x_11; -} -} -else +x_101 = lean_ctor_get(x_98, 1); +lean_inc(x_101); +x_102 = l_Lean_Expr_getAppFn___main(x_99); +if (lean_obj_tag(x_102) == 4) { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_103 = lean_ctor_get(x_11, 1); -x_104 = lean_ctor_get(x_11, 0); +lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_103 = lean_ctor_get(x_102, 0); lean_inc(x_103); +x_104 = lean_ctor_get(x_102, 1); lean_inc(x_104); -lean_dec(x_11); -x_105 = lean_ctor_get(x_103, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_103, 1); -lean_inc(x_106); -x_107 = l_Lean_Expr_getAppFn___main(x_104); -if (lean_obj_tag(x_107) == 4) +lean_dec(x_102); +lean_inc(x_100); +x_105 = lean_environment_find(x_100, x_103); +if (lean_obj_tag(x_105) == 0) { -lean_object* x_108; lean_object* x_109; lean_object* x_110; -x_108 = lean_ctor_get(x_107, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_107, 1); -lean_inc(x_109); -lean_dec(x_107); -lean_inc(x_105); -x_110 = lean_environment_find(x_105, x_108); -if (lean_obj_tag(x_110) == 0) -{ -lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; -lean_dec(x_109); +lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_dec(x_104); -lean_dec(x_2); -lean_dec(x_1); -x_111 = lean_ctor_get(x_6, 1); -lean_inc(x_111); -lean_dec(x_6); -x_112 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_112, 0, x_105); -lean_ctor_set(x_112, 1, x_106); -lean_ctor_set(x_112, 2, x_111); -x_113 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_113, 0, x_3); -lean_ctor_set(x_113, 1, x_4); -lean_ctor_set(x_113, 2, x_5); -lean_ctor_set(x_113, 3, x_112); -x_114 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_103); -return x_114; +lean_dec(x_99); +x_106 = lean_ctor_get(x_4, 1); +lean_inc(x_106); +lean_dec(x_4); +x_107 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_107, 0, x_100); +lean_ctor_set(x_107, 1, x_101); +lean_ctor_set(x_107, 2, x_106); +x_108 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_108, 0, x_1); +lean_ctor_set(x_108, 1, x_2); +lean_ctor_set(x_108, 2, x_3); +lean_ctor_set(x_108, 3, x_107); +x_109 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_109, 0, x_108); +lean_ctor_set(x_109, 1, x_98); +return x_109; } else { -lean_object* x_115; -x_115 = lean_ctor_get(x_110, 0); -lean_inc(x_115); -lean_dec(x_110); -if (lean_obj_tag(x_115) == 5) +lean_object* x_110; +x_110 = lean_ctor_get(x_105, 0); +lean_inc(x_110); +lean_dec(x_105); +if (lean_obj_tag(x_110) == 5) { -lean_object* x_116; lean_object* x_117; -x_116 = lean_ctor_get(x_115, 0); -lean_inc(x_116); -lean_dec(x_115); -x_117 = lean_ctor_get(x_116, 4); +lean_object* x_111; lean_object* x_112; +x_111 = lean_ctor_get(x_110, 0); +lean_inc(x_111); +lean_dec(x_110); +x_112 = lean_ctor_get(x_111, 4); +lean_inc(x_112); +if (lean_obj_tag(x_112) == 0) +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; +lean_dec(x_111); +lean_dec(x_104); +lean_dec(x_99); +x_113 = lean_ctor_get(x_4, 1); +lean_inc(x_113); +lean_dec(x_4); +x_114 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_114, 0, x_100); +lean_ctor_set(x_114, 1, x_101); +lean_ctor_set(x_114, 2, x_113); +x_115 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_115, 0, x_1); +lean_ctor_set(x_115, 1, x_2); +lean_ctor_set(x_115, 2, x_3); +lean_ctor_set(x_115, 3, x_114); +x_116 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_116, 0, x_115); +lean_ctor_set(x_116, 1, x_98); +return x_116; +} +else +{ +lean_object* x_117; +x_117 = lean_ctor_get(x_112, 1); lean_inc(x_117); if (lean_obj_tag(x_117) == 0) { -lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; -lean_dec(x_116); -lean_dec(x_109); -lean_dec(x_104); -lean_dec(x_2); -lean_dec(x_1); -x_118 = lean_ctor_get(x_6, 1); +lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; uint8_t x_128; +x_118 = lean_ctor_get(x_111, 1); lean_inc(x_118); -lean_dec(x_6); -x_119 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_119, 0, x_105); -lean_ctor_set(x_119, 1, x_106); -lean_ctor_set(x_119, 2, x_118); -x_120 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_120, 0, x_3); -lean_ctor_set(x_120, 1, x_4); -lean_ctor_set(x_120, 2, x_5); -lean_ctor_set(x_120, 3, x_119); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_120); -lean_ctor_set(x_121, 1, x_103); -return x_121; +lean_dec(x_111); +x_119 = lean_ctor_get(x_112, 0); +lean_inc(x_119); +lean_dec(x_112); +x_120 = lean_unsigned_to_nat(0u); +x_121 = l_Lean_Expr_getAppNumArgsAux___main(x_99, x_120); +x_122 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_121); +x_123 = lean_mk_array(x_121, x_122); +x_124 = lean_unsigned_to_nat(1u); +x_125 = lean_nat_sub(x_121, x_124); +lean_dec(x_121); +x_126 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_99, x_123, x_125); +x_127 = lean_array_get_size(x_126); +x_128 = lean_nat_dec_eq(x_118, x_127); +lean_dec(x_127); +lean_dec(x_118); +if (x_128 == 0) +{ +lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; +lean_dec(x_126); +lean_dec(x_119); +lean_dec(x_104); +x_129 = lean_ctor_get(x_4, 1); +lean_inc(x_129); +lean_dec(x_4); +x_130 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_130, 0, x_100); +lean_ctor_set(x_130, 1, x_101); +lean_ctor_set(x_130, 2, x_129); +x_131 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_131, 0, x_1); +lean_ctor_set(x_131, 1, x_2); +lean_ctor_set(x_131, 2, x_3); +lean_ctor_set(x_131, 3, x_130); +x_132 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_132, 0, x_131); +lean_ctor_set(x_132, 1, x_98); +return x_132; } else { -lean_object* x_122; -x_122 = lean_ctor_get(x_117, 1); -lean_inc(x_122); -if (lean_obj_tag(x_122) == 0) -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; uint8_t x_133; -x_123 = lean_ctor_get(x_116, 1); -lean_inc(x_123); -lean_dec(x_116); -x_124 = lean_ctor_get(x_117, 0); -lean_inc(x_124); -lean_dec(x_117); -x_125 = lean_unsigned_to_nat(0u); -x_126 = l_Lean_Expr_getAppNumArgsAux___main(x_104, x_125); -x_127 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_126); -x_128 = lean_mk_array(x_126, x_127); -x_129 = lean_unsigned_to_nat(1u); -x_130 = lean_nat_sub(x_126, x_129); -lean_dec(x_126); -x_131 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_104, x_128, x_130); -x_132 = lean_array_get_size(x_131); -x_133 = lean_nat_dec_eq(x_123, x_132); -lean_dec(x_132); -lean_dec(x_123); -if (x_133 == 0) +lean_object* x_133; +lean_inc(x_119); +lean_inc(x_100); +x_133 = lean_environment_find(x_100, x_119); +if (lean_obj_tag(x_133) == 0) { lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; -lean_dec(x_131); -lean_dec(x_124); -lean_dec(x_109); -lean_dec(x_2); -lean_dec(x_1); -x_134 = lean_ctor_get(x_6, 1); +lean_dec(x_126); +lean_dec(x_119); +lean_dec(x_104); +x_134 = lean_ctor_get(x_4, 1); lean_inc(x_134); -lean_dec(x_6); +lean_dec(x_4); x_135 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_135, 0, x_105); -lean_ctor_set(x_135, 1, x_106); +lean_ctor_set(x_135, 0, x_100); +lean_ctor_set(x_135, 1, x_101); lean_ctor_set(x_135, 2, x_134); x_136 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_136, 0, x_3); -lean_ctor_set(x_136, 1, x_4); -lean_ctor_set(x_136, 2, x_5); +lean_ctor_set(x_136, 0, x_1); +lean_ctor_set(x_136, 1, x_2); +lean_ctor_set(x_136, 2, x_3); lean_ctor_set(x_136, 3, x_135); x_137 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_137, 0, x_136); -lean_ctor_set(x_137, 1, x_103); +lean_ctor_set(x_137, 1, x_98); return x_137; } else { -lean_object* x_138; -lean_inc(x_124); -lean_inc(x_105); -x_138 = lean_environment_find(x_105, x_124); -if (lean_obj_tag(x_138) == 0) +lean_object* x_138; lean_object* x_139; +lean_dec(x_133); +lean_dec(x_101); +lean_dec(x_100); +x_138 = l_Lean_mkConst(x_119, x_104); +lean_inc(x_4); +x_139 = l___private_Init_Lean_Meta_InferType_1__inferAppType(x_138, x_126, x_4, x_98); +if (lean_obj_tag(x_139) == 0) { -lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; -lean_dec(x_131); -lean_dec(x_124); -lean_dec(x_109); -lean_dec(x_2); -lean_dec(x_1); -x_139 = lean_ctor_get(x_6, 1); -lean_inc(x_139); -lean_dec(x_6); -x_140 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_140, 0, x_105); -lean_ctor_set(x_140, 1, x_106); -lean_ctor_set(x_140, 2, x_139); -x_141 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_141, 0, x_3); -lean_ctor_set(x_141, 1, x_4); -lean_ctor_set(x_141, 2, x_5); -lean_ctor_set(x_141, 3, x_140); -x_142 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_142, 0, x_141); -lean_ctor_set(x_142, 1, x_103); -return x_142; -} -else -{ -lean_object* x_143; lean_object* x_144; -lean_dec(x_138); -lean_dec(x_106); -lean_dec(x_105); -x_143 = l_Lean_mkConst(x_124, x_109); -lean_inc(x_6); -lean_inc(x_1); -x_144 = l___private_Init_Lean_Meta_InferType_1__inferAppType(x_1, x_2, x_143, x_131, x_6, x_103); -if (lean_obj_tag(x_144) == 0) -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; -x_145 = lean_ctor_get(x_144, 0); -lean_inc(x_145); -x_146 = lean_ctor_get(x_144, 1); -lean_inc(x_146); -lean_dec(x_144); -lean_inc(x_5); +lean_object* x_140; lean_object* x_141; lean_object* x_142; +x_140 = lean_ctor_get(x_139, 0); +lean_inc(x_140); +x_141 = lean_ctor_get(x_139, 1); +lean_inc(x_141); +lean_dec(x_139); lean_inc(x_4); lean_inc(x_3); +lean_inc_n(x_2, 2); lean_inc(x_1); -x_147 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_InferType_3__inferProjType___lambda__1), 8, 4); -lean_closure_set(x_147, 0, x_1); -lean_closure_set(x_147, 1, x_3); -lean_closure_set(x_147, 2, x_4); -lean_closure_set(x_147, 3, x_5); -x_148 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; +x_142 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_3__inferProjType___spec__1(x_1, x_2, x_3, x_2, x_2, x_140, x_4, x_141); +if (lean_obj_tag(x_142) == 0) +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; +x_143 = lean_ctor_get(x_142, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_142, 1); +lean_inc(x_144); +lean_dec(x_142); lean_inc(x_4); -x_149 = l_Nat_foldMAux___main___rarg(x_148, x_147, x_4, x_4, x_145); -lean_inc(x_6); -x_150 = lean_apply_2(x_149, x_6, x_146); -if (lean_obj_tag(x_150) == 0) +x_145 = l_Lean_Meta_whnf(x_143, x_4, x_144); +if (lean_obj_tag(x_145) == 0) { -lean_object* x_151; lean_object* x_152; lean_object* x_153; -x_151 = lean_ctor_get(x_150, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_150, 1); -lean_inc(x_152); -lean_dec(x_150); -lean_inc(x_6); -x_153 = lean_apply_3(x_1, x_151, x_6, x_152); -if (lean_obj_tag(x_153) == 0) +lean_object* x_146; +x_146 = lean_ctor_get(x_145, 0); +lean_inc(x_146); +if (lean_obj_tag(x_146) == 7) { -lean_object* x_154; -x_154 = lean_ctor_get(x_153, 0); -lean_inc(x_154); -if (lean_obj_tag(x_154) == 7) -{ -lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; -lean_dec(x_6); -lean_dec(x_5); +lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_dec(x_4); lean_dec(x_3); -x_155 = lean_ctor_get(x_153, 1); -lean_inc(x_155); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - lean_ctor_release(x_153, 1); - x_156 = x_153; +lean_dec(x_2); +lean_dec(x_1); +x_147 = lean_ctor_get(x_145, 1); +lean_inc(x_147); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + x_148 = x_145; } else { - lean_dec_ref(x_153); - x_156 = lean_box(0); + lean_dec_ref(x_145); + x_148 = lean_box(0); } -x_157 = lean_ctor_get(x_154, 1); -lean_inc(x_157); -lean_dec(x_154); -if (lean_is_scalar(x_156)) { - x_158 = lean_alloc_ctor(0, 2, 0); +x_149 = lean_ctor_get(x_146, 1); +lean_inc(x_149); +lean_dec(x_146); +if (lean_is_scalar(x_148)) { + x_150 = lean_alloc_ctor(0, 2, 0); } else { - x_158 = x_156; + x_150 = x_148; } -lean_ctor_set(x_158, 0, x_157); -lean_ctor_set(x_158, 1, x_155); -return x_158; +lean_ctor_set(x_150, 0, x_149); +lean_ctor_set(x_150, 1, x_147); +return x_150; } else { -lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_154); -x_159 = lean_ctor_get(x_153, 1); -lean_inc(x_159); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - lean_ctor_release(x_153, 1); - x_160 = x_153; +lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; +lean_dec(x_146); +x_151 = lean_ctor_get(x_145, 1); +lean_inc(x_151); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + x_152 = x_145; } else { - lean_dec_ref(x_153); - x_160 = lean_box(0); + lean_dec_ref(x_145); + x_152 = lean_box(0); } -x_161 = lean_ctor_get(x_159, 0); -lean_inc(x_161); -x_162 = lean_ctor_get(x_159, 1); -lean_inc(x_162); -x_163 = lean_ctor_get(x_6, 1); +x_153 = lean_ctor_get(x_151, 0); +lean_inc(x_153); +x_154 = lean_ctor_get(x_151, 1); +lean_inc(x_154); +x_155 = lean_ctor_get(x_4, 1); +lean_inc(x_155); +lean_dec(x_4); +x_156 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_156, 0, x_153); +lean_ctor_set(x_156, 1, x_154); +lean_ctor_set(x_156, 2, x_155); +x_157 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_157, 0, x_1); +lean_ctor_set(x_157, 1, x_2); +lean_ctor_set(x_157, 2, x_3); +lean_ctor_set(x_157, 3, x_156); +if (lean_is_scalar(x_152)) { + x_158 = lean_alloc_ctor(1, 2, 0); +} else { + x_158 = x_152; + lean_ctor_set_tag(x_158, 1); +} +lean_ctor_set(x_158, 0, x_157); +lean_ctor_set(x_158, 1, x_151); +return x_158; +} +} +else +{ +lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_159 = lean_ctor_get(x_145, 0); +lean_inc(x_159); +x_160 = lean_ctor_get(x_145, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_145)) { + lean_ctor_release(x_145, 0); + lean_ctor_release(x_145, 1); + x_161 = x_145; +} else { + lean_dec_ref(x_145); + x_161 = lean_box(0); +} +if (lean_is_scalar(x_161)) { + x_162 = lean_alloc_ctor(1, 2, 0); +} else { + x_162 = x_161; +} +lean_ctor_set(x_162, 0, x_159); +lean_ctor_set(x_162, 1, x_160); +return x_162; +} +} +else +{ +lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_163 = lean_ctor_get(x_142, 0); lean_inc(x_163); -lean_dec(x_6); -x_164 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_164, 0, x_161); -lean_ctor_set(x_164, 1, x_162); -lean_ctor_set(x_164, 2, x_163); -x_165 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_165, 0, x_3); -lean_ctor_set(x_165, 1, x_4); -lean_ctor_set(x_165, 2, x_5); -lean_ctor_set(x_165, 3, x_164); -if (lean_is_scalar(x_160)) { +x_164 = lean_ctor_get(x_142, 1); +lean_inc(x_164); +if (lean_is_exclusive(x_142)) { + lean_ctor_release(x_142, 0); + lean_ctor_release(x_142, 1); + x_165 = x_142; +} else { + lean_dec_ref(x_142); + x_165 = lean_box(0); +} +if (lean_is_scalar(x_165)) { x_166 = lean_alloc_ctor(1, 2, 0); } else { - x_166 = x_160; - lean_ctor_set_tag(x_166, 1); + x_166 = x_165; } -lean_ctor_set(x_166, 0, x_165); -lean_ctor_set(x_166, 1, x_159); +lean_ctor_set(x_166, 0, x_163); +lean_ctor_set(x_166, 1, x_164); return x_166; } } else { lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -lean_dec(x_6); -lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_167 = lean_ctor_get(x_153, 0); +lean_dec(x_2); +lean_dec(x_1); +x_167 = lean_ctor_get(x_139, 0); lean_inc(x_167); -x_168 = lean_ctor_get(x_153, 1); +x_168 = lean_ctor_get(x_139, 1); lean_inc(x_168); -if (lean_is_exclusive(x_153)) { - lean_ctor_release(x_153, 0); - lean_ctor_release(x_153, 1); - x_169 = x_153; +if (lean_is_exclusive(x_139)) { + lean_ctor_release(x_139, 0); + lean_ctor_release(x_139, 1); + x_169 = x_139; } else { - lean_dec_ref(x_153); + lean_dec_ref(x_139); x_169 = lean_box(0); } if (lean_is_scalar(x_169)) { @@ -1555,309 +1562,675 @@ lean_ctor_set(x_170, 1, x_168); return x_170; } } +} +} else { lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_171 = lean_ctor_get(x_150, 0); +lean_dec(x_117); +lean_dec(x_112); +lean_dec(x_111); +lean_dec(x_104); +lean_dec(x_99); +x_171 = lean_ctor_get(x_4, 1); lean_inc(x_171); -x_172 = lean_ctor_get(x_150, 1); -lean_inc(x_172); -if (lean_is_exclusive(x_150)) { - lean_ctor_release(x_150, 0); - lean_ctor_release(x_150, 1); - x_173 = x_150; -} else { - lean_dec_ref(x_150); - x_173 = lean_box(0); -} -if (lean_is_scalar(x_173)) { - x_174 = lean_alloc_ctor(1, 2, 0); -} else { - x_174 = x_173; -} -lean_ctor_set(x_174, 0, x_171); -lean_ctor_set(x_174, 1, x_172); +lean_dec(x_4); +x_172 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_172, 0, x_100); +lean_ctor_set(x_172, 1, x_101); +lean_ctor_set(x_172, 2, x_171); +x_173 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_173, 0, x_1); +lean_ctor_set(x_173, 1, x_2); +lean_ctor_set(x_173, 2, x_3); +lean_ctor_set(x_173, 3, x_172); +x_174 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_174, 0, x_173); +lean_ctor_set(x_174, 1, x_98); return x_174; } } +} else { lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_175 = lean_ctor_get(x_144, 0); +lean_dec(x_110); +lean_dec(x_104); +lean_dec(x_99); +x_175 = lean_ctor_get(x_4, 1); lean_inc(x_175); -x_176 = lean_ctor_get(x_144, 1); -lean_inc(x_176); -if (lean_is_exclusive(x_144)) { - lean_ctor_release(x_144, 0); - lean_ctor_release(x_144, 1); - x_177 = x_144; -} else { - lean_dec_ref(x_144); - x_177 = lean_box(0); -} -if (lean_is_scalar(x_177)) { - x_178 = lean_alloc_ctor(1, 2, 0); -} else { - x_178 = x_177; -} -lean_ctor_set(x_178, 0, x_175); -lean_ctor_set(x_178, 1, x_176); +lean_dec(x_4); +x_176 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_176, 0, x_100); +lean_ctor_set(x_176, 1, x_101); +lean_ctor_set(x_176, 2, x_175); +x_177 = lean_alloc_ctor(8, 4, 0); +lean_ctor_set(x_177, 0, x_1); +lean_ctor_set(x_177, 1, x_2); +lean_ctor_set(x_177, 2, x_3); +lean_ctor_set(x_177, 3, x_176); +x_178 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_178, 0, x_177); +lean_ctor_set(x_178, 1, x_98); return x_178; } } } -} else { lean_object* x_179; lean_object* x_180; lean_object* x_181; lean_object* x_182; -lean_dec(x_122); -lean_dec(x_117); -lean_dec(x_116); -lean_dec(x_109); -lean_dec(x_104); -lean_dec(x_2); -lean_dec(x_1); -x_179 = lean_ctor_get(x_6, 1); +lean_dec(x_102); +lean_dec(x_99); +x_179 = lean_ctor_get(x_4, 1); lean_inc(x_179); -lean_dec(x_6); +lean_dec(x_4); x_180 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_180, 0, x_105); -lean_ctor_set(x_180, 1, x_106); +lean_ctor_set(x_180, 0, x_100); +lean_ctor_set(x_180, 1, x_101); lean_ctor_set(x_180, 2, x_179); x_181 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_181, 0, x_3); -lean_ctor_set(x_181, 1, x_4); -lean_ctor_set(x_181, 2, x_5); +lean_ctor_set(x_181, 0, x_1); +lean_ctor_set(x_181, 1, x_2); +lean_ctor_set(x_181, 2, x_3); lean_ctor_set(x_181, 3, x_180); x_182 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_182, 0, x_181); -lean_ctor_set(x_182, 1, x_103); +lean_ctor_set(x_182, 1, x_98); return x_182; } } } else { -lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; -lean_dec(x_115); -lean_dec(x_109); -lean_dec(x_104); +uint8_t x_183; +lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_183 = lean_ctor_get(x_6, 1); -lean_inc(x_183); -lean_dec(x_6); -x_184 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_184, 0, x_105); -lean_ctor_set(x_184, 1, x_106); -lean_ctor_set(x_184, 2, x_183); -x_185 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_185, 0, x_3); -lean_ctor_set(x_185, 1, x_4); -lean_ctor_set(x_185, 2, x_5); -lean_ctor_set(x_185, 3, x_184); +x_183 = !lean_is_exclusive(x_9); +if (x_183 == 0) +{ +return x_9; +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_184 = lean_ctor_get(x_9, 0); +x_185 = lean_ctor_get(x_9, 1); +lean_inc(x_185); +lean_inc(x_184); +lean_dec(x_9); x_186 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_186, 0, x_185); -lean_ctor_set(x_186, 1, x_103); +lean_ctor_set(x_186, 0, x_184); +lean_ctor_set(x_186, 1, x_185); return x_186; } } } else { -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; -lean_dec(x_107); -lean_dec(x_104); +uint8_t x_187; +lean_dec(x_4); +lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_187 = lean_ctor_get(x_6, 1); -lean_inc(x_187); +x_187 = !lean_is_exclusive(x_6); +if (x_187 == 0) +{ +return x_6; +} +else +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; +x_188 = lean_ctor_get(x_6, 0); +x_189 = lean_ctor_get(x_6, 1); +lean_inc(x_189); +lean_inc(x_188); lean_dec(x_6); -x_188 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_188, 0, x_105); -lean_ctor_set(x_188, 1, x_106); -lean_ctor_set(x_188, 2, x_187); -x_189 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_189, 0, x_3); -lean_ctor_set(x_189, 1, x_4); -lean_ctor_set(x_189, 2, x_5); -lean_ctor_set(x_189, 3, x_188); x_190 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_190, 0, x_189); -lean_ctor_set(x_190, 1, x_103); +lean_ctor_set(x_190, 0, x_188); +lean_ctor_set(x_190, 1, x_189); return x_190; } } } +} +lean_object* l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_3__inferProjType___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Nat_foldMAux___main___at___private_Init_Lean_Meta_InferType_3__inferProjType___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_4); +return x_9; +} +} +lean_object* l_Lean_Meta_getLevel(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +lean_inc(x_2); +lean_inc(x_1); +x_4 = l_Lean_Meta_inferType(x_1, x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_4, 1); +lean_inc(x_6); +lean_dec(x_4); +lean_inc(x_2); +x_7 = l_Lean_Meta_whnf(x_5, x_2, x_6); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +switch (lean_obj_tag(x_8)) { +case 2: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; +x_9 = lean_ctor_get(x_7, 1); +lean_inc(x_9); +lean_dec(x_7); +x_10 = lean_ctor_get(x_8, 0); +lean_inc(x_10); +lean_dec(x_8); +lean_inc(x_10); +x_11 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_10, x_2, x_9); +if (lean_obj_tag(x_11) == 0) +{ +lean_object* x_12; uint8_t x_13; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_unbox(x_12); +lean_dec(x_12); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +lean_dec(x_1); +x_14 = lean_ctor_get(x_11, 1); +lean_inc(x_14); +lean_dec(x_11); +x_15 = l_Lean_Meta_mkFreshId___rarg(x_14); +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_15, 1); +lean_inc(x_17); +lean_dec(x_15); +x_18 = l_Lean_mkLevelMVar(x_16); +lean_inc(x_18); +x_19 = l_Lean_mkSort(x_18); +x_20 = l_Lean_Meta_assignExprMVar(x_10, x_19, x_2, x_17); +lean_dec(x_2); +if (lean_obj_tag(x_20) == 0) +{ +uint8_t x_21; +x_21 = !lean_is_exclusive(x_20); +if (x_21 == 0) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_20, 0); +lean_dec(x_22); +lean_ctor_set(x_20, 0, x_18); +return x_20; +} +else +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_20, 1); +lean_inc(x_23); +lean_dec(x_20); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_18); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +else +{ +uint8_t x_25; +lean_dec(x_18); +x_25 = !lean_is_exclusive(x_20); +if (x_25 == 0) +{ +return x_20; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_20, 0); +x_27 = lean_ctor_get(x_20, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_20); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} else { -uint8_t x_191; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); +uint8_t x_29; +lean_dec(x_10); +x_29 = !lean_is_exclusive(x_11); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_30 = lean_ctor_get(x_11, 1); +x_31 = lean_ctor_get(x_11, 0); +lean_dec(x_31); +x_32 = lean_ctor_get(x_30, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_30, 1); +lean_inc(x_33); +x_34 = lean_ctor_get(x_2, 1); +lean_inc(x_34); +lean_dec(x_2); +x_35 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_35, 0, x_32); +lean_ctor_set(x_35, 1, x_33); +lean_ctor_set(x_35, 2, x_34); +x_36 = lean_alloc_ctor(6, 2, 0); +lean_ctor_set(x_36, 0, x_1); +lean_ctor_set(x_36, 1, x_35); +lean_ctor_set_tag(x_11, 1); +lean_ctor_set(x_11, 0, x_36); +return x_11; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_37 = lean_ctor_get(x_11, 1); +lean_inc(x_37); +lean_dec(x_11); +x_38 = lean_ctor_get(x_37, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_37, 1); +lean_inc(x_39); +x_40 = lean_ctor_get(x_2, 1); +lean_inc(x_40); +lean_dec(x_2); +x_41 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_41, 0, x_38); +lean_ctor_set(x_41, 1, x_39); +lean_ctor_set(x_41, 2, x_40); +x_42 = lean_alloc_ctor(6, 2, 0); +lean_ctor_set(x_42, 0, x_1); +lean_ctor_set(x_42, 1, x_41); +x_43 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_43, 0, x_42); +lean_ctor_set(x_43, 1, x_37); +return x_43; +} +} +} +else +{ +uint8_t x_44; +lean_dec(x_10); lean_dec(x_2); lean_dec(x_1); -x_191 = !lean_is_exclusive(x_11); -if (x_191 == 0) +x_44 = !lean_is_exclusive(x_11); +if (x_44 == 0) { return x_11; } else { -lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_192 = lean_ctor_get(x_11, 0); -x_193 = lean_ctor_get(x_11, 1); -lean_inc(x_193); -lean_inc(x_192); +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_11, 0); +x_46 = lean_ctor_get(x_11, 1); +lean_inc(x_46); +lean_inc(x_45); lean_dec(x_11); -x_194 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_194, 0, x_192); -lean_ctor_set(x_194, 1, x_193); -return x_194; +x_47 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_47, 0, x_45); +lean_ctor_set(x_47, 1, x_46); +return x_47; } } } -else +case 3: { -uint8_t x_195; -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); +uint8_t x_48; lean_dec(x_2); lean_dec(x_1); -x_195 = !lean_is_exclusive(x_8); -if (x_195 == 0) +x_48 = !lean_is_exclusive(x_7); +if (x_48 == 0) { -return x_8; +lean_object* x_49; lean_object* x_50; +x_49 = lean_ctor_get(x_7, 0); +lean_dec(x_49); +x_50 = lean_ctor_get(x_8, 0); +lean_inc(x_50); +lean_dec(x_8); +lean_ctor_set(x_7, 0, x_50); +return x_7; } else { -lean_object* x_196; lean_object* x_197; lean_object* x_198; -x_196 = lean_ctor_get(x_8, 0); -x_197 = lean_ctor_get(x_8, 1); -lean_inc(x_197); -lean_inc(x_196); +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_7, 1); +lean_inc(x_51); +lean_dec(x_7); +x_52 = lean_ctor_get(x_8, 0); +lean_inc(x_52); lean_dec(x_8); -x_198 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_198, 0, x_196); -lean_ctor_set(x_198, 1, x_197); -return x_198; +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_52); +lean_ctor_set(x_53, 1, x_51); +return x_53; +} +} +default: +{ +uint8_t x_54; +lean_dec(x_8); +x_54 = !lean_is_exclusive(x_7); +if (x_54 == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_55 = lean_ctor_get(x_7, 1); +x_56 = lean_ctor_get(x_7, 0); +lean_dec(x_56); +x_57 = lean_ctor_get(x_55, 0); +lean_inc(x_57); +x_58 = lean_ctor_get(x_55, 1); +lean_inc(x_58); +x_59 = lean_ctor_get(x_2, 1); +lean_inc(x_59); +lean_dec(x_2); +x_60 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_60, 0, x_57); +lean_ctor_set(x_60, 1, x_58); +lean_ctor_set(x_60, 2, x_59); +x_61 = lean_alloc_ctor(6, 2, 0); +lean_ctor_set(x_61, 0, x_1); +lean_ctor_set(x_61, 1, x_60); +lean_ctor_set_tag(x_7, 1); +lean_ctor_set(x_7, 0, x_61); +return x_7; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; +x_62 = lean_ctor_get(x_7, 1); +lean_inc(x_62); +lean_dec(x_7); +x_63 = lean_ctor_get(x_62, 0); +lean_inc(x_63); +x_64 = lean_ctor_get(x_62, 1); +lean_inc(x_64); +x_65 = lean_ctor_get(x_2, 1); +lean_inc(x_65); +lean_dec(x_2); +x_66 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_66, 0, x_63); +lean_ctor_set(x_66, 1, x_64); +lean_ctor_set(x_66, 2, x_65); +x_67 = lean_alloc_ctor(6, 2, 0); +lean_ctor_set(x_67, 0, x_1); +lean_ctor_set(x_67, 1, x_66); +x_68 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_68, 0, x_67); +lean_ctor_set(x_68, 1, x_62); +return x_68; } } } } -lean_object* l_Lean_Meta_getLevelAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +else +{ +uint8_t x_69; +lean_dec(x_2); +lean_dec(x_1); +x_69 = !lean_is_exclusive(x_7); +if (x_69 == 0) +{ +return x_7; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_7, 0); +x_71 = lean_ctor_get(x_7, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_7); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_2); +lean_dec(x_1); +x_73 = !lean_is_exclusive(x_4); +if (x_73 == 0) +{ +return x_4; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_4, 0); +x_75 = lean_ctor_get(x_4, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_4); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +} +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_6; -lean_inc(x_4); -lean_inc(x_3); -x_6 = lean_apply_3(x_2, x_3, x_4, x_5); -if (lean_obj_tag(x_6) == 0) +lean_object* x_8; uint8_t x_9; +x_8 = lean_unsigned_to_nat(0u); +x_9 = lean_nat_dec_eq(x_3, x_8); +if (x_9 == 0) { -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); -lean_dec(x_6); -lean_inc(x_4); -x_9 = lean_apply_3(x_1, x_7, x_4, x_8); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -switch (lean_obj_tag(x_10)) { -case 2: -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_9, 1); -lean_inc(x_11); -lean_dec(x_9); -x_12 = lean_ctor_get(x_10, 0); -lean_inc(x_12); -lean_dec(x_10); -lean_inc(x_12); -x_13 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_12, x_4, x_11); +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_sub(x_3, x_10); +lean_dec(x_3); +x_12 = lean_array_fget(x_2, x_11); +lean_inc(x_6); +x_13 = l_Lean_Meta_inferType(x_12, x_6, x_7); if (lean_obj_tag(x_13) == 0) { -lean_object* x_14; uint8_t x_15; +lean_object* x_14; lean_object* x_15; lean_object* x_16; x_14 = lean_ctor_get(x_13, 0); lean_inc(x_14); -x_15 = lean_unbox(x_14); -lean_dec(x_14); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -lean_dec(x_3); -x_16 = lean_ctor_get(x_13, 1); -lean_inc(x_16); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); lean_dec(x_13); -x_17 = l_Lean_Meta_mkFreshId___rarg(x_16); -x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_6); +x_16 = l_Lean_Meta_getLevel(x_14, x_6, x_15); +if (lean_obj_tag(x_16) == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_16, 0); +lean_inc(x_17); +x_18 = lean_ctor_get(x_16, 1); lean_inc(x_18); -x_19 = lean_ctor_get(x_17, 1); -lean_inc(x_19); -lean_dec(x_17); -x_20 = l_Lean_mkLevelMVar(x_18); -lean_inc(x_20); -x_21 = l_Lean_mkSort(x_20); -x_22 = l_Lean_Meta_assignExprMVar(x_12, x_21, x_4, x_19); -lean_dec(x_4); -if (lean_obj_tag(x_22) == 0) -{ -uint8_t x_23; -x_23 = !lean_is_exclusive(x_22); -if (x_23 == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_22, 0); -lean_dec(x_24); -lean_ctor_set(x_22, 0, x_20); -return x_22; +lean_dec(x_16); +x_19 = l_Lean_mkLevelIMax(x_17, x_5); +x_3 = x_11; +x_4 = lean_box(0); +x_5 = x_19; +x_7 = x_18; +goto _start; } else { -lean_object* x_25; lean_object* x_26; -x_25 = lean_ctor_get(x_22, 1); +uint8_t x_21; +lean_dec(x_11); +lean_dec(x_6); +lean_dec(x_5); +x_21 = !lean_is_exclusive(x_16); +if (x_21 == 0) +{ +return x_16; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_16, 0); +x_23 = lean_ctor_get(x_16, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_16); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +else +{ +uint8_t x_25; +lean_dec(x_11); +lean_dec(x_6); +lean_dec(x_5); +x_25 = !lean_is_exclusive(x_13); +if (x_25 == 0) +{ +return x_13; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_13, 0); +x_27 = lean_ctor_get(x_13, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_13); +x_28 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_28, 0, x_26); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +} +else +{ +lean_object* x_29; +lean_dec(x_6); +lean_dec(x_3); +x_29 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_29, 0, x_5); +lean_ctor_set(x_29, 1, x_7); +return x_29; +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_4); +x_9 = lean_nat_dec_lt(x_5, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; +lean_dec(x_5); +lean_inc(x_6); +x_10 = l_Lean_Meta_getLevel(x_3, x_6, x_7); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_13 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1(x_1, x_1, x_2, lean_box(0), x_11, x_6, x_12); +if (lean_obj_tag(x_13) == 0) +{ +uint8_t x_14; +x_14 = !lean_is_exclusive(x_13); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_13, 0); +x_16 = l_Lean_Level_normalize___main(x_15); +lean_dec(x_15); +x_17 = l_Lean_mkSort(x_16); +lean_ctor_set(x_13, 0, x_17); +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_18 = lean_ctor_get(x_13, 0); +x_19 = lean_ctor_get(x_13, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_13); +x_20 = l_Lean_Level_normalize___main(x_18); +lean_dec(x_18); +x_21 = l_Lean_mkSort(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_19); +return x_22; +} +} +else +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_13); +if (x_23 == 0) +{ +return x_13; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_13, 0); +x_25 = lean_ctor_get(x_13, 1); lean_inc(x_25); -lean_dec(x_22); -x_26 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_26, 0, x_20); +lean_inc(x_24); +lean_dec(x_13); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); lean_ctor_set(x_26, 1, x_25); return x_26; } } +} else { uint8_t x_27; -lean_dec(x_20); -x_27 = !lean_is_exclusive(x_22); +lean_dec(x_6); +lean_dec(x_2); +x_27 = !lean_is_exclusive(x_10); if (x_27 == 0) { -return x_22; +return x_10; } else { lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_22, 0); -x_29 = lean_ctor_get(x_22, 1); +x_28 = lean_ctor_get(x_10, 0); +x_29 = lean_ctor_get(x_10, 1); lean_inc(x_29); lean_inc(x_28); -lean_dec(x_22); +lean_dec(x_10); x_30 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_30, 0, x_28); lean_ctor_set(x_30, 1, x_29); @@ -1867,346 +2240,285 @@ return x_30; } else { -uint8_t x_31; -lean_dec(x_12); -x_31 = !lean_is_exclusive(x_13); -if (x_31 == 0) +lean_object* x_31; lean_object* x_32; +x_31 = lean_array_fget(x_4, x_5); +lean_inc(x_6); +x_32 = l_Lean_Meta_getFVarLocalDecl(x_31, x_6, x_7); +if (lean_obj_tag(x_32) == 0) { -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_32 = lean_ctor_get(x_13, 1); -x_33 = lean_ctor_get(x_13, 0); -lean_dec(x_33); -x_34 = lean_ctor_get(x_32, 0); +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +x_34 = lean_ctor_get(x_32, 1); lean_inc(x_34); -x_35 = lean_ctor_get(x_32, 1); +lean_dec(x_32); +x_35 = l_Lean_LocalDecl_type(x_33); +lean_dec(x_33); +lean_inc(x_6); lean_inc(x_35); -x_36 = lean_ctor_get(x_4, 1); -lean_inc(x_36); -lean_dec(x_4); -x_37 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_37, 0, x_34); -lean_ctor_set(x_37, 1, x_35); -lean_ctor_set(x_37, 2, x_36); -x_38 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_38, 0, x_3); -lean_ctor_set(x_38, 1, x_37); -lean_ctor_set_tag(x_13, 1); -lean_ctor_set(x_13, 0, x_38); -return x_13; -} -else +x_36 = l_Lean_Meta_isClassQuick___main(x_35, x_6, x_34); +if (lean_obj_tag(x_36) == 0) { -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_39 = lean_ctor_get(x_13, 1); -lean_inc(x_39); -lean_dec(x_13); -x_40 = lean_ctor_get(x_39, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_39, 1); -lean_inc(x_41); -x_42 = lean_ctor_get(x_4, 1); +lean_object* x_37; +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +switch (lean_obj_tag(x_37)) { +case 0: +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +lean_dec(x_35); +lean_dec(x_31); +x_38 = lean_ctor_get(x_36, 1); +lean_inc(x_38); +lean_dec(x_36); +x_39 = lean_unsigned_to_nat(1u); +x_40 = lean_nat_add(x_5, x_39); +lean_dec(x_5); +x_5 = x_40; +x_7 = x_38; +goto _start; +} +case 1: +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; +lean_dec(x_35); +x_42 = lean_ctor_get(x_36, 1); lean_inc(x_42); -lean_dec(x_4); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_40); -lean_ctor_set(x_43, 1, x_41); -lean_ctor_set(x_43, 2, x_42); -x_44 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_44, 0, x_3); -lean_ctor_set(x_44, 1, x_43); -x_45 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_45, 0, x_44); -lean_ctor_set(x_45, 1, x_39); -return x_45; -} -} -} -else -{ -uint8_t x_46; -lean_dec(x_12); -lean_dec(x_4); -lean_dec(x_3); -x_46 = !lean_is_exclusive(x_13); +lean_dec(x_36); +x_43 = lean_ctor_get(x_37, 0); +lean_inc(x_43); +lean_dec(x_37); +x_44 = lean_unsigned_to_nat(1u); +x_45 = lean_nat_add(x_5, x_44); +lean_dec(x_5); +x_46 = !lean_is_exclusive(x_6); if (x_46 == 0) { -return x_13; -} -else -{ lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_47 = lean_ctor_get(x_13, 0); -x_48 = lean_ctor_get(x_13, 1); -lean_inc(x_48); -lean_inc(x_47); -lean_dec(x_13); -x_49 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -return x_49; -} -} -} -case 3: -{ -uint8_t x_50; -lean_dec(x_4); -lean_dec(x_3); -x_50 = !lean_is_exclusive(x_9); -if (x_50 == 0) -{ -lean_object* x_51; lean_object* x_52; -x_51 = lean_ctor_get(x_9, 0); -lean_dec(x_51); -x_52 = lean_ctor_get(x_10, 0); -lean_inc(x_52); -lean_dec(x_10); -lean_ctor_set(x_9, 0, x_52); -return x_9; +x_47 = lean_ctor_get(x_6, 2); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_31); +x_49 = lean_array_push(x_47, x_48); +lean_ctor_set(x_6, 2, x_49); +x_5 = x_45; +x_7 = x_42; +goto _start; } else { -lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_53 = lean_ctor_get(x_9, 1); +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_51 = lean_ctor_get(x_6, 0); +x_52 = lean_ctor_get(x_6, 1); +x_53 = lean_ctor_get(x_6, 2); lean_inc(x_53); -lean_dec(x_9); -x_54 = lean_ctor_get(x_10, 0); -lean_inc(x_54); -lean_dec(x_10); -x_55 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_53); -return x_55; +lean_inc(x_52); +lean_inc(x_51); +lean_dec(x_6); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_31); +x_55 = lean_array_push(x_53, x_54); +x_56 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_56, 0, x_51); +lean_ctor_set(x_56, 1, x_52); +lean_ctor_set(x_56, 2, x_55); +x_5 = x_45; +x_6 = x_56; +x_7 = x_42; +goto _start; } } default: { -uint8_t x_56; -lean_dec(x_10); -x_56 = !lean_is_exclusive(x_9); -if (x_56 == 0) +lean_object* x_58; lean_object* x_59; +x_58 = lean_ctor_get(x_36, 1); +lean_inc(x_58); +lean_dec(x_36); +lean_inc(x_6); +x_59 = l_Lean_Meta_isClassExpensive___main(x_35, x_6, x_58); +if (lean_obj_tag(x_59) == 0) { -lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_57 = lean_ctor_get(x_9, 1); -x_58 = lean_ctor_get(x_9, 0); -lean_dec(x_58); -x_59 = lean_ctor_get(x_57, 0); -lean_inc(x_59); -x_60 = lean_ctor_get(x_57, 1); +lean_object* x_60; +x_60 = lean_ctor_get(x_59, 0); lean_inc(x_60); -x_61 = lean_ctor_get(x_4, 1); +if (lean_obj_tag(x_60) == 0) +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; +lean_dec(x_31); +x_61 = lean_ctor_get(x_59, 1); lean_inc(x_61); -lean_dec(x_4); -x_62 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_62, 0, x_59); -lean_ctor_set(x_62, 1, x_60); -lean_ctor_set(x_62, 2, x_61); -x_63 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_63, 0, x_3); -lean_ctor_set(x_63, 1, x_62); -lean_ctor_set_tag(x_9, 1); -lean_ctor_set(x_9, 0, x_63); -return x_9; +lean_dec(x_59); +x_62 = lean_unsigned_to_nat(1u); +x_63 = lean_nat_add(x_5, x_62); +lean_dec(x_5); +x_5 = x_63; +x_7 = x_61; +goto _start; } else { -lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; -x_64 = lean_ctor_get(x_9, 1); -lean_inc(x_64); -lean_dec(x_9); -x_65 = lean_ctor_get(x_64, 0); +lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; +x_65 = lean_ctor_get(x_59, 1); lean_inc(x_65); -x_66 = lean_ctor_get(x_64, 1); +lean_dec(x_59); +x_66 = lean_ctor_get(x_60, 0); lean_inc(x_66); -x_67 = lean_ctor_get(x_4, 1); -lean_inc(x_67); -lean_dec(x_4); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_65); -lean_ctor_set(x_68, 1, x_66); -lean_ctor_set(x_68, 2, x_67); -x_69 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_69, 0, x_3); -lean_ctor_set(x_69, 1, x_68); -x_70 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_70, 0, x_69); -lean_ctor_set(x_70, 1, x_64); -return x_70; -} -} -} +lean_dec(x_60); +x_67 = lean_unsigned_to_nat(1u); +x_68 = lean_nat_add(x_5, x_67); +lean_dec(x_5); +x_69 = !lean_is_exclusive(x_6); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_6, 2); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_66); +lean_ctor_set(x_71, 1, x_31); +x_72 = lean_array_push(x_70, x_71); +lean_ctor_set(x_6, 2, x_72); +x_5 = x_68; +x_7 = x_65; +goto _start; } else { -uint8_t x_71; -lean_dec(x_4); -lean_dec(x_3); -x_71 = !lean_is_exclusive(x_9); -if (x_71 == 0) -{ -return x_9; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_72 = lean_ctor_get(x_9, 0); -x_73 = lean_ctor_get(x_9, 1); -lean_inc(x_73); -lean_inc(x_72); -lean_dec(x_9); -x_74 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -return x_74; -} -} -} -else -{ -uint8_t x_75; -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_75 = !lean_is_exclusive(x_6); -if (x_75 == 0) -{ -return x_6; -} -else -{ -lean_object* x_76; lean_object* x_77; lean_object* x_78; -x_76 = lean_ctor_get(x_6, 0); -x_77 = lean_ctor_get(x_6, 1); -lean_inc(x_77); +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_74 = lean_ctor_get(x_6, 0); +x_75 = lean_ctor_get(x_6, 1); +x_76 = lean_ctor_get(x_6, 2); lean_inc(x_76); +lean_inc(x_75); +lean_inc(x_74); lean_dec(x_6); -x_78 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_78, 0, x_76); -lean_ctor_set(x_78, 1, x_77); -return x_78; +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_66); +lean_ctor_set(x_77, 1, x_31); +x_78 = lean_array_push(x_76, x_77); +x_79 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_79, 0, x_74); +lean_ctor_set(x_79, 1, x_75); +lean_ctor_set(x_79, 2, x_78); +x_5 = x_68; +x_6 = x_79; +x_7 = x_65; +goto _start; +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_31); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_81 = !lean_is_exclusive(x_59); +if (x_81 == 0) +{ +return x_59; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_59, 0); +x_83 = lean_ctor_get(x_59, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_59); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; } } } } -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +} +else +{ +uint8_t x_85; +lean_dec(x_35); +lean_dec(x_31); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_85 = !lean_is_exclusive(x_36); +if (x_85 == 0) +{ +return x_36; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_36, 0); +x_87 = lean_ctor_get(x_36, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_36); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +else +{ +uint8_t x_89; +lean_dec(x_31); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_89 = !lean_is_exclusive(x_32); +if (x_89 == 0) +{ +return x_32; +} +else +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_90 = lean_ctor_get(x_32, 0); +x_91 = lean_ctor_get(x_32, 1); +lean_inc(x_91); +lean_inc(x_90); +lean_dec(x_32); +x_92 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_92, 0, x_90); +lean_ctor_set(x_92, 1, x_91); +return x_92; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { _start: { -lean_object* x_8; -lean_inc(x_1); -lean_inc(x_6); -x_8 = lean_apply_3(x_1, x_4, x_6, x_7); -if (lean_obj_tag(x_8) == 0) +uint8_t x_10; +x_10 = l_Lean_Expr_isForall(x_7); +if (x_10 == 0) { -lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_9 = lean_ctor_get(x_8, 0); -lean_inc(x_9); -x_10 = lean_ctor_get(x_8, 1); -lean_inc(x_10); -lean_dec(x_8); -x_11 = l_Lean_Meta_getLevelAux(x_2, x_1, x_9, x_6, x_10); +lean_object* x_11; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_inc(x_8); +x_11 = l_Lean_Meta_getLevel(x_1, x_8, x_9); if (lean_obj_tag(x_11) == 0) { -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; -x_13 = lean_ctor_get(x_11, 0); -x_14 = l_Lean_mkLevelIMax(x_13, x_5); -lean_ctor_set(x_11, 0, x_14); -return x_11; -} -else -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_15 = lean_ctor_get(x_11, 0); -x_16 = lean_ctor_get(x_11, 1); -lean_inc(x_16); -lean_inc(x_15); +lean_object* x_12; lean_object* x_13; lean_object* x_14; +x_12 = lean_ctor_get(x_11, 0); +lean_inc(x_12); +x_13 = lean_ctor_get(x_11, 1); +lean_inc(x_13); lean_dec(x_11); -x_17 = l_Lean_mkLevelIMax(x_15, x_5); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_16); -return x_18; -} -} -else -{ -uint8_t x_19; -lean_dec(x_5); -x_19 = !lean_is_exclusive(x_11); -if (x_19 == 0) -{ -return x_11; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_20 = lean_ctor_get(x_11, 0); -x_21 = lean_ctor_get(x_11, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_11); -x_22 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_22, 0, x_20); -lean_ctor_set(x_22, 1, x_21); -return x_22; -} -} -} -else -{ -uint8_t x_23; -lean_dec(x_6); -lean_dec(x_5); +x_14 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1(x_2, x_2, x_3, lean_box(0), x_12, x_8, x_13); lean_dec(x_2); -lean_dec(x_1); -x_23 = !lean_is_exclusive(x_8); -if (x_23 == 0) -{ -return x_8; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_8, 0); -x_25 = lean_ctor_get(x_8, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_8); -x_26 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_26, 0, x_24); -lean_ctor_set(x_26, 1, x_25); -return x_26; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -lean_inc(x_5); -lean_inc(x_2); -lean_inc(x_1); -x_7 = l_Lean_Meta_getLevelAux(x_1, x_2, x_4, x_5, x_6); -if (lean_obj_tag(x_7) == 0) -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_8 = lean_ctor_get(x_7, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_7, 1); -lean_inc(x_9); -lean_dec(x_7); -x_10 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__1___boxed), 7, 2); -lean_closure_set(x_10, 0, x_2); -lean_closure_set(x_10, 1, x_1); -x_11 = lean_array_get_size(x_3); -x_12 = l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1; -x_13 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___rarg(x_12, lean_box(0), x_3, x_10, x_11, lean_box(0), x_8); -lean_dec(x_11); -x_14 = lean_apply_2(x_13, x_5, x_9); if (lean_obj_tag(x_14) == 0) { uint8_t x_15; @@ -2264,23 +2576,22 @@ return x_27; else { uint8_t x_28; -lean_dec(x_5); +lean_dec(x_8); lean_dec(x_3); lean_dec(x_2); -lean_dec(x_1); -x_28 = !lean_is_exclusive(x_7); +x_28 = !lean_is_exclusive(x_11); if (x_28 == 0) { -return x_7; +return x_11; } else { lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_7, 0); -x_30 = lean_ctor_get(x_7, 1); +x_29 = lean_ctor_get(x_11, 0); +x_30 = lean_ctor_get(x_11, 1); lean_inc(x_30); lean_inc(x_29); -lean_dec(x_7); +lean_dec(x_11); x_31 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_31, 0, x_29); lean_ctor_set(x_31, 1, x_30); @@ -2288,266 +2599,1744 @@ return x_31; } } } +else +{ +lean_object* x_32; +lean_dec(x_1); +x_32 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__2(x_4, x_5, x_6, x_2, x_3, x_7, x_8, x_9); +return x_32; } -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { _start: { -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; -lean_inc(x_1); -x_6 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__2), 6, 2); -lean_closure_set(x_6, 0, x_1); -lean_closure_set(x_6, 1, x_2); -x_7 = lean_ctor_get(x_5, 2); -lean_inc(x_7); -x_8 = lean_ctor_get(x_4, 1); +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; uint8_t x_17; lean_inc(x_8); -lean_inc(x_1); -x_9 = lean_alloc_closure((void*)(l_Lean_Meta_isClassExpensive), 4, 1); -lean_closure_set(x_9, 0, x_1); -x_10 = lean_box(0); -x_11 = 0; -x_12 = l_Array_empty___closed__1; -x_13 = lean_unsigned_to_nat(0u); -x_14 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___rarg(x_1, x_9, x_11, x_10, x_6, x_8, x_12, x_13, x_3, x_4, x_5); -if (lean_obj_tag(x_14) == 0) -{ -uint8_t x_15; -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) -{ -lean_object* x_16; uint8_t x_17; -x_16 = lean_ctor_get(x_14, 1); -x_17 = !lean_is_exclusive(x_16); +x_13 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 1); +lean_closure_set(x_13, 0, x_8); +x_14 = lean_box(x_1); +lean_inc(x_3); +lean_inc(x_2); +lean_inc(x_7); +lean_inc(x_4); +lean_inc(x_8); +x_15 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___lambda__1___boxed), 9, 6); +lean_closure_set(x_15, 0, x_8); +lean_closure_set(x_15, 1, x_4); +lean_closure_set(x_15, 2, x_7); +lean_closure_set(x_15, 3, x_14); +lean_closure_set(x_15, 4, x_2); +lean_closure_set(x_15, 5, x_3); +x_16 = lean_array_get_size(x_9); +x_17 = lean_nat_dec_lt(x_10, x_16); +lean_dec(x_16); if (x_17 == 0) { lean_object* x_18; -x_18 = lean_ctor_get(x_16, 2); -lean_dec(x_18); -lean_ctor_set(x_16, 2, x_7); -return x_14; +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_18 = l_ReaderT_bind___at_Lean_Meta_isClassExpensive___main___spec__4___rarg(x_13, x_15, x_11, x_12); +return x_18; } else { -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_19 = lean_ctor_get(x_16, 0); -x_20 = lean_ctor_get(x_16, 1); -x_21 = lean_ctor_get(x_16, 3); -x_22 = lean_ctor_get(x_16, 4); -x_23 = lean_ctor_get(x_16, 5); -lean_inc(x_23); -lean_inc(x_22); +lean_object* x_19; lean_object* x_20; +lean_dec(x_15); +lean_dec(x_13); +x_19 = lean_array_fget(x_9, x_10); +lean_inc(x_11); +x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_11, x_12); +if (lean_obj_tag(x_20) == 0) +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_21 = lean_ctor_get(x_20, 0); lean_inc(x_21); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_16); -x_24 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_24, 0, x_19); -lean_ctor_set(x_24, 1, x_20); -lean_ctor_set(x_24, 2, x_7); -lean_ctor_set(x_24, 3, x_21); -lean_ctor_set(x_24, 4, x_22); -lean_ctor_set(x_24, 5, x_23); -lean_ctor_set(x_14, 1, x_24); -return x_14; -} -} -else +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +lean_dec(x_20); +x_23 = l_Lean_LocalDecl_type(x_21); +lean_dec(x_21); +lean_inc(x_11); +lean_inc(x_23); +x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_11, x_22); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_25 = lean_ctor_get(x_14, 1); -x_26 = lean_ctor_get(x_14, 0); +lean_object* x_25; +x_25 = lean_ctor_get(x_24, 0); lean_inc(x_25); +switch (lean_obj_tag(x_25)) { +case 0: +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +lean_dec(x_23); +lean_dec(x_19); +x_26 = lean_ctor_get(x_24, 1); lean_inc(x_26); -lean_dec(x_14); -x_27 = lean_ctor_get(x_25, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_25, 1); -lean_inc(x_28); -x_29 = lean_ctor_get(x_25, 3); -lean_inc(x_29); -x_30 = lean_ctor_get(x_25, 4); +lean_dec(x_24); +x_27 = lean_unsigned_to_nat(1u); +x_28 = lean_nat_add(x_10, x_27); +lean_dec(x_10); +x_10 = x_28; +x_12 = x_26; +goto _start; +} +case 1: +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; +lean_dec(x_23); +x_30 = lean_ctor_get(x_24, 1); lean_inc(x_30); -x_31 = lean_ctor_get(x_25, 5); +lean_dec(x_24); +x_31 = lean_ctor_get(x_25, 0); lean_inc(x_31); -if (lean_is_exclusive(x_25)) { - lean_ctor_release(x_25, 0); - lean_ctor_release(x_25, 1); - lean_ctor_release(x_25, 2); - lean_ctor_release(x_25, 3); - lean_ctor_release(x_25, 4); - lean_ctor_release(x_25, 5); - x_32 = x_25; -} else { - lean_dec_ref(x_25); - x_32 = lean_box(0); -} -if (lean_is_scalar(x_32)) { - x_33 = lean_alloc_ctor(0, 6, 0); -} else { - x_33 = x_32; -} -lean_ctor_set(x_33, 0, x_27); -lean_ctor_set(x_33, 1, x_28); -lean_ctor_set(x_33, 2, x_7); -lean_ctor_set(x_33, 3, x_29); -lean_ctor_set(x_33, 4, x_30); -lean_ctor_set(x_33, 5, x_31); -x_34 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_34, 0, x_26); -lean_ctor_set(x_34, 1, x_33); -return x_34; -} -} -else +lean_dec(x_25); +x_32 = lean_unsigned_to_nat(1u); +x_33 = lean_nat_add(x_10, x_32); +lean_dec(x_10); +x_34 = !lean_is_exclusive(x_11); +if (x_34 == 0) { -uint8_t x_35; -x_35 = !lean_is_exclusive(x_14); -if (x_35 == 0) -{ -lean_object* x_36; uint8_t x_37; -x_36 = lean_ctor_get(x_14, 1); -x_37 = !lean_is_exclusive(x_36); -if (x_37 == 0) -{ -lean_object* x_38; -x_38 = lean_ctor_get(x_36, 2); -lean_dec(x_38); -lean_ctor_set(x_36, 2, x_7); -return x_14; +lean_object* x_35; lean_object* x_36; lean_object* x_37; +x_35 = lean_ctor_get(x_11, 2); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_31); +lean_ctor_set(x_36, 1, x_19); +x_37 = lean_array_push(x_35, x_36); +lean_ctor_set(x_11, 2, x_37); +x_10 = x_33; +x_12 = x_30; +goto _start; } else { lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_36, 0); -x_40 = lean_ctor_get(x_36, 1); -x_41 = lean_ctor_get(x_36, 3); -x_42 = lean_ctor_get(x_36, 4); -x_43 = lean_ctor_get(x_36, 5); -lean_inc(x_43); -lean_inc(x_42); +x_39 = lean_ctor_get(x_11, 0); +x_40 = lean_ctor_get(x_11, 1); +x_41 = lean_ctor_get(x_11, 2); lean_inc(x_41); lean_inc(x_40); lean_inc(x_39); -lean_dec(x_36); -x_44 = lean_alloc_ctor(0, 6, 0); +lean_dec(x_11); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_31); +lean_ctor_set(x_42, 1, x_19); +x_43 = lean_array_push(x_41, x_42); +x_44 = lean_alloc_ctor(0, 3, 0); lean_ctor_set(x_44, 0, x_39); lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_7); -lean_ctor_set(x_44, 3, x_41); -lean_ctor_set(x_44, 4, x_42); -lean_ctor_set(x_44, 5, x_43); -lean_ctor_set(x_14, 1, x_44); -return x_14; +lean_ctor_set(x_44, 2, x_43); +x_10 = x_33; +x_11 = x_44; +x_12 = x_30; +goto _start; +} +} +default: +{ +lean_object* x_46; lean_object* x_47; +x_46 = lean_ctor_get(x_24, 1); +lean_inc(x_46); +lean_dec(x_24); +lean_inc(x_11); +x_47 = l_Lean_Meta_isClassExpensive___main(x_23, x_11, x_46); +if (lean_obj_tag(x_47) == 0) +{ +lean_object* x_48; +x_48 = lean_ctor_get(x_47, 0); +lean_inc(x_48); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +lean_dec(x_19); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +lean_dec(x_47); +x_50 = lean_unsigned_to_nat(1u); +x_51 = lean_nat_add(x_10, x_50); +lean_dec(x_10); +x_10 = x_51; +x_12 = x_49; +goto _start; +} +else +{ +lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; +x_53 = lean_ctor_get(x_47, 1); +lean_inc(x_53); +lean_dec(x_47); +x_54 = lean_ctor_get(x_48, 0); +lean_inc(x_54); +lean_dec(x_48); +x_55 = lean_unsigned_to_nat(1u); +x_56 = lean_nat_add(x_10, x_55); +lean_dec(x_10); +x_57 = !lean_is_exclusive(x_11); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_11, 2); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_54); +lean_ctor_set(x_59, 1, x_19); +x_60 = lean_array_push(x_58, x_59); +lean_ctor_set(x_11, 2, x_60); +x_10 = x_56; +x_12 = x_53; +goto _start; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_62 = lean_ctor_get(x_11, 0); +x_63 = lean_ctor_get(x_11, 1); +x_64 = lean_ctor_get(x_11, 2); +lean_inc(x_64); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_11); +x_65 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_65, 0, x_54); +lean_ctor_set(x_65, 1, x_19); +x_66 = lean_array_push(x_64, x_65); +x_67 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_67, 0, x_62); +lean_ctor_set(x_67, 1, x_63); +lean_ctor_set(x_67, 2, x_66); +x_10 = x_56; +x_11 = x_67; +x_12 = x_53; +goto _start; +} } } else { -lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_45 = lean_ctor_get(x_14, 1); -x_46 = lean_ctor_get(x_14, 0); -lean_inc(x_45); -lean_inc(x_46); -lean_dec(x_14); -x_47 = lean_ctor_get(x_45, 0); -lean_inc(x_47); -x_48 = lean_ctor_get(x_45, 1); -lean_inc(x_48); -x_49 = lean_ctor_get(x_45, 3); -lean_inc(x_49); -x_50 = lean_ctor_get(x_45, 4); -lean_inc(x_50); -x_51 = lean_ctor_get(x_45, 5); +uint8_t x_69; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_69 = !lean_is_exclusive(x_47); +if (x_69 == 0) +{ +return x_47; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_47, 0); +x_71 = lean_ctor_get(x_47, 1); +lean_inc(x_71); +lean_inc(x_70); +lean_dec(x_47); +x_72 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_72, 0, x_70); +lean_ctor_set(x_72, 1, x_71); +return x_72; +} +} +} +} +} +else +{ +uint8_t x_73; +lean_dec(x_23); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_73 = !lean_is_exclusive(x_24); +if (x_73 == 0) +{ +return x_24; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_74 = lean_ctor_get(x_24, 0); +x_75 = lean_ctor_get(x_24, 1); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_24); +x_76 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_76, 0, x_74); +lean_ctor_set(x_76, 1, x_75); +return x_76; +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_77 = !lean_is_exclusive(x_20); +if (x_77 == 0) +{ +return x_20; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_20, 0); +x_79 = lean_ctor_get(x_20, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_20); +x_80 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_80, 0, x_78); +lean_ctor_set(x_80, 1, x_79); +return x_80; +} +} +} +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_get_size(x_4); +x_9 = lean_nat_dec_lt(x_5, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; +lean_dec(x_5); +lean_inc(x_6); +x_10 = l_Lean_Meta_getLevel(x_3, x_6, x_7); +if (lean_obj_tag(x_10) == 0) +{ +lean_object* x_11; lean_object* x_12; lean_object* x_13; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_ctor_get(x_10, 1); +lean_inc(x_12); +lean_dec(x_10); +x_13 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1(x_1, x_1, x_2, lean_box(0), x_11, x_6, x_12); +if (lean_obj_tag(x_13) == 0) +{ +uint8_t x_14; +x_14 = !lean_is_exclusive(x_13); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_13, 0); +x_16 = l_Lean_Level_normalize___main(x_15); +lean_dec(x_15); +x_17 = l_Lean_mkSort(x_16); +lean_ctor_set(x_13, 0, x_17); +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_18 = lean_ctor_get(x_13, 0); +x_19 = lean_ctor_get(x_13, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_13); +x_20 = l_Lean_Level_normalize___main(x_18); +lean_dec(x_18); +x_21 = l_Lean_mkSort(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_19); +return x_22; +} +} +else +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_13); +if (x_23 == 0) +{ +return x_13; +} +else +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_13, 0); +x_25 = lean_ctor_get(x_13, 1); +lean_inc(x_25); +lean_inc(x_24); +lean_dec(x_13); +x_26 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +} +else +{ +uint8_t x_27; +lean_dec(x_6); +lean_dec(x_2); +x_27 = !lean_is_exclusive(x_10); +if (x_27 == 0) +{ +return x_10; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_10, 0); +x_29 = lean_ctor_get(x_10, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_10); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +} +else +{ +lean_object* x_31; lean_object* x_32; +x_31 = lean_array_fget(x_4, x_5); +lean_inc(x_6); +x_32 = l_Lean_Meta_getFVarLocalDecl(x_31, x_6, x_7); +if (lean_obj_tag(x_32) == 0) +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; +x_33 = lean_ctor_get(x_32, 0); +lean_inc(x_33); +x_34 = lean_ctor_get(x_32, 1); +lean_inc(x_34); +lean_dec(x_32); +x_35 = l_Lean_LocalDecl_type(x_33); +lean_dec(x_33); +lean_inc(x_6); +lean_inc(x_35); +x_36 = l_Lean_Meta_isClassQuick___main(x_35, x_6, x_34); +if (lean_obj_tag(x_36) == 0) +{ +lean_object* x_37; +x_37 = lean_ctor_get(x_36, 0); +lean_inc(x_37); +switch (lean_obj_tag(x_37)) { +case 0: +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; +lean_dec(x_35); +lean_dec(x_31); +x_38 = lean_ctor_get(x_36, 1); +lean_inc(x_38); +lean_dec(x_36); +x_39 = lean_unsigned_to_nat(1u); +x_40 = lean_nat_add(x_5, x_39); +lean_dec(x_5); +x_5 = x_40; +x_7 = x_38; +goto _start; +} +case 1: +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; +lean_dec(x_35); +x_42 = lean_ctor_get(x_36, 1); +lean_inc(x_42); +lean_dec(x_36); +x_43 = lean_ctor_get(x_37, 0); +lean_inc(x_43); +lean_dec(x_37); +x_44 = lean_unsigned_to_nat(1u); +x_45 = lean_nat_add(x_5, x_44); +lean_dec(x_5); +x_46 = !lean_is_exclusive(x_6); +if (x_46 == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_47 = lean_ctor_get(x_6, 2); +x_48 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_48, 0, x_43); +lean_ctor_set(x_48, 1, x_31); +x_49 = lean_array_push(x_47, x_48); +lean_ctor_set(x_6, 2, x_49); +x_5 = x_45; +x_7 = x_42; +goto _start; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_51 = lean_ctor_get(x_6, 0); +x_52 = lean_ctor_get(x_6, 1); +x_53 = lean_ctor_get(x_6, 2); +lean_inc(x_53); +lean_inc(x_52); lean_inc(x_51); -if (lean_is_exclusive(x_45)) { - lean_ctor_release(x_45, 0); - lean_ctor_release(x_45, 1); - lean_ctor_release(x_45, 2); - lean_ctor_release(x_45, 3); - lean_ctor_release(x_45, 4); - lean_ctor_release(x_45, 5); - x_52 = x_45; +lean_dec(x_6); +x_54 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_54, 0, x_43); +lean_ctor_set(x_54, 1, x_31); +x_55 = lean_array_push(x_53, x_54); +x_56 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_56, 0, x_51); +lean_ctor_set(x_56, 1, x_52); +lean_ctor_set(x_56, 2, x_55); +x_5 = x_45; +x_6 = x_56; +x_7 = x_42; +goto _start; +} +} +default: +{ +lean_object* x_58; lean_object* x_59; +x_58 = lean_ctor_get(x_36, 1); +lean_inc(x_58); +lean_dec(x_36); +lean_inc(x_6); +x_59 = l_Lean_Meta_isClassExpensive___main(x_35, x_6, x_58); +if (lean_obj_tag(x_59) == 0) +{ +lean_object* x_60; +x_60 = lean_ctor_get(x_59, 0); +lean_inc(x_60); +if (lean_obj_tag(x_60) == 0) +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; +lean_dec(x_31); +x_61 = lean_ctor_get(x_59, 1); +lean_inc(x_61); +lean_dec(x_59); +x_62 = lean_unsigned_to_nat(1u); +x_63 = lean_nat_add(x_5, x_62); +lean_dec(x_5); +x_5 = x_63; +x_7 = x_61; +goto _start; +} +else +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; +x_65 = lean_ctor_get(x_59, 1); +lean_inc(x_65); +lean_dec(x_59); +x_66 = lean_ctor_get(x_60, 0); +lean_inc(x_66); +lean_dec(x_60); +x_67 = lean_unsigned_to_nat(1u); +x_68 = lean_nat_add(x_5, x_67); +lean_dec(x_5); +x_69 = !lean_is_exclusive(x_6); +if (x_69 == 0) +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; +x_70 = lean_ctor_get(x_6, 2); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_66); +lean_ctor_set(x_71, 1, x_31); +x_72 = lean_array_push(x_70, x_71); +lean_ctor_set(x_6, 2, x_72); +x_5 = x_68; +x_7 = x_65; +goto _start; +} +else +{ +lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_74 = lean_ctor_get(x_6, 0); +x_75 = lean_ctor_get(x_6, 1); +x_76 = lean_ctor_get(x_6, 2); +lean_inc(x_76); +lean_inc(x_75); +lean_inc(x_74); +lean_dec(x_6); +x_77 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_77, 0, x_66); +lean_ctor_set(x_77, 1, x_31); +x_78 = lean_array_push(x_76, x_77); +x_79 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_79, 0, x_74); +lean_ctor_set(x_79, 1, x_75); +lean_ctor_set(x_79, 2, x_78); +x_5 = x_68; +x_6 = x_79; +x_7 = x_65; +goto _start; +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_31); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_81 = !lean_is_exclusive(x_59); +if (x_81 == 0) +{ +return x_59; +} +else +{ +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_59, 0); +x_83 = lean_ctor_get(x_59, 1); +lean_inc(x_83); +lean_inc(x_82); +lean_dec(x_59); +x_84 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_84, 0, x_82); +lean_ctor_set(x_84, 1, x_83); +return x_84; +} +} +} +} +} +else +{ +uint8_t x_85; +lean_dec(x_35); +lean_dec(x_31); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_85 = !lean_is_exclusive(x_36); +if (x_85 == 0) +{ +return x_36; +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_36, 0); +x_87 = lean_ctor_get(x_36, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_36); +x_88 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_88, 0, x_86); +lean_ctor_set(x_88, 1, x_87); +return x_88; +} +} +} +else +{ +uint8_t x_89; +lean_dec(x_31); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_3); +lean_dec(x_2); +x_89 = !lean_is_exclusive(x_32); +if (x_89 == 0) +{ +return x_32; +} +else +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; +x_90 = lean_ctor_get(x_32, 0); +x_91 = lean_ctor_get(x_32, 1); +lean_inc(x_91); +lean_inc(x_90); +lean_dec(x_32); +x_92 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_92, 0, x_90); +lean_ctor_set(x_92, 1, x_91); +return x_92; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__2(uint8_t x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +if (lean_obj_tag(x_6) == 7) +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; uint64_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_22 = lean_ctor_get(x_6, 0); +lean_inc(x_22); +x_23 = lean_ctor_get(x_6, 1); +lean_inc(x_23); +x_24 = lean_ctor_get(x_6, 2); +lean_inc(x_24); +x_25 = lean_ctor_get_uint64(x_6, sizeof(void*)*3); +lean_dec(x_6); +x_26 = lean_array_get_size(x_4); +lean_inc(x_4); +x_27 = lean_expr_instantiate_rev_range(x_23, x_5, x_26, x_4); +lean_dec(x_26); +lean_dec(x_23); +x_28 = l_Lean_Meta_mkFreshId___rarg(x_8); +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = (uint8_t)((x_25 << 24) >> 61); +lean_inc(x_29); +x_32 = lean_local_ctx_mk_local_decl(x_3, x_29, x_22, x_27, x_31); +x_33 = l_Lean_mkFVar(x_29); +x_34 = lean_array_push(x_4, x_33); +if (lean_obj_tag(x_2) == 0) +{ +x_3 = x_32; +x_4 = x_34; +x_6 = x_24; +x_8 = x_30; +goto _start; +} +else +{ +lean_object* x_36; lean_object* x_37; uint8_t x_38; +x_36 = lean_ctor_get(x_2, 0); +lean_inc(x_36); +x_37 = lean_array_get_size(x_34); +x_38 = lean_nat_dec_lt(x_37, x_36); +lean_dec(x_36); +if (x_38 == 0) +{ +lean_object* x_39; uint8_t x_40; +lean_dec(x_2); +lean_inc(x_34); +x_39 = lean_expr_instantiate_rev_range(x_24, x_5, x_37, x_34); +lean_dec(x_24); +x_40 = !lean_is_exclusive(x_7); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_7, 1); +lean_dec(x_41); +lean_ctor_set(x_7, 1, x_32); +x_42 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__5(x_34, x_37, x_39, x_34, x_5, x_7, x_30); +lean_dec(x_34); +return x_42; +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_43 = lean_ctor_get(x_7, 0); +x_44 = lean_ctor_get(x_7, 2); +lean_inc(x_44); +lean_inc(x_43); +lean_dec(x_7); +x_45 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_45, 0, x_43); +lean_ctor_set(x_45, 1, x_32); +lean_ctor_set(x_45, 2, x_44); +x_46 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__5(x_34, x_37, x_39, x_34, x_5, x_45, x_30); +lean_dec(x_34); +return x_46; +} +} +else +{ +lean_dec(x_37); +x_3 = x_32; +x_4 = x_34; +x_6 = x_24; +x_8 = x_30; +goto _start; +} +} +} +else +{ +lean_object* x_48; +x_48 = lean_box(0); +x_9 = x_48; +goto block_21; +} +block_21: +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; +lean_dec(x_9); +x_10 = lean_array_get_size(x_4); +lean_inc(x_4); +x_11 = lean_expr_instantiate_rev_range(x_6, x_5, x_10, x_4); +x_12 = !lean_is_exclusive(x_7); +if (x_12 == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_7, 1); +lean_dec(x_13); +lean_inc(x_3); +lean_ctor_set(x_7, 1, x_3); +if (x_1 == 0) +{ +lean_object* x_14; +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__3(x_4, x_10, x_11, x_4, x_5, x_7, x_8); +lean_dec(x_4); +return x_14; +} +else +{ +lean_object* x_15; +lean_inc(x_5); +lean_inc(x_4); +x_15 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_7, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_7, 0); +x_17 = lean_ctor_get(x_7, 2); +lean_inc(x_17); +lean_inc(x_16); +lean_dec(x_7); +lean_inc(x_3); +x_18 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_3); +lean_ctor_set(x_18, 2, x_17); +if (x_1 == 0) +{ +lean_object* x_19; +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +x_19 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__3(x_4, x_10, x_11, x_4, x_5, x_18, x_8); +lean_dec(x_4); +return x_19; +} +else +{ +lean_object* x_20; +lean_inc(x_5); +lean_inc(x_4); +x_20 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_10, x_11, x_4, x_5, x_18, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +return x_20; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; +x_4 = lean_ctor_get(x_3, 2); +lean_inc(x_4); +x_5 = lean_ctor_get(x_2, 1); +lean_inc(x_5); +x_6 = lean_box(0); +x_7 = 0; +x_8 = l_Array_empty___closed__1; +x_9 = lean_unsigned_to_nat(0u); +x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__2(x_7, x_6, x_5, x_8, x_9, x_1, x_2, x_3); +if (lean_obj_tag(x_10) == 0) +{ +uint8_t x_11; +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; uint8_t x_13; +x_12 = lean_ctor_get(x_10, 1); +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_12, 2); +lean_dec(x_14); +lean_ctor_set(x_12, 2, x_4); +return x_10; +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_15 = lean_ctor_get(x_12, 0); +x_16 = lean_ctor_get(x_12, 1); +x_17 = lean_ctor_get(x_12, 3); +x_18 = lean_ctor_get(x_12, 4); +x_19 = lean_ctor_get(x_12, 5); +lean_inc(x_19); +lean_inc(x_18); +lean_inc(x_17); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_12); +x_20 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_20, 0, x_15); +lean_ctor_set(x_20, 1, x_16); +lean_ctor_set(x_20, 2, x_4); +lean_ctor_set(x_20, 3, x_17); +lean_ctor_set(x_20, 4, x_18); +lean_ctor_set(x_20, 5, x_19); +lean_ctor_set(x_10, 1, x_20); +return x_10; +} +} +else +{ +lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_21 = lean_ctor_get(x_10, 1); +x_22 = lean_ctor_get(x_10, 0); +lean_inc(x_21); +lean_inc(x_22); +lean_dec(x_10); +x_23 = lean_ctor_get(x_21, 0); +lean_inc(x_23); +x_24 = lean_ctor_get(x_21, 1); +lean_inc(x_24); +x_25 = lean_ctor_get(x_21, 3); +lean_inc(x_25); +x_26 = lean_ctor_get(x_21, 4); +lean_inc(x_26); +x_27 = lean_ctor_get(x_21, 5); +lean_inc(x_27); +if (lean_is_exclusive(x_21)) { + lean_ctor_release(x_21, 0); + lean_ctor_release(x_21, 1); + lean_ctor_release(x_21, 2); + lean_ctor_release(x_21, 3); + lean_ctor_release(x_21, 4); + lean_ctor_release(x_21, 5); + x_28 = x_21; } else { - lean_dec_ref(x_45); - x_52 = lean_box(0); + lean_dec_ref(x_21); + x_28 = lean_box(0); } -if (lean_is_scalar(x_52)) { - x_53 = lean_alloc_ctor(0, 6, 0); +if (lean_is_scalar(x_28)) { + x_29 = lean_alloc_ctor(0, 6, 0); } else { - x_53 = x_52; + x_29 = x_28; } -lean_ctor_set(x_53, 0, x_47); -lean_ctor_set(x_53, 1, x_48); -lean_ctor_set(x_53, 2, x_7); -lean_ctor_set(x_53, 3, x_49); -lean_ctor_set(x_53, 4, x_50); -lean_ctor_set(x_53, 5, x_51); -x_54 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_54, 0, x_46); -lean_ctor_set(x_54, 1, x_53); -return x_54; +lean_ctor_set(x_29, 0, x_23); +lean_ctor_set(x_29, 1, x_24); +lean_ctor_set(x_29, 2, x_4); +lean_ctor_set(x_29, 3, x_25); +lean_ctor_set(x_29, 4, x_26); +lean_ctor_set(x_29, 5, x_27); +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_22); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +else +{ +uint8_t x_31; +x_31 = !lean_is_exclusive(x_10); +if (x_31 == 0) +{ +lean_object* x_32; uint8_t x_33; +x_32 = lean_ctor_get(x_10, 1); +x_33 = !lean_is_exclusive(x_32); +if (x_33 == 0) +{ +lean_object* x_34; +x_34 = lean_ctor_get(x_32, 2); +lean_dec(x_34); +lean_ctor_set(x_32, 2, x_4); +return x_10; +} +else +{ +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_35 = lean_ctor_get(x_32, 0); +x_36 = lean_ctor_get(x_32, 1); +x_37 = lean_ctor_get(x_32, 3); +x_38 = lean_ctor_get(x_32, 4); +x_39 = lean_ctor_get(x_32, 5); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_inc(x_36); +lean_inc(x_35); +lean_dec(x_32); +x_40 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_40, 0, x_35); +lean_ctor_set(x_40, 1, x_36); +lean_ctor_set(x_40, 2, x_4); +lean_ctor_set(x_40, 3, x_37); +lean_ctor_set(x_40, 4, x_38); +lean_ctor_set(x_40, 5, x_39); +lean_ctor_set(x_10, 1, x_40); +return x_10; +} +} +else +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_41 = lean_ctor_get(x_10, 1); +x_42 = lean_ctor_get(x_10, 0); +lean_inc(x_41); +lean_inc(x_42); +lean_dec(x_10); +x_43 = lean_ctor_get(x_41, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_41, 1); +lean_inc(x_44); +x_45 = lean_ctor_get(x_41, 3); +lean_inc(x_45); +x_46 = lean_ctor_get(x_41, 4); +lean_inc(x_46); +x_47 = lean_ctor_get(x_41, 5); +lean_inc(x_47); +if (lean_is_exclusive(x_41)) { + lean_ctor_release(x_41, 0); + lean_ctor_release(x_41, 1); + lean_ctor_release(x_41, 2); + lean_ctor_release(x_41, 3); + lean_ctor_release(x_41, 4); + lean_ctor_release(x_41, 5); + x_48 = x_41; +} else { + lean_dec_ref(x_41); + x_48 = lean_box(0); +} +if (lean_is_scalar(x_48)) { + x_49 = lean_alloc_ctor(0, 6, 0); +} else { + x_49 = x_48; +} +lean_ctor_set(x_49, 0, x_43); +lean_ctor_set(x_49, 1, x_44); +lean_ctor_set(x_49, 2, x_4); +lean_ctor_set(x_49, 3, x_45); +lean_ctor_set(x_49, 4, x_46); +lean_ctor_set(x_49, 5, x_47); +x_50 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_50, 0, x_42); +lean_ctor_set(x_50, 1, x_49); +return x_50; } } } } -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { lean_object* x_8; -x_8 = l___private_Init_Lean_Meta_InferType_4__inferForallType___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_3); +x_8 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_2); +lean_dec(x_1); return x_8; } } -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { _start: { -lean_object* x_6; -lean_inc(x_4); -x_6 = lean_apply_3(x_1, x_3, x_4, x_5); -if (lean_obj_tag(x_6) == 0) +lean_object* x_8; +x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +lean_dec(x_1); +return x_8; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +_start: { -lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); +uint8_t x_10; lean_object* x_11; +x_10 = lean_unbox(x_4); +lean_dec(x_4); +x_11 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___lambda__1(x_1, x_2, x_3, x_10, x_5, x_6, x_7, x_8, x_9); +return x_11; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12) { +_start: +{ +uint8_t x_13; lean_object* x_14; +x_13 = lean_unbox(x_1); +lean_dec(x_1); +x_14 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__4(x_13, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12); +lean_dec(x_9); lean_dec(x_6); -x_9 = l_Lean_Meta_mkForall(x_2, x_7, x_4, x_8); +lean_dec(x_5); +return x_14; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { +_start: +{ +lean_object* x_8; +x_8 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__5(x_1, x_2, x_3, x_4, x_5, x_6, x_7); +lean_dec(x_4); +lean_dec(x_1); +return x_8; +} +} +lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +uint8_t x_9; lean_object* x_10; +x_9 = lean_unbox(x_1); +lean_dec(x_1); +x_10 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at___private_Init_Lean_Meta_InferType_4__inferForallType___spec__2(x_9, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +return x_10; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_lt(x_4, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; +lean_dec(x_4); +lean_inc(x_5); +x_9 = l_Lean_Meta_inferType(x_2, x_5, x_6); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_9, 1); +lean_inc(x_11); +lean_dec(x_9); +x_12 = l_Lean_Meta_mkForall(x_1, x_10, x_5, x_11); +return x_12; +} +else +{ +uint8_t x_13; +lean_dec(x_5); +lean_dec(x_1); +x_13 = !lean_is_exclusive(x_9); +if (x_13 == 0) +{ return x_9; } else { -uint8_t x_10; -lean_dec(x_4); -lean_dec(x_2); -x_10 = !lean_is_exclusive(x_6); -if (x_10 == 0) -{ -return x_6; +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_9, 0); +x_15 = lean_ctor_get(x_9, 1); +lean_inc(x_15); +lean_inc(x_14); +lean_dec(x_9); +x_16 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_16, 0, x_14); +lean_ctor_set(x_16, 1, x_15); +return x_16; +} +} } else { -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_6, 0); -x_12 = lean_ctor_get(x_6, 1); -lean_inc(x_12); -lean_inc(x_11); -lean_dec(x_6); -x_13 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_13, 0, x_11); -lean_ctor_set(x_13, 1, x_12); -return x_13; +lean_object* x_17; lean_object* x_18; +x_17 = lean_array_fget(x_3, x_4); +lean_inc(x_5); +x_18 = l_Lean_Meta_getFVarLocalDecl(x_17, x_5, x_6); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_18, 1); +lean_inc(x_20); +lean_dec(x_18); +x_21 = l_Lean_LocalDecl_type(x_19); +lean_dec(x_19); +lean_inc(x_5); +lean_inc(x_21); +x_22 = l_Lean_Meta_isClassQuick___main(x_21, x_5, x_20); +if (lean_obj_tag(x_22) == 0) +{ +lean_object* x_23; +x_23 = lean_ctor_get(x_22, 0); +lean_inc(x_23); +switch (lean_obj_tag(x_23)) { +case 0: +{ +lean_object* x_24; lean_object* x_25; lean_object* x_26; +lean_dec(x_21); +lean_dec(x_17); +x_24 = lean_ctor_get(x_22, 1); +lean_inc(x_24); +lean_dec(x_22); +x_25 = lean_unsigned_to_nat(1u); +x_26 = lean_nat_add(x_4, x_25); +lean_dec(x_4); +x_4 = x_26; +x_6 = x_24; +goto _start; +} +case 1: +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; +lean_dec(x_21); +x_28 = lean_ctor_get(x_22, 1); +lean_inc(x_28); +lean_dec(x_22); +x_29 = lean_ctor_get(x_23, 0); +lean_inc(x_29); +lean_dec(x_23); +x_30 = lean_unsigned_to_nat(1u); +x_31 = lean_nat_add(x_4, x_30); +lean_dec(x_4); +x_32 = !lean_is_exclusive(x_5); +if (x_32 == 0) +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_5, 2); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_29); +lean_ctor_set(x_34, 1, x_17); +x_35 = lean_array_push(x_33, x_34); +lean_ctor_set(x_5, 2, x_35); +x_4 = x_31; +x_6 = x_28; +goto _start; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_37 = lean_ctor_get(x_5, 0); +x_38 = lean_ctor_get(x_5, 1); +x_39 = lean_ctor_get(x_5, 2); +lean_inc(x_39); +lean_inc(x_38); +lean_inc(x_37); +lean_dec(x_5); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_17); +x_41 = lean_array_push(x_39, x_40); +x_42 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_42, 0, x_37); +lean_ctor_set(x_42, 1, x_38); +lean_ctor_set(x_42, 2, x_41); +x_4 = x_31; +x_5 = x_42; +x_6 = x_28; +goto _start; +} +} +default: +{ +lean_object* x_44; lean_object* x_45; +x_44 = lean_ctor_get(x_22, 1); +lean_inc(x_44); +lean_dec(x_22); +lean_inc(x_5); +x_45 = l_Lean_Meta_isClassExpensive___main(x_21, x_5, x_44); +if (lean_obj_tag(x_45) == 0) +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_45, 0); +lean_inc(x_46); +if (lean_obj_tag(x_46) == 0) +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_17); +x_47 = lean_ctor_get(x_45, 1); +lean_inc(x_47); +lean_dec(x_45); +x_48 = lean_unsigned_to_nat(1u); +x_49 = lean_nat_add(x_4, x_48); +lean_dec(x_4); +x_4 = x_49; +x_6 = x_47; +goto _start; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; uint8_t x_55; +x_51 = lean_ctor_get(x_45, 1); +lean_inc(x_51); +lean_dec(x_45); +x_52 = lean_ctor_get(x_46, 0); +lean_inc(x_52); +lean_dec(x_46); +x_53 = lean_unsigned_to_nat(1u); +x_54 = lean_nat_add(x_4, x_53); +lean_dec(x_4); +x_55 = !lean_is_exclusive(x_5); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_5, 2); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_52); +lean_ctor_set(x_57, 1, x_17); +x_58 = lean_array_push(x_56, x_57); +lean_ctor_set(x_5, 2, x_58); +x_4 = x_54; +x_6 = x_51; +goto _start; +} +else +{ +lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_60 = lean_ctor_get(x_5, 0); +x_61 = lean_ctor_get(x_5, 1); +x_62 = lean_ctor_get(x_5, 2); +lean_inc(x_62); +lean_inc(x_61); +lean_inc(x_60); +lean_dec(x_5); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_52); +lean_ctor_set(x_63, 1, x_17); +x_64 = lean_array_push(x_62, x_63); +x_65 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_65, 0, x_60); +lean_ctor_set(x_65, 1, x_61); +lean_ctor_set(x_65, 2, x_64); +x_4 = x_54; +x_5 = x_65; +x_6 = x_51; +goto _start; +} +} +} +else +{ +uint8_t x_67; +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_67 = !lean_is_exclusive(x_45); +if (x_67 == 0) +{ +return x_45; +} +else +{ +lean_object* x_68; lean_object* x_69; lean_object* x_70; +x_68 = lean_ctor_get(x_45, 0); +x_69 = lean_ctor_get(x_45, 1); +lean_inc(x_69); +lean_inc(x_68); +lean_dec(x_45); +x_70 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_70, 0, x_68); +lean_ctor_set(x_70, 1, x_69); +return x_70; } } } } -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +} +else +{ +uint8_t x_71; +lean_dec(x_21); +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_71 = !lean_is_exclusive(x_22); +if (x_71 == 0) +{ +return x_22; +} +else +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_72 = lean_ctor_get(x_22, 0); +x_73 = lean_ctor_get(x_22, 1); +lean_inc(x_73); +lean_inc(x_72); +lean_dec(x_22); +x_74 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_74, 0, x_72); +lean_ctor_set(x_74, 1, x_73); +return x_74; +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_17); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_75 = !lean_is_exclusive(x_18); +if (x_75 == 0) +{ +return x_18; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_18, 0); +x_77 = lean_ctor_get(x_18, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_18); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +} +} +lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_6; lean_object* x_7; -x_6 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_InferType_5__inferLambdaType___lambda__1), 5, 1); -lean_closure_set(x_6, 0, x_2); -x_7 = l_Lean_Meta_lambdaTelescope___rarg(x_1, x_3, x_6, x_4, x_5); +lean_object* x_7; +switch (lean_obj_tag(x_4)) { +case 6: +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; uint64_t x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; uint8_t x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_18 = lean_ctor_get(x_4, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_4, 1); +lean_inc(x_19); +x_20 = lean_ctor_get(x_4, 2); +lean_inc(x_20); +x_21 = lean_ctor_get_uint64(x_4, sizeof(void*)*3); +lean_dec(x_4); +x_22 = lean_array_get_size(x_2); +lean_inc(x_2); +x_23 = lean_expr_instantiate_rev_range(x_19, x_3, x_22, x_2); +lean_dec(x_22); +lean_dec(x_19); +x_24 = l_Lean_Meta_mkFreshId___rarg(x_6); +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +x_27 = (uint8_t)((x_21 << 24) >> 61); +lean_inc(x_25); +x_28 = lean_local_ctx_mk_local_decl(x_1, x_25, x_18, x_23, x_27); +x_29 = l_Lean_mkFVar(x_25); +x_30 = lean_array_push(x_2, x_29); +x_1 = x_28; +x_2 = x_30; +x_4 = x_20; +x_6 = x_26; +goto _start; +} +case 8: +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_32 = lean_ctor_get(x_4, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_4, 1); +lean_inc(x_33); +x_34 = lean_ctor_get(x_4, 2); +lean_inc(x_34); +x_35 = lean_ctor_get(x_4, 3); +lean_inc(x_35); +lean_dec(x_4); +x_36 = lean_array_get_size(x_2); +lean_inc(x_2); +x_37 = lean_expr_instantiate_rev_range(x_33, x_3, x_36, x_2); +lean_dec(x_33); +lean_inc(x_2); +x_38 = lean_expr_instantiate_rev_range(x_34, x_3, x_36, x_2); +lean_dec(x_36); +lean_dec(x_34); +x_39 = l_Lean_Meta_mkFreshId___rarg(x_6); +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +lean_dec(x_39); +lean_inc(x_40); +x_42 = lean_local_ctx_mk_let_decl(x_1, x_40, x_32, x_37, x_38); +x_43 = l_Lean_mkFVar(x_40); +x_44 = lean_array_push(x_2, x_43); +x_1 = x_42; +x_2 = x_44; +x_4 = x_35; +x_6 = x_41; +goto _start; +} +default: +{ +lean_object* x_46; +x_46 = lean_box(0); +x_7 = x_46; +goto block_17; +} +} +block_17: +{ +lean_object* x_8; lean_object* x_9; uint8_t x_10; +lean_dec(x_7); +x_8 = lean_array_get_size(x_2); +lean_inc(x_2); +x_9 = lean_expr_instantiate_rev_range(x_4, x_3, x_8, x_2); +lean_dec(x_8); +lean_dec(x_4); +x_10 = !lean_is_exclusive(x_5); +if (x_10 == 0) +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_5, 1); +lean_dec(x_11); +lean_ctor_set(x_5, 1, x_1); +lean_inc(x_2); +x_12 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__3(x_2, x_9, x_2, x_3, x_5, x_6); +lean_dec(x_2); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_ctor_get(x_5, 0); +x_14 = lean_ctor_get(x_5, 2); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_5); +x_15 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_15, 0, x_13); +lean_ctor_set(x_15, 1, x_1); +lean_ctor_set(x_15, 2, x_14); +lean_inc(x_2); +x_16 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__3(x_2, x_9, x_2, x_3, x_15, x_6); +lean_dec(x_2); +return x_16; +} +} +} +} +lean_object* l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_4 = lean_ctor_get(x_3, 2); +lean_inc(x_4); +x_5 = lean_ctor_get(x_2, 1); +lean_inc(x_5); +x_6 = l_Array_empty___closed__1; +x_7 = lean_unsigned_to_nat(0u); +x_8 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__2(x_5, x_6, x_7, x_1, x_2, x_3); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; uint8_t x_11; +x_10 = lean_ctor_get(x_8, 1); +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) +{ +lean_object* x_12; +x_12 = lean_ctor_get(x_10, 2); +lean_dec(x_12); +lean_ctor_set(x_10, 2, x_4); +return x_8; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_13 = lean_ctor_get(x_10, 0); +x_14 = lean_ctor_get(x_10, 1); +x_15 = lean_ctor_get(x_10, 3); +x_16 = lean_ctor_get(x_10, 4); +x_17 = lean_ctor_get(x_10, 5); +lean_inc(x_17); +lean_inc(x_16); +lean_inc(x_15); +lean_inc(x_14); +lean_inc(x_13); +lean_dec(x_10); +x_18 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_18, 0, x_13); +lean_ctor_set(x_18, 1, x_14); +lean_ctor_set(x_18, 2, x_4); +lean_ctor_set(x_18, 3, x_15); +lean_ctor_set(x_18, 4, x_16); +lean_ctor_set(x_18, 5, x_17); +lean_ctor_set(x_8, 1, x_18); +return x_8; +} +} +else +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_19 = lean_ctor_get(x_8, 1); +x_20 = lean_ctor_get(x_8, 0); +lean_inc(x_19); +lean_inc(x_20); +lean_dec(x_8); +x_21 = lean_ctor_get(x_19, 0); +lean_inc(x_21); +x_22 = lean_ctor_get(x_19, 1); +lean_inc(x_22); +x_23 = lean_ctor_get(x_19, 3); +lean_inc(x_23); +x_24 = lean_ctor_get(x_19, 4); +lean_inc(x_24); +x_25 = lean_ctor_get(x_19, 5); +lean_inc(x_25); +if (lean_is_exclusive(x_19)) { + lean_ctor_release(x_19, 0); + lean_ctor_release(x_19, 1); + lean_ctor_release(x_19, 2); + lean_ctor_release(x_19, 3); + lean_ctor_release(x_19, 4); + lean_ctor_release(x_19, 5); + x_26 = x_19; +} else { + lean_dec_ref(x_19); + x_26 = lean_box(0); +} +if (lean_is_scalar(x_26)) { + x_27 = lean_alloc_ctor(0, 6, 0); +} else { + x_27 = x_26; +} +lean_ctor_set(x_27, 0, x_21); +lean_ctor_set(x_27, 1, x_22); +lean_ctor_set(x_27, 2, x_4); +lean_ctor_set(x_27, 3, x_23); +lean_ctor_set(x_27, 4, x_24); +lean_ctor_set(x_27, 5, x_25); +x_28 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_28, 0, x_20); +lean_ctor_set(x_28, 1, x_27); +return x_28; +} +} +else +{ +uint8_t x_29; +x_29 = !lean_is_exclusive(x_8); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_8, 1); +x_31 = !lean_is_exclusive(x_30); +if (x_31 == 0) +{ +lean_object* x_32; +x_32 = lean_ctor_get(x_30, 2); +lean_dec(x_32); +lean_ctor_set(x_30, 2, x_4); +return x_8; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_33 = lean_ctor_get(x_30, 0); +x_34 = lean_ctor_get(x_30, 1); +x_35 = lean_ctor_get(x_30, 3); +x_36 = lean_ctor_get(x_30, 4); +x_37 = lean_ctor_get(x_30, 5); +lean_inc(x_37); +lean_inc(x_36); +lean_inc(x_35); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_30); +x_38 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_38, 0, x_33); +lean_ctor_set(x_38, 1, x_34); +lean_ctor_set(x_38, 2, x_4); +lean_ctor_set(x_38, 3, x_35); +lean_ctor_set(x_38, 4, x_36); +lean_ctor_set(x_38, 5, x_37); +lean_ctor_set(x_8, 1, x_38); +return x_8; +} +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +x_39 = lean_ctor_get(x_8, 1); +x_40 = lean_ctor_get(x_8, 0); +lean_inc(x_39); +lean_inc(x_40); +lean_dec(x_8); +x_41 = lean_ctor_get(x_39, 0); +lean_inc(x_41); +x_42 = lean_ctor_get(x_39, 1); +lean_inc(x_42); +x_43 = lean_ctor_get(x_39, 3); +lean_inc(x_43); +x_44 = lean_ctor_get(x_39, 4); +lean_inc(x_44); +x_45 = lean_ctor_get(x_39, 5); +lean_inc(x_45); +if (lean_is_exclusive(x_39)) { + lean_ctor_release(x_39, 0); + lean_ctor_release(x_39, 1); + lean_ctor_release(x_39, 2); + lean_ctor_release(x_39, 3); + lean_ctor_release(x_39, 4); + lean_ctor_release(x_39, 5); + x_46 = x_39; +} else { + lean_dec_ref(x_39); + x_46 = lean_box(0); +} +if (lean_is_scalar(x_46)) { + x_47 = lean_alloc_ctor(0, 6, 0); +} else { + x_47 = x_46; +} +lean_ctor_set(x_47, 0, x_41); +lean_ctor_set(x_47, 1, x_42); +lean_ctor_set(x_47, 2, x_4); +lean_ctor_set(x_47, 3, x_43); +lean_ctor_set(x_47, 4, x_44); +lean_ctor_set(x_47, 5, x_45); +x_48 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_48, 0, x_40); +lean_ctor_set(x_48, 1, x_47); +return x_48; +} +} +} +} +lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__1(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; +x_7 = l_Lean_Meta_withNewLocalInstances___main___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__3(x_1, x_2, x_3, x_4, x_5, x_6); +lean_dec(x_3); return x_7; } } @@ -3878,11968 +5667,775 @@ x_8 = l_PersistentHashMap_insertAux___main___at___private_Init_Lean_Meta_InferTy return x_8; } } -lean_object* l_Lean_Meta_inferTypeAuxAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_10__inferTypeAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_5; -switch (lean_obj_tag(x_2)) { +switch (lean_obj_tag(x_1)) { case 0: { -lean_object* x_59; lean_object* x_60; lean_object* x_61; -lean_dec(x_3); -lean_dec(x_1); -x_59 = lean_ctor_get(x_2, 0); -lean_inc(x_59); +lean_object* x_4; lean_object* x_5; lean_object* x_6; lean_dec(x_2); -x_60 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_60, 0, x_59); -x_61 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_61, 0, x_60); -lean_ctor_set(x_61, 1, x_4); -return x_61; +x_4 = lean_ctor_get(x_1, 0); +lean_inc(x_4); +lean_dec(x_1); +x_5 = lean_alloc_ctor(4, 1, 0); +lean_ctor_set(x_5, 0, x_4); +x_6 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_6, 0, x_5); +lean_ctor_set(x_6, 1, x_3); +return x_6; } case 1: { -lean_object* x_62; lean_object* x_63; +lean_object* x_7; lean_object* x_8; +x_7 = lean_ctor_get(x_1, 0); +lean_inc(x_7); lean_dec(x_1); -x_62 = lean_ctor_get(x_2, 0); -lean_inc(x_62); -lean_dec(x_2); -x_63 = l___private_Init_Lean_Meta_InferType_8__inferFVarType(x_62, x_3, x_4); -return x_63; +x_8 = l___private_Init_Lean_Meta_InferType_8__inferFVarType(x_7, x_2, x_3); +return x_8; } case 2: { -lean_object* x_64; lean_object* x_65; +lean_object* x_9; lean_object* x_10; +x_9 = lean_ctor_get(x_1, 0); +lean_inc(x_9); lean_dec(x_1); -x_64 = lean_ctor_get(x_2, 0); -lean_inc(x_64); +x_10 = l___private_Init_Lean_Meta_InferType_7__inferMVarType(x_9, x_2, x_3); lean_dec(x_2); -x_65 = l___private_Init_Lean_Meta_InferType_7__inferMVarType(x_64, x_3, x_4); -lean_dec(x_3); -return x_65; +return x_10; } case 3: { -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -lean_dec(x_3); -lean_dec(x_1); -x_66 = lean_ctor_get(x_2, 0); -lean_inc(x_66); +lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_dec(x_2); -x_67 = l_Lean_mkLevelSucc(x_66); -x_68 = l_Lean_mkSort(x_67); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_68); -lean_ctor_set(x_69, 1, x_4); -return x_69; +x_11 = lean_ctor_get(x_1, 0); +lean_inc(x_11); +lean_dec(x_1); +x_12 = l_Lean_mkLevelSucc(x_11); +x_13 = l_Lean_mkSort(x_12); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_3); +return x_14; } case 4: { -lean_object* x_70; lean_object* x_71; lean_object* x_72; +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_1, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_1, 1); +lean_inc(x_16); lean_dec(x_1); -x_70 = lean_ctor_get(x_2, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_2, 1); -lean_inc(x_71); +x_17 = l___private_Init_Lean_Meta_InferType_2__inferConstType(x_15, x_16, x_2, x_3); lean_dec(x_2); -x_72 = l___private_Init_Lean_Meta_InferType_2__inferConstType(x_70, x_71, x_3, x_4); -lean_dec(x_3); -return x_72; +return x_17; } case 5: { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_73 = lean_ctor_get(x_2, 0); -lean_inc(x_73); +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_18 = lean_ctor_get(x_1, 0); +lean_inc(x_18); +x_19 = l_Lean_Expr_getAppFn___main(x_18); +lean_dec(x_18); +x_20 = lean_unsigned_to_nat(0u); +x_21 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_20); +x_22 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_21); +x_23 = lean_mk_array(x_21, x_22); +x_24 = lean_unsigned_to_nat(1u); +x_25 = lean_nat_sub(x_21, x_24); +lean_dec(x_21); lean_inc(x_1); -x_74 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAuxAux___main), 4, 1); -lean_closure_set(x_74, 0, x_1); -x_75 = l_Lean_Expr_getAppFn___main(x_73); -lean_dec(x_73); -x_76 = lean_unsigned_to_nat(0u); -x_77 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_76); -x_78 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_77); -x_79 = lean_mk_array(x_77, x_78); -x_80 = lean_unsigned_to_nat(1u); -x_81 = lean_nat_sub(x_77, x_80); -lean_dec(x_77); -lean_inc(x_2); -x_82 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_79, x_81); -x_83 = lean_ctor_get(x_4, 2); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 0); -lean_inc(x_84); -lean_dec(x_83); -x_85 = l_Lean_ExprStructEq_HasBeq; -x_86 = l_Lean_ExprStructEq_Hashable; -lean_inc(x_2); -x_87 = l_PersistentHashMap_find___rarg(x_85, x_86, x_84, x_2); -lean_dec(x_84); -if (lean_obj_tag(x_87) == 0) +x_26 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_23, x_25); +x_27 = lean_ctor_get(x_3, 2); +lean_inc(x_27); +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +lean_dec(x_27); +x_29 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_28, x_1); +lean_dec(x_28); +if (lean_obj_tag(x_29) == 0) { -lean_object* x_88; -x_88 = l___private_Init_Lean_Meta_InferType_1__inferAppType(x_1, x_74, x_75, x_82, x_3, x_4); -if (lean_obj_tag(x_88) == 0) +lean_object* x_30; +x_30 = l___private_Init_Lean_Meta_InferType_1__inferAppType(x_19, x_26, x_2, x_3); +if (lean_obj_tag(x_30) == 0) { -lean_object* x_89; lean_object* x_90; uint8_t x_91; -x_89 = lean_ctor_get(x_88, 1); -lean_inc(x_89); -x_90 = lean_ctor_get(x_89, 2); -lean_inc(x_90); -x_91 = !lean_is_exclusive(x_88); -if (x_91 == 0) +lean_object* x_31; lean_object* x_32; uint8_t x_33; +x_31 = lean_ctor_get(x_30, 1); +lean_inc(x_31); +x_32 = lean_ctor_get(x_31, 2); +lean_inc(x_32); +x_33 = !lean_is_exclusive(x_30); +if (x_33 == 0) { -lean_object* x_92; lean_object* x_93; uint8_t x_94; -x_92 = lean_ctor_get(x_88, 0); -x_93 = lean_ctor_get(x_88, 1); -lean_dec(x_93); -x_94 = !lean_is_exclusive(x_89); -if (x_94 == 0) +lean_object* x_34; lean_object* x_35; uint8_t x_36; +x_34 = lean_ctor_get(x_30, 0); +x_35 = lean_ctor_get(x_30, 1); +lean_dec(x_35); +x_36 = !lean_is_exclusive(x_31); +if (x_36 == 0) { -lean_object* x_95; uint8_t x_96; -x_95 = lean_ctor_get(x_89, 2); -lean_dec(x_95); -x_96 = !lean_is_exclusive(x_90); -if (x_96 == 0) +lean_object* x_37; uint8_t x_38; +x_37 = lean_ctor_get(x_31, 2); +lean_dec(x_37); +x_38 = !lean_is_exclusive(x_32); +if (x_38 == 0) { -lean_object* x_97; lean_object* x_98; -x_97 = lean_ctor_get(x_90, 0); -lean_inc(x_92); -x_98 = l_PersistentHashMap_insert___rarg(x_85, x_86, x_97, x_2, x_92); -lean_ctor_set(x_90, 0, x_98); -return x_88; +lean_object* x_39; lean_object* x_40; +x_39 = lean_ctor_get(x_32, 0); +lean_inc(x_34); +x_40 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_39, x_1, x_34); +lean_ctor_set(x_32, 0, x_40); +return x_30; } else { -lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; -x_99 = lean_ctor_get(x_90, 0); -x_100 = lean_ctor_get(x_90, 1); -lean_inc(x_100); -lean_inc(x_99); -lean_dec(x_90); -lean_inc(x_92); -x_101 = l_PersistentHashMap_insert___rarg(x_85, x_86, x_99, x_2, x_92); -x_102 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_102, 0, x_101); -lean_ctor_set(x_102, 1, x_100); -lean_ctor_set(x_89, 2, x_102); -return x_88; +lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_41 = lean_ctor_get(x_32, 0); +x_42 = lean_ctor_get(x_32, 1); +lean_inc(x_42); +lean_inc(x_41); +lean_dec(x_32); +lean_inc(x_34); +x_43 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_41, x_1, x_34); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_42); +lean_ctor_set(x_31, 2, x_44); +return x_30; } } else { -lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; -x_103 = lean_ctor_get(x_89, 0); -x_104 = lean_ctor_get(x_89, 1); -x_105 = lean_ctor_get(x_89, 3); -x_106 = lean_ctor_get(x_89, 4); -x_107 = lean_ctor_get(x_89, 5); -lean_inc(x_107); -lean_inc(x_106); -lean_inc(x_105); -lean_inc(x_104); -lean_inc(x_103); -lean_dec(x_89); -x_108 = lean_ctor_get(x_90, 0); -lean_inc(x_108); -x_109 = lean_ctor_get(x_90, 1); -lean_inc(x_109); -if (lean_is_exclusive(x_90)) { - lean_ctor_release(x_90, 0); - lean_ctor_release(x_90, 1); - x_110 = x_90; +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; +x_45 = lean_ctor_get(x_31, 0); +x_46 = lean_ctor_get(x_31, 1); +x_47 = lean_ctor_get(x_31, 3); +x_48 = lean_ctor_get(x_31, 4); +x_49 = lean_ctor_get(x_31, 5); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_31); +x_50 = lean_ctor_get(x_32, 0); +lean_inc(x_50); +x_51 = lean_ctor_get(x_32, 1); +lean_inc(x_51); +if (lean_is_exclusive(x_32)) { + lean_ctor_release(x_32, 0); + lean_ctor_release(x_32, 1); + x_52 = x_32; } else { - lean_dec_ref(x_90); - x_110 = lean_box(0); + lean_dec_ref(x_32); + x_52 = lean_box(0); } -lean_inc(x_92); -x_111 = l_PersistentHashMap_insert___rarg(x_85, x_86, x_108, x_2, x_92); -if (lean_is_scalar(x_110)) { - x_112 = lean_alloc_ctor(0, 2, 0); +lean_inc(x_34); +x_53 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_50, x_1, x_34); +if (lean_is_scalar(x_52)) { + x_54 = lean_alloc_ctor(0, 2, 0); } else { - x_112 = x_110; + x_54 = x_52; } -lean_ctor_set(x_112, 0, x_111); -lean_ctor_set(x_112, 1, x_109); -x_113 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_113, 0, x_103); -lean_ctor_set(x_113, 1, x_104); -lean_ctor_set(x_113, 2, x_112); -lean_ctor_set(x_113, 3, x_105); -lean_ctor_set(x_113, 4, x_106); -lean_ctor_set(x_113, 5, x_107); -lean_ctor_set(x_88, 1, x_113); -return x_88; +lean_ctor_set(x_54, 0, x_53); +lean_ctor_set(x_54, 1, x_51); +x_55 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_55, 0, x_45); +lean_ctor_set(x_55, 1, x_46); +lean_ctor_set(x_55, 2, x_54); +lean_ctor_set(x_55, 3, x_47); +lean_ctor_set(x_55, 4, x_48); +lean_ctor_set(x_55, 5, x_49); +lean_ctor_set(x_30, 1, x_55); +return x_30; } } else { -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; -x_114 = lean_ctor_get(x_88, 0); -lean_inc(x_114); -lean_dec(x_88); -x_115 = lean_ctor_get(x_89, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_89, 1); -lean_inc(x_116); -x_117 = lean_ctor_get(x_89, 3); -lean_inc(x_117); -x_118 = lean_ctor_get(x_89, 4); -lean_inc(x_118); -x_119 = lean_ctor_get(x_89, 5); -lean_inc(x_119); -if (lean_is_exclusive(x_89)) { - lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - lean_ctor_release(x_89, 2); - lean_ctor_release(x_89, 3); - lean_ctor_release(x_89, 4); - lean_ctor_release(x_89, 5); - x_120 = x_89; +lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_56 = lean_ctor_get(x_30, 0); +lean_inc(x_56); +lean_dec(x_30); +x_57 = lean_ctor_get(x_31, 0); +lean_inc(x_57); +x_58 = lean_ctor_get(x_31, 1); +lean_inc(x_58); +x_59 = lean_ctor_get(x_31, 3); +lean_inc(x_59); +x_60 = lean_ctor_get(x_31, 4); +lean_inc(x_60); +x_61 = lean_ctor_get(x_31, 5); +lean_inc(x_61); +if (lean_is_exclusive(x_31)) { + lean_ctor_release(x_31, 0); + lean_ctor_release(x_31, 1); + lean_ctor_release(x_31, 2); + lean_ctor_release(x_31, 3); + lean_ctor_release(x_31, 4); + lean_ctor_release(x_31, 5); + x_62 = x_31; } else { - lean_dec_ref(x_89); - x_120 = lean_box(0); + lean_dec_ref(x_31); + x_62 = lean_box(0); } -x_121 = lean_ctor_get(x_90, 0); -lean_inc(x_121); -x_122 = lean_ctor_get(x_90, 1); -lean_inc(x_122); -if (lean_is_exclusive(x_90)) { - lean_ctor_release(x_90, 0); - lean_ctor_release(x_90, 1); - x_123 = x_90; +x_63 = lean_ctor_get(x_32, 0); +lean_inc(x_63); +x_64 = lean_ctor_get(x_32, 1); +lean_inc(x_64); +if (lean_is_exclusive(x_32)) { + lean_ctor_release(x_32, 0); + lean_ctor_release(x_32, 1); + x_65 = x_32; } else { - lean_dec_ref(x_90); - x_123 = lean_box(0); + lean_dec_ref(x_32); + x_65 = lean_box(0); } -lean_inc(x_114); -x_124 = l_PersistentHashMap_insert___rarg(x_85, x_86, x_121, x_2, x_114); -if (lean_is_scalar(x_123)) { - x_125 = lean_alloc_ctor(0, 2, 0); +lean_inc(x_56); +x_66 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_63, x_1, x_56); +if (lean_is_scalar(x_65)) { + x_67 = lean_alloc_ctor(0, 2, 0); } else { - x_125 = x_123; + x_67 = x_65; } -lean_ctor_set(x_125, 0, x_124); -lean_ctor_set(x_125, 1, x_122); -if (lean_is_scalar(x_120)) { - x_126 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_64); +if (lean_is_scalar(x_62)) { + x_68 = lean_alloc_ctor(0, 6, 0); } else { - x_126 = x_120; + x_68 = x_62; } -lean_ctor_set(x_126, 0, x_115); -lean_ctor_set(x_126, 1, x_116); -lean_ctor_set(x_126, 2, x_125); -lean_ctor_set(x_126, 3, x_117); -lean_ctor_set(x_126, 4, x_118); -lean_ctor_set(x_126, 5, x_119); -x_127 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_127, 0, x_114); -lean_ctor_set(x_127, 1, x_126); -return x_127; +lean_ctor_set(x_68, 0, x_57); +lean_ctor_set(x_68, 1, x_58); +lean_ctor_set(x_68, 2, x_67); +lean_ctor_set(x_68, 3, x_59); +lean_ctor_set(x_68, 4, x_60); +lean_ctor_set(x_68, 5, x_61); +x_69 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_69, 0, x_56); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } else { -uint8_t x_128; -lean_dec(x_2); -x_128 = !lean_is_exclusive(x_88); -if (x_128 == 0) +uint8_t x_70; +lean_dec(x_1); +x_70 = !lean_is_exclusive(x_30); +if (x_70 == 0) { -return x_88; +return x_30; } else { -lean_object* x_129; lean_object* x_130; lean_object* x_131; -x_129 = lean_ctor_get(x_88, 0); -x_130 = lean_ctor_get(x_88, 1); -lean_inc(x_130); -lean_inc(x_129); -lean_dec(x_88); -x_131 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_131, 0, x_129); -lean_ctor_set(x_131, 1, x_130); -return x_131; +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_30, 0); +x_72 = lean_ctor_get(x_30, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_30); +x_73 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_73, 0, x_71); +lean_ctor_set(x_73, 1, x_72); +return x_73; } } } else { -lean_object* x_132; lean_object* x_133; -lean_dec(x_82); -lean_dec(x_75); -lean_dec(x_74); -lean_dec(x_3); +lean_object* x_74; lean_object* x_75; +lean_dec(x_26); +lean_dec(x_19); lean_dec(x_2); lean_dec(x_1); -x_132 = lean_ctor_get(x_87, 0); -lean_inc(x_132); -lean_dec(x_87); -x_133 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_133, 0, x_132); -lean_ctor_set(x_133, 1, x_4); -return x_133; +x_74 = lean_ctor_get(x_29, 0); +lean_inc(x_74); +lean_dec(x_29); +x_75 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_75, 0, x_74); +lean_ctor_set(x_75, 1, x_3); +return x_75; } } case 7: { -lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_3, 2); +lean_inc(x_76); +x_77 = lean_ctor_get(x_76, 0); +lean_inc(x_77); +lean_dec(x_76); +x_78 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_77, x_1); +lean_dec(x_77); +if (lean_obj_tag(x_78) == 0) +{ +lean_object* x_79; lean_inc(x_1); -x_134 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAuxAux___main), 4, 1); -lean_closure_set(x_134, 0, x_1); -x_135 = lean_ctor_get(x_4, 2); -lean_inc(x_135); -x_136 = lean_ctor_get(x_135, 0); -lean_inc(x_136); -lean_dec(x_135); -x_137 = l_Lean_ExprStructEq_HasBeq; -x_138 = l_Lean_ExprStructEq_Hashable; -lean_inc(x_2); -x_139 = l_PersistentHashMap_find___rarg(x_137, x_138, x_136, x_2); -lean_dec(x_136); -if (lean_obj_tag(x_139) == 0) +x_79 = l___private_Init_Lean_Meta_InferType_4__inferForallType(x_1, x_2, x_3); +if (lean_obj_tag(x_79) == 0) { -lean_object* x_140; -lean_inc(x_2); -x_140 = l___private_Init_Lean_Meta_InferType_4__inferForallType(x_1, x_134, x_2, x_3, x_4); -if (lean_obj_tag(x_140) == 0) +lean_object* x_80; lean_object* x_81; uint8_t x_82; +x_80 = lean_ctor_get(x_79, 1); +lean_inc(x_80); +x_81 = lean_ctor_get(x_80, 2); +lean_inc(x_81); +x_82 = !lean_is_exclusive(x_79); +if (x_82 == 0) { -lean_object* x_141; lean_object* x_142; uint8_t x_143; -x_141 = lean_ctor_get(x_140, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_141, 2); -lean_inc(x_142); -x_143 = !lean_is_exclusive(x_140); -if (x_143 == 0) +lean_object* x_83; lean_object* x_84; uint8_t x_85; +x_83 = lean_ctor_get(x_79, 0); +x_84 = lean_ctor_get(x_79, 1); +lean_dec(x_84); +x_85 = !lean_is_exclusive(x_80); +if (x_85 == 0) { -lean_object* x_144; lean_object* x_145; uint8_t x_146; -x_144 = lean_ctor_get(x_140, 0); -x_145 = lean_ctor_get(x_140, 1); -lean_dec(x_145); -x_146 = !lean_is_exclusive(x_141); -if (x_146 == 0) +lean_object* x_86; uint8_t x_87; +x_86 = lean_ctor_get(x_80, 2); +lean_dec(x_86); +x_87 = !lean_is_exclusive(x_81); +if (x_87 == 0) { -lean_object* x_147; uint8_t x_148; -x_147 = lean_ctor_get(x_141, 2); -lean_dec(x_147); -x_148 = !lean_is_exclusive(x_142); -if (x_148 == 0) -{ -lean_object* x_149; lean_object* x_150; -x_149 = lean_ctor_get(x_142, 0); -lean_inc(x_144); -x_150 = l_PersistentHashMap_insert___rarg(x_137, x_138, x_149, x_2, x_144); -lean_ctor_set(x_142, 0, x_150); -return x_140; +lean_object* x_88; lean_object* x_89; +x_88 = lean_ctor_get(x_81, 0); +lean_inc(x_83); +x_89 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_88, x_1, x_83); +lean_ctor_set(x_81, 0, x_89); +return x_79; } else { -lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; -x_151 = lean_ctor_get(x_142, 0); -x_152 = lean_ctor_get(x_142, 1); +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +x_90 = lean_ctor_get(x_81, 0); +x_91 = lean_ctor_get(x_81, 1); +lean_inc(x_91); +lean_inc(x_90); +lean_dec(x_81); +lean_inc(x_83); +x_92 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_90, x_1, x_83); +x_93 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_93, 0, x_92); +lean_ctor_set(x_93, 1, x_91); +lean_ctor_set(x_80, 2, x_93); +return x_79; +} +} +else +{ +lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +x_94 = lean_ctor_get(x_80, 0); +x_95 = lean_ctor_get(x_80, 1); +x_96 = lean_ctor_get(x_80, 3); +x_97 = lean_ctor_get(x_80, 4); +x_98 = lean_ctor_get(x_80, 5); +lean_inc(x_98); +lean_inc(x_97); +lean_inc(x_96); +lean_inc(x_95); +lean_inc(x_94); +lean_dec(x_80); +x_99 = lean_ctor_get(x_81, 0); +lean_inc(x_99); +x_100 = lean_ctor_get(x_81, 1); +lean_inc(x_100); +if (lean_is_exclusive(x_81)) { + lean_ctor_release(x_81, 0); + lean_ctor_release(x_81, 1); + x_101 = x_81; +} else { + lean_dec_ref(x_81); + x_101 = lean_box(0); +} +lean_inc(x_83); +x_102 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_99, x_1, x_83); +if (lean_is_scalar(x_101)) { + x_103 = lean_alloc_ctor(0, 2, 0); +} else { + x_103 = x_101; +} +lean_ctor_set(x_103, 0, x_102); +lean_ctor_set(x_103, 1, x_100); +x_104 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_104, 0, x_94); +lean_ctor_set(x_104, 1, x_95); +lean_ctor_set(x_104, 2, x_103); +lean_ctor_set(x_104, 3, x_96); +lean_ctor_set(x_104, 4, x_97); +lean_ctor_set(x_104, 5, x_98); +lean_ctor_set(x_79, 1, x_104); +return x_79; +} +} +else +{ +lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; +x_105 = lean_ctor_get(x_79, 0); +lean_inc(x_105); +lean_dec(x_79); +x_106 = lean_ctor_get(x_80, 0); +lean_inc(x_106); +x_107 = lean_ctor_get(x_80, 1); +lean_inc(x_107); +x_108 = lean_ctor_get(x_80, 3); +lean_inc(x_108); +x_109 = lean_ctor_get(x_80, 4); +lean_inc(x_109); +x_110 = lean_ctor_get(x_80, 5); +lean_inc(x_110); +if (lean_is_exclusive(x_80)) { + lean_ctor_release(x_80, 0); + lean_ctor_release(x_80, 1); + lean_ctor_release(x_80, 2); + lean_ctor_release(x_80, 3); + lean_ctor_release(x_80, 4); + lean_ctor_release(x_80, 5); + x_111 = x_80; +} else { + lean_dec_ref(x_80); + x_111 = lean_box(0); +} +x_112 = lean_ctor_get(x_81, 0); +lean_inc(x_112); +x_113 = lean_ctor_get(x_81, 1); +lean_inc(x_113); +if (lean_is_exclusive(x_81)) { + lean_ctor_release(x_81, 0); + lean_ctor_release(x_81, 1); + x_114 = x_81; +} else { + lean_dec_ref(x_81); + x_114 = lean_box(0); +} +lean_inc(x_105); +x_115 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_112, x_1, x_105); +if (lean_is_scalar(x_114)) { + x_116 = lean_alloc_ctor(0, 2, 0); +} else { + x_116 = x_114; +} +lean_ctor_set(x_116, 0, x_115); +lean_ctor_set(x_116, 1, x_113); +if (lean_is_scalar(x_111)) { + x_117 = lean_alloc_ctor(0, 6, 0); +} else { + x_117 = x_111; +} +lean_ctor_set(x_117, 0, x_106); +lean_ctor_set(x_117, 1, x_107); +lean_ctor_set(x_117, 2, x_116); +lean_ctor_set(x_117, 3, x_108); +lean_ctor_set(x_117, 4, x_109); +lean_ctor_set(x_117, 5, x_110); +x_118 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_118, 0, x_105); +lean_ctor_set(x_118, 1, x_117); +return x_118; +} +} +else +{ +uint8_t x_119; +lean_dec(x_1); +x_119 = !lean_is_exclusive(x_79); +if (x_119 == 0) +{ +return x_79; +} +else +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_79, 0); +x_121 = lean_ctor_get(x_79, 1); +lean_inc(x_121); +lean_inc(x_120); +lean_dec(x_79); +x_122 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_122, 0, x_120); +lean_ctor_set(x_122, 1, x_121); +return x_122; +} +} +} +else +{ +lean_object* x_123; lean_object* x_124; +lean_dec(x_2); +lean_dec(x_1); +x_123 = lean_ctor_get(x_78, 0); +lean_inc(x_123); +lean_dec(x_78); +x_124 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_124, 0, x_123); +lean_ctor_set(x_124, 1, x_3); +return x_124; +} +} +case 9: +{ +lean_object* x_125; lean_object* x_126; lean_object* x_127; +lean_dec(x_2); +x_125 = lean_ctor_get(x_1, 0); +lean_inc(x_125); +lean_dec(x_1); +x_126 = l_Lean_Literal_type(x_125); +lean_dec(x_125); +x_127 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_127, 0, x_126); +lean_ctor_set(x_127, 1, x_3); +return x_127; +} +case 10: +{ +lean_object* x_128; +x_128 = lean_ctor_get(x_1, 1); +lean_inc(x_128); +lean_dec(x_1); +x_1 = x_128; +goto _start; +} +case 11: +{ +lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; +x_130 = lean_ctor_get(x_1, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_1, 1); +lean_inc(x_131); +x_132 = lean_ctor_get(x_1, 2); +lean_inc(x_132); +x_133 = lean_ctor_get(x_3, 2); +lean_inc(x_133); +x_134 = lean_ctor_get(x_133, 0); +lean_inc(x_134); +lean_dec(x_133); +x_135 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_134, x_1); +lean_dec(x_134); +if (lean_obj_tag(x_135) == 0) +{ +lean_object* x_136; +x_136 = l___private_Init_Lean_Meta_InferType_3__inferProjType(x_130, x_131, x_132, x_2, x_3); +if (lean_obj_tag(x_136) == 0) +{ +lean_object* x_137; lean_object* x_138; uint8_t x_139; +x_137 = lean_ctor_get(x_136, 1); +lean_inc(x_137); +x_138 = lean_ctor_get(x_137, 2); +lean_inc(x_138); +x_139 = !lean_is_exclusive(x_136); +if (x_139 == 0) +{ +lean_object* x_140; lean_object* x_141; uint8_t x_142; +x_140 = lean_ctor_get(x_136, 0); +x_141 = lean_ctor_get(x_136, 1); +lean_dec(x_141); +x_142 = !lean_is_exclusive(x_137); +if (x_142 == 0) +{ +lean_object* x_143; uint8_t x_144; +x_143 = lean_ctor_get(x_137, 2); +lean_dec(x_143); +x_144 = !lean_is_exclusive(x_138); +if (x_144 == 0) +{ +lean_object* x_145; lean_object* x_146; +x_145 = lean_ctor_get(x_138, 0); +lean_inc(x_140); +x_146 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_145, x_1, x_140); +lean_ctor_set(x_138, 0, x_146); +return x_136; +} +else +{ +lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; +x_147 = lean_ctor_get(x_138, 0); +x_148 = lean_ctor_get(x_138, 1); +lean_inc(x_148); +lean_inc(x_147); +lean_dec(x_138); +lean_inc(x_140); +x_149 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_147, x_1, x_140); +x_150 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_150, 0, x_149); +lean_ctor_set(x_150, 1, x_148); +lean_ctor_set(x_137, 2, x_150); +return x_136; +} +} +else +{ +lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; +x_151 = lean_ctor_get(x_137, 0); +x_152 = lean_ctor_get(x_137, 1); +x_153 = lean_ctor_get(x_137, 3); +x_154 = lean_ctor_get(x_137, 4); +x_155 = lean_ctor_get(x_137, 5); +lean_inc(x_155); +lean_inc(x_154); +lean_inc(x_153); lean_inc(x_152); lean_inc(x_151); -lean_dec(x_142); -lean_inc(x_144); -x_153 = l_PersistentHashMap_insert___rarg(x_137, x_138, x_151, x_2, x_144); -x_154 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_154, 0, x_153); -lean_ctor_set(x_154, 1, x_152); -lean_ctor_set(x_141, 2, x_154); -return x_140; -} -} -else -{ -lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; -x_155 = lean_ctor_get(x_141, 0); -x_156 = lean_ctor_get(x_141, 1); -x_157 = lean_ctor_get(x_141, 3); -x_158 = lean_ctor_get(x_141, 4); -x_159 = lean_ctor_get(x_141, 5); -lean_inc(x_159); -lean_inc(x_158); -lean_inc(x_157); +lean_dec(x_137); +x_156 = lean_ctor_get(x_138, 0); lean_inc(x_156); -lean_inc(x_155); -lean_dec(x_141); -x_160 = lean_ctor_get(x_142, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_142, 1); -lean_inc(x_161); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - x_162 = x_142; +x_157 = lean_ctor_get(x_138, 1); +lean_inc(x_157); +if (lean_is_exclusive(x_138)) { + lean_ctor_release(x_138, 0); + lean_ctor_release(x_138, 1); + x_158 = x_138; } else { - lean_dec_ref(x_142); - x_162 = lean_box(0); + lean_dec_ref(x_138); + x_158 = lean_box(0); } -lean_inc(x_144); -x_163 = l_PersistentHashMap_insert___rarg(x_137, x_138, x_160, x_2, x_144); -if (lean_is_scalar(x_162)) { - x_164 = lean_alloc_ctor(0, 2, 0); +lean_inc(x_140); +x_159 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_156, x_1, x_140); +if (lean_is_scalar(x_158)) { + x_160 = lean_alloc_ctor(0, 2, 0); } else { - x_164 = x_162; + x_160 = x_158; } -lean_ctor_set(x_164, 0, x_163); -lean_ctor_set(x_164, 1, x_161); -x_165 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_165, 0, x_155); -lean_ctor_set(x_165, 1, x_156); -lean_ctor_set(x_165, 2, x_164); -lean_ctor_set(x_165, 3, x_157); -lean_ctor_set(x_165, 4, x_158); -lean_ctor_set(x_165, 5, x_159); -lean_ctor_set(x_140, 1, x_165); -return x_140; +lean_ctor_set(x_160, 0, x_159); +lean_ctor_set(x_160, 1, x_157); +x_161 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_161, 0, x_151); +lean_ctor_set(x_161, 1, x_152); +lean_ctor_set(x_161, 2, x_160); +lean_ctor_set(x_161, 3, x_153); +lean_ctor_set(x_161, 4, x_154); +lean_ctor_set(x_161, 5, x_155); +lean_ctor_set(x_136, 1, x_161); +return x_136; } } else { -lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; -x_166 = lean_ctor_get(x_140, 0); +lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_162 = lean_ctor_get(x_136, 0); +lean_inc(x_162); +lean_dec(x_136); +x_163 = lean_ctor_get(x_137, 0); +lean_inc(x_163); +x_164 = lean_ctor_get(x_137, 1); +lean_inc(x_164); +x_165 = lean_ctor_get(x_137, 3); +lean_inc(x_165); +x_166 = lean_ctor_get(x_137, 4); lean_inc(x_166); -lean_dec(x_140); -x_167 = lean_ctor_get(x_141, 0); +x_167 = lean_ctor_get(x_137, 5); lean_inc(x_167); -x_168 = lean_ctor_get(x_141, 1); -lean_inc(x_168); -x_169 = lean_ctor_get(x_141, 3); +if (lean_is_exclusive(x_137)) { + lean_ctor_release(x_137, 0); + lean_ctor_release(x_137, 1); + lean_ctor_release(x_137, 2); + lean_ctor_release(x_137, 3); + lean_ctor_release(x_137, 4); + lean_ctor_release(x_137, 5); + x_168 = x_137; +} else { + lean_dec_ref(x_137); + x_168 = lean_box(0); +} +x_169 = lean_ctor_get(x_138, 0); lean_inc(x_169); -x_170 = lean_ctor_get(x_141, 4); +x_170 = lean_ctor_get(x_138, 1); lean_inc(x_170); -x_171 = lean_ctor_get(x_141, 5); -lean_inc(x_171); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - lean_ctor_release(x_141, 4); - lean_ctor_release(x_141, 5); - x_172 = x_141; +if (lean_is_exclusive(x_138)) { + lean_ctor_release(x_138, 0); + lean_ctor_release(x_138, 1); + x_171 = x_138; } else { - lean_dec_ref(x_141); - x_172 = lean_box(0); + lean_dec_ref(x_138); + x_171 = lean_box(0); } -x_173 = lean_ctor_get(x_142, 0); -lean_inc(x_173); -x_174 = lean_ctor_get(x_142, 1); -lean_inc(x_174); -if (lean_is_exclusive(x_142)) { - lean_ctor_release(x_142, 0); - lean_ctor_release(x_142, 1); - x_175 = x_142; +lean_inc(x_162); +x_172 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_169, x_1, x_162); +if (lean_is_scalar(x_171)) { + x_173 = lean_alloc_ctor(0, 2, 0); } else { - lean_dec_ref(x_142); - x_175 = lean_box(0); + x_173 = x_171; } -lean_inc(x_166); -x_176 = l_PersistentHashMap_insert___rarg(x_137, x_138, x_173, x_2, x_166); -if (lean_is_scalar(x_175)) { - x_177 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_173, 0, x_172); +lean_ctor_set(x_173, 1, x_170); +if (lean_is_scalar(x_168)) { + x_174 = lean_alloc_ctor(0, 6, 0); } else { - x_177 = x_175; + x_174 = x_168; } -lean_ctor_set(x_177, 0, x_176); -lean_ctor_set(x_177, 1, x_174); -if (lean_is_scalar(x_172)) { - x_178 = lean_alloc_ctor(0, 6, 0); -} else { - x_178 = x_172; +lean_ctor_set(x_174, 0, x_163); +lean_ctor_set(x_174, 1, x_164); +lean_ctor_set(x_174, 2, x_173); +lean_ctor_set(x_174, 3, x_165); +lean_ctor_set(x_174, 4, x_166); +lean_ctor_set(x_174, 5, x_167); +x_175 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_175, 0, x_162); +lean_ctor_set(x_175, 1, x_174); +return x_175; } -lean_ctor_set(x_178, 0, x_167); -lean_ctor_set(x_178, 1, x_168); -lean_ctor_set(x_178, 2, x_177); -lean_ctor_set(x_178, 3, x_169); -lean_ctor_set(x_178, 4, x_170); -lean_ctor_set(x_178, 5, x_171); -x_179 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_179, 0, x_166); +} +else +{ +uint8_t x_176; +lean_dec(x_1); +x_176 = !lean_is_exclusive(x_136); +if (x_176 == 0) +{ +return x_136; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_136, 0); +x_178 = lean_ctor_get(x_136, 1); +lean_inc(x_178); +lean_inc(x_177); +lean_dec(x_136); +x_179 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_179, 0, x_177); lean_ctor_set(x_179, 1, x_178); return x_179; } } -else -{ -uint8_t x_180; -lean_dec(x_2); -x_180 = !lean_is_exclusive(x_140); -if (x_180 == 0) -{ -return x_140; } else { -lean_object* x_181; lean_object* x_182; lean_object* x_183; -x_181 = lean_ctor_get(x_140, 0); -x_182 = lean_ctor_get(x_140, 1); -lean_inc(x_182); -lean_inc(x_181); -lean_dec(x_140); -x_183 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_183, 0, x_181); -lean_ctor_set(x_183, 1, x_182); -return x_183; -} -} -} -else -{ -lean_object* x_184; lean_object* x_185; -lean_dec(x_134); -lean_dec(x_3); +lean_object* x_180; lean_object* x_181; +lean_dec(x_132); +lean_dec(x_131); +lean_dec(x_130); lean_dec(x_2); lean_dec(x_1); -x_184 = lean_ctor_get(x_139, 0); -lean_inc(x_184); -lean_dec(x_139); -x_185 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_185, 0, x_184); -lean_ctor_set(x_185, 1, x_4); -return x_185; -} -} -case 9: -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; -lean_dec(x_3); -lean_dec(x_1); -x_186 = lean_ctor_get(x_2, 0); -lean_inc(x_186); -lean_dec(x_2); -x_187 = l_Lean_Literal_type(x_186); -lean_dec(x_186); -x_188 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_188, 0, x_187); -lean_ctor_set(x_188, 1, x_4); -return x_188; -} -case 10: -{ -lean_object* x_189; -x_189 = lean_ctor_get(x_2, 1); -lean_inc(x_189); -lean_dec(x_2); -x_2 = x_189; -goto _start; -} -case 11: -{ -lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; lean_object* x_199; -x_191 = lean_ctor_get(x_2, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_2, 1); -lean_inc(x_192); -x_193 = lean_ctor_get(x_2, 2); -lean_inc(x_193); -lean_inc(x_1); -x_194 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAuxAux___main), 4, 1); -lean_closure_set(x_194, 0, x_1); -x_195 = lean_ctor_get(x_4, 2); -lean_inc(x_195); -x_196 = lean_ctor_get(x_195, 0); -lean_inc(x_196); -lean_dec(x_195); -x_197 = l_Lean_ExprStructEq_HasBeq; -x_198 = l_Lean_ExprStructEq_Hashable; -lean_inc(x_2); -x_199 = l_PersistentHashMap_find___rarg(x_197, x_198, x_196, x_2); -lean_dec(x_196); -if (lean_obj_tag(x_199) == 0) -{ -lean_object* x_200; -x_200 = l___private_Init_Lean_Meta_InferType_3__inferProjType(x_1, x_194, x_191, x_192, x_193, x_3, x_4); -if (lean_obj_tag(x_200) == 0) -{ -lean_object* x_201; lean_object* x_202; uint8_t x_203; -x_201 = lean_ctor_get(x_200, 1); -lean_inc(x_201); -x_202 = lean_ctor_get(x_201, 2); -lean_inc(x_202); -x_203 = !lean_is_exclusive(x_200); -if (x_203 == 0) -{ -lean_object* x_204; lean_object* x_205; uint8_t x_206; -x_204 = lean_ctor_get(x_200, 0); -x_205 = lean_ctor_get(x_200, 1); -lean_dec(x_205); -x_206 = !lean_is_exclusive(x_201); -if (x_206 == 0) -{ -lean_object* x_207; uint8_t x_208; -x_207 = lean_ctor_get(x_201, 2); -lean_dec(x_207); -x_208 = !lean_is_exclusive(x_202); -if (x_208 == 0) -{ -lean_object* x_209; lean_object* x_210; -x_209 = lean_ctor_get(x_202, 0); -lean_inc(x_204); -x_210 = l_PersistentHashMap_insert___rarg(x_197, x_198, x_209, x_2, x_204); -lean_ctor_set(x_202, 0, x_210); -return x_200; -} -else -{ -lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; -x_211 = lean_ctor_get(x_202, 0); -x_212 = lean_ctor_get(x_202, 1); -lean_inc(x_212); -lean_inc(x_211); -lean_dec(x_202); -lean_inc(x_204); -x_213 = l_PersistentHashMap_insert___rarg(x_197, x_198, x_211, x_2, x_204); -x_214 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_214, 0, x_213); -lean_ctor_set(x_214, 1, x_212); -lean_ctor_set(x_201, 2, x_214); -return x_200; -} -} -else -{ -lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; -x_215 = lean_ctor_get(x_201, 0); -x_216 = lean_ctor_get(x_201, 1); -x_217 = lean_ctor_get(x_201, 3); -x_218 = lean_ctor_get(x_201, 4); -x_219 = lean_ctor_get(x_201, 5); -lean_inc(x_219); -lean_inc(x_218); -lean_inc(x_217); -lean_inc(x_216); -lean_inc(x_215); -lean_dec(x_201); -x_220 = lean_ctor_get(x_202, 0); -lean_inc(x_220); -x_221 = lean_ctor_get(x_202, 1); -lean_inc(x_221); -if (lean_is_exclusive(x_202)) { - lean_ctor_release(x_202, 0); - lean_ctor_release(x_202, 1); - x_222 = x_202; -} else { - lean_dec_ref(x_202); - x_222 = lean_box(0); -} -lean_inc(x_204); -x_223 = l_PersistentHashMap_insert___rarg(x_197, x_198, x_220, x_2, x_204); -if (lean_is_scalar(x_222)) { - x_224 = lean_alloc_ctor(0, 2, 0); -} else { - x_224 = x_222; -} -lean_ctor_set(x_224, 0, x_223); -lean_ctor_set(x_224, 1, x_221); -x_225 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_225, 0, x_215); -lean_ctor_set(x_225, 1, x_216); -lean_ctor_set(x_225, 2, x_224); -lean_ctor_set(x_225, 3, x_217); -lean_ctor_set(x_225, 4, x_218); -lean_ctor_set(x_225, 5, x_219); -lean_ctor_set(x_200, 1, x_225); -return x_200; -} -} -else -{ -lean_object* x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; -x_226 = lean_ctor_get(x_200, 0); -lean_inc(x_226); -lean_dec(x_200); -x_227 = lean_ctor_get(x_201, 0); -lean_inc(x_227); -x_228 = lean_ctor_get(x_201, 1); -lean_inc(x_228); -x_229 = lean_ctor_get(x_201, 3); -lean_inc(x_229); -x_230 = lean_ctor_get(x_201, 4); -lean_inc(x_230); -x_231 = lean_ctor_get(x_201, 5); -lean_inc(x_231); -if (lean_is_exclusive(x_201)) { - lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - lean_ctor_release(x_201, 4); - lean_ctor_release(x_201, 5); - x_232 = x_201; -} else { - lean_dec_ref(x_201); - x_232 = lean_box(0); -} -x_233 = lean_ctor_get(x_202, 0); -lean_inc(x_233); -x_234 = lean_ctor_get(x_202, 1); -lean_inc(x_234); -if (lean_is_exclusive(x_202)) { - lean_ctor_release(x_202, 0); - lean_ctor_release(x_202, 1); - x_235 = x_202; -} else { - lean_dec_ref(x_202); - x_235 = lean_box(0); -} -lean_inc(x_226); -x_236 = l_PersistentHashMap_insert___rarg(x_197, x_198, x_233, x_2, x_226); -if (lean_is_scalar(x_235)) { - x_237 = lean_alloc_ctor(0, 2, 0); -} else { - x_237 = x_235; -} -lean_ctor_set(x_237, 0, x_236); -lean_ctor_set(x_237, 1, x_234); -if (lean_is_scalar(x_232)) { - x_238 = lean_alloc_ctor(0, 6, 0); -} else { - x_238 = x_232; -} -lean_ctor_set(x_238, 0, x_227); -lean_ctor_set(x_238, 1, x_228); -lean_ctor_set(x_238, 2, x_237); -lean_ctor_set(x_238, 3, x_229); -lean_ctor_set(x_238, 4, x_230); -lean_ctor_set(x_238, 5, x_231); -x_239 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_239, 0, x_226); -lean_ctor_set(x_239, 1, x_238); -return x_239; -} -} -else -{ -uint8_t x_240; -lean_dec(x_2); -x_240 = !lean_is_exclusive(x_200); -if (x_240 == 0) -{ -return x_200; -} -else -{ -lean_object* x_241; lean_object* x_242; lean_object* x_243; -x_241 = lean_ctor_get(x_200, 0); -x_242 = lean_ctor_get(x_200, 1); -lean_inc(x_242); -lean_inc(x_241); -lean_dec(x_200); -x_243 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_243, 0, x_241); -lean_ctor_set(x_243, 1, x_242); -return x_243; -} -} -} -else -{ -lean_object* x_244; lean_object* x_245; -lean_dec(x_194); -lean_dec(x_193); -lean_dec(x_192); -lean_dec(x_191); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_244 = lean_ctor_get(x_199, 0); -lean_inc(x_244); -lean_dec(x_199); -x_245 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_245, 0, x_244); -lean_ctor_set(x_245, 1, x_4); -return x_245; +x_180 = lean_ctor_get(x_135, 0); +lean_inc(x_180); +lean_dec(x_135); +x_181 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_181, 0, x_180); +lean_ctor_set(x_181, 1, x_3); +return x_181; } } case 12: { -lean_object* x_246; lean_object* x_247; lean_object* x_248; -lean_dec(x_2); +lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_dec(x_1); -x_246 = l_Lean_Meta_isClassQuick___main___closed__1; -x_247 = l_unreachable_x21___rarg(x_246); -x_248 = lean_apply_2(x_247, x_3, x_4); -return x_248; +x_182 = l_Lean_Meta_isClassQuick___main___closed__1; +x_183 = l_unreachable_x21___rarg(x_182); +x_184 = lean_apply_2(x_183, x_2, x_3); +return x_184; } default: { -lean_object* x_249; -x_249 = lean_box(0); -x_5 = x_249; -goto block_58; -} -} -block_58: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -lean_dec(x_5); -lean_inc(x_1); -x_6 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeAuxAux___main), 4, 1); -lean_closure_set(x_6, 0, x_1); -x_7 = lean_ctor_get(x_4, 2); -lean_inc(x_7); -x_8 = lean_ctor_get(x_7, 0); -lean_inc(x_8); -lean_dec(x_7); -x_9 = l_Lean_ExprStructEq_HasBeq; -x_10 = l_Lean_ExprStructEq_Hashable; -lean_inc(x_2); -x_11 = l_PersistentHashMap_find___rarg(x_9, x_10, x_8, x_2); -lean_dec(x_8); -if (lean_obj_tag(x_11) == 0) -{ -lean_object* x_12; -lean_inc(x_2); -x_12 = l___private_Init_Lean_Meta_InferType_5__inferLambdaType(x_1, x_6, x_2, x_3, x_4); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; uint8_t x_15; -x_13 = lean_ctor_get(x_12, 1); -lean_inc(x_13); -x_14 = lean_ctor_get(x_13, 2); -lean_inc(x_14); -x_15 = !lean_is_exclusive(x_12); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; uint8_t x_18; -x_16 = lean_ctor_get(x_12, 0); -x_17 = lean_ctor_get(x_12, 1); -lean_dec(x_17); -x_18 = !lean_is_exclusive(x_13); -if (x_18 == 0) -{ -lean_object* x_19; uint8_t x_20; -x_19 = lean_ctor_get(x_13, 2); -lean_dec(x_19); -x_20 = !lean_is_exclusive(x_14); -if (x_20 == 0) -{ -lean_object* x_21; lean_object* x_22; -x_21 = lean_ctor_get(x_14, 0); -lean_inc(x_16); -x_22 = l_PersistentHashMap_insert___rarg(x_9, x_10, x_21, x_2, x_16); -lean_ctor_set(x_14, 0, x_22); -return x_12; -} -else -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_23 = lean_ctor_get(x_14, 0); -x_24 = lean_ctor_get(x_14, 1); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_14); -lean_inc(x_16); -x_25 = l_PersistentHashMap_insert___rarg(x_9, x_10, x_23, x_2, x_16); -x_26 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_26, 0, x_25); -lean_ctor_set(x_26, 1, x_24); -lean_ctor_set(x_13, 2, x_26); -return x_12; -} -} -else -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_27 = lean_ctor_get(x_13, 0); -x_28 = lean_ctor_get(x_13, 1); -x_29 = lean_ctor_get(x_13, 3); -x_30 = lean_ctor_get(x_13, 4); -x_31 = lean_ctor_get(x_13, 5); -lean_inc(x_31); -lean_inc(x_30); -lean_inc(x_29); -lean_inc(x_28); -lean_inc(x_27); -lean_dec(x_13); -x_32 = lean_ctor_get(x_14, 0); -lean_inc(x_32); -x_33 = lean_ctor_get(x_14, 1); -lean_inc(x_33); -if (lean_is_exclusive(x_14)) { - lean_ctor_release(x_14, 0); - lean_ctor_release(x_14, 1); - x_34 = x_14; -} else { - lean_dec_ref(x_14); - x_34 = lean_box(0); -} -lean_inc(x_16); -x_35 = l_PersistentHashMap_insert___rarg(x_9, x_10, x_32, x_2, x_16); -if (lean_is_scalar(x_34)) { - x_36 = lean_alloc_ctor(0, 2, 0); -} else { - x_36 = x_34; -} -lean_ctor_set(x_36, 0, x_35); -lean_ctor_set(x_36, 1, x_33); -x_37 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_37, 0, x_27); -lean_ctor_set(x_37, 1, x_28); -lean_ctor_set(x_37, 2, x_36); -lean_ctor_set(x_37, 3, x_29); -lean_ctor_set(x_37, 4, x_30); -lean_ctor_set(x_37, 5, x_31); -lean_ctor_set(x_12, 1, x_37); -return x_12; -} -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_38 = lean_ctor_get(x_12, 0); -lean_inc(x_38); -lean_dec(x_12); -x_39 = lean_ctor_get(x_13, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_13, 1); -lean_inc(x_40); -x_41 = lean_ctor_get(x_13, 3); -lean_inc(x_41); -x_42 = lean_ctor_get(x_13, 4); -lean_inc(x_42); -x_43 = lean_ctor_get(x_13, 5); -lean_inc(x_43); -if (lean_is_exclusive(x_13)) { - lean_ctor_release(x_13, 0); - lean_ctor_release(x_13, 1); - lean_ctor_release(x_13, 2); - lean_ctor_release(x_13, 3); - lean_ctor_release(x_13, 4); - lean_ctor_release(x_13, 5); - x_44 = x_13; -} else { - lean_dec_ref(x_13); - x_44 = lean_box(0); -} -x_45 = lean_ctor_get(x_14, 0); -lean_inc(x_45); -x_46 = lean_ctor_get(x_14, 1); -lean_inc(x_46); -if (lean_is_exclusive(x_14)) { - lean_ctor_release(x_14, 0); - lean_ctor_release(x_14, 1); - x_47 = x_14; -} else { - lean_dec_ref(x_14); - x_47 = lean_box(0); -} -lean_inc(x_38); -x_48 = l_PersistentHashMap_insert___rarg(x_9, x_10, x_45, x_2, x_38); -if (lean_is_scalar(x_47)) { - x_49 = lean_alloc_ctor(0, 2, 0); -} else { - x_49 = x_47; -} -lean_ctor_set(x_49, 0, x_48); -lean_ctor_set(x_49, 1, x_46); -if (lean_is_scalar(x_44)) { - x_50 = lean_alloc_ctor(0, 6, 0); -} else { - x_50 = x_44; -} -lean_ctor_set(x_50, 0, x_39); -lean_ctor_set(x_50, 1, x_40); -lean_ctor_set(x_50, 2, x_49); -lean_ctor_set(x_50, 3, x_41); -lean_ctor_set(x_50, 4, x_42); -lean_ctor_set(x_50, 5, x_43); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_38); -lean_ctor_set(x_51, 1, x_50); -return x_51; -} -} -else -{ -uint8_t x_52; -lean_dec(x_2); -x_52 = !lean_is_exclusive(x_12); -if (x_52 == 0) -{ -return x_12; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_53 = lean_ctor_get(x_12, 0); -x_54 = lean_ctor_get(x_12, 1); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_12); -x_55 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_55, 0, x_53); -lean_ctor_set(x_55, 1, x_54); -return x_55; -} -} -} -else -{ -lean_object* x_56; lean_object* x_57; -lean_dec(x_6); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_56 = lean_ctor_get(x_11, 0); -lean_inc(x_56); -lean_dec(x_11); -x_57 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_57, 0, x_56); -lean_ctor_set(x_57, 1, x_4); -return x_57; -} -} -} -} -lean_object* l_Lean_Meta_inferTypeAuxAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Meta_inferTypeAuxAux___main(x_1, x_2, x_3, x_4); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__9(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_9 = l_Lean_Expr_getAppFn___main(x_2); -if (lean_obj_tag(x_9) == 4) -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -lean_dec(x_9); -x_11 = lean_ctor_get(x_6, 0); -lean_inc(x_11); -lean_inc(x_10); -x_12 = lean_is_class(x_11, x_10); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; -lean_dec(x_10); -x_13 = lean_box(0); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_6); -return x_14; -} -else -{ -lean_object* x_15; lean_object* x_16; -x_15 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_15, 0, x_10); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_6); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; -lean_dec(x_9); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_6); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; -x_19 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_5, x_6); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_20, 1); -lean_inc(x_22); -lean_dec(x_20); -x_23 = l_Lean_LocalDecl_type(x_21); -lean_dec(x_21); -lean_inc(x_5); -lean_inc(x_23); -x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_5, x_22); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -switch (lean_obj_tag(x_25)) { -case 0: -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_dec(x_23); -lean_dec(x_19); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_4, x_27); -lean_dec(x_4); -x_4 = x_28; -x_6 = x_26; -goto _start; -} -case 1: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 1); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_4, x_32); -lean_dec(x_4); -x_34 = !lean_is_exclusive(x_5); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_5, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_31); -lean_ctor_set(x_36, 1, x_19); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_5, 2, x_37); -x_4 = x_33; -x_6 = x_30; -goto _start; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_5, 0); -x_40 = lean_ctor_get(x_5, 1); -x_41 = lean_ctor_get(x_5, 2); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_5); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_31); -lean_ctor_set(x_42, 1, x_19); -x_43 = lean_array_push(x_41, x_42); -x_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_43); -x_4 = x_33; -x_5 = x_44; -x_6 = x_30; -goto _start; -} -} -default: -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_24, 1); -lean_inc(x_46); -lean_dec(x_24); -lean_inc(x_5); -lean_inc(x_1); -x_47 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__6(x_1, x_23, x_5, x_46); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_19); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -x_50 = lean_unsigned_to_nat(1u); -x_51 = lean_nat_add(x_4, x_50); -lean_dec(x_4); -x_4 = x_51; -x_6 = x_49; -goto _start; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; -x_53 = lean_ctor_get(x_47, 1); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_ctor_get(x_48, 0); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_unsigned_to_nat(1u); -x_56 = lean_nat_add(x_4, x_55); -lean_dec(x_4); -x_57 = !lean_is_exclusive(x_5); -if (x_57 == 0) -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_5, 2); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_54); -lean_ctor_set(x_59, 1, x_19); -x_60 = lean_array_push(x_58, x_59); -lean_ctor_set(x_5, 2, x_60); -x_4 = x_56; -x_6 = x_53; -goto _start; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_62 = lean_ctor_get(x_5, 0); -x_63 = lean_ctor_get(x_5, 1); -x_64 = lean_ctor_get(x_5, 2); -lean_inc(x_64); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_5); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_54); -lean_ctor_set(x_65, 1, x_19); -x_66 = lean_array_push(x_64, x_65); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_63); -lean_ctor_set(x_67, 2, x_66); -x_4 = x_56; -x_5 = x_67; -x_6 = x_53; -goto _start; -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_69 = !lean_is_exclusive(x_47); -if (x_69 == 0) -{ -return x_47; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_47, 0); -x_71 = lean_ctor_get(x_47, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_47); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_73 = !lean_is_exclusive(x_24); -if (x_73 == 0) -{ -return x_24; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_24, 0); -x_75 = lean_ctor_get(x_24, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_24); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_77 = !lean_is_exclusive(x_20); -if (x_77 == 0) -{ -return x_20; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_20, 0); -x_79 = lean_ctor_get(x_20, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_20); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___lambda__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -uint8_t x_11; -x_11 = l_Lean_Expr_isForall(x_8); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_12 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_12) == 4) -{ -lean_object* x_13; lean_object* x_14; uint8_t x_15; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -lean_dec(x_12); -x_14 = lean_ctor_get(x_10, 0); -lean_inc(x_14); -lean_inc(x_13); -x_15 = lean_is_class(x_14, x_13); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_13); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_10); -return x_17; -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_18, 0, x_13); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_18); -lean_ctor_set(x_19, 1, x_10); -return x_19; -} -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_12); -x_20 = lean_box(0); -x_21 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_21, 0, x_20); -lean_ctor_set(x_21, 1, x_10); -return x_21; -} -} -else -{ -lean_object* x_22; -x_22 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8(x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -return x_22; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { -_start: -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -lean_inc(x_9); -lean_inc(x_1); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_1); -lean_closure_set(x_14, 1, x_9); -x_15 = lean_box(x_2); -lean_inc(x_8); -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_1); -lean_inc(x_9); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___lambda__1___boxed), 10, 7); -lean_closure_set(x_16, 0, x_9); -lean_closure_set(x_16, 1, x_1); -lean_closure_set(x_16, 2, x_15); -lean_closure_set(x_16, 3, x_3); -lean_closure_set(x_16, 4, x_4); -lean_closure_set(x_16, 5, x_5); -lean_closure_set(x_16, 6, x_8); -x_17 = lean_array_get_size(x_10); -x_18 = lean_nat_dec_lt(x_11, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_12, x_13); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_10, x_11); -lean_inc(x_12); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_12, x_13); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_12); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_12, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_11, x_28); -lean_dec(x_11); -x_11 = x_29; -x_13 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_11, x_33); -lean_dec(x_11); -x_35 = !lean_is_exclusive(x_12); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_12, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_12, 2, x_38); -x_11 = x_34; -x_13 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_12, 0); -x_41 = lean_ctor_get(x_12, 1); -x_42 = lean_ctor_get(x_12, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_12); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_11 = x_34; -x_12 = x_45; -x_13 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_12); -lean_inc(x_1); -x_48 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__6(x_1, x_24, x_12, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_11, x_51); -lean_dec(x_11); -x_11 = x_52; -x_13 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_11, x_56); -lean_dec(x_11); -x_58 = !lean_is_exclusive(x_12); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_12, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_12, 2, x_61); -x_11 = x_57; -x_13 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_12, 0); -x_64 = lean_ctor_get(x_12, 1); -x_65 = lean_ctor_get(x_12, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_12); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_11 = x_57; -x_12 = x_68; -x_13 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__11(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_9 = l_Lean_Expr_getAppFn___main(x_2); -if (lean_obj_tag(x_9) == 4) -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -lean_dec(x_9); -x_11 = lean_ctor_get(x_6, 0); -lean_inc(x_11); -lean_inc(x_10); -x_12 = lean_is_class(x_11, x_10); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; -lean_dec(x_10); -x_13 = lean_box(0); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_6); -return x_14; -} -else -{ -lean_object* x_15; lean_object* x_16; -x_15 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_15, 0, x_10); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_6); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; -lean_dec(x_9); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_6); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; -x_19 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_5, x_6); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_20, 1); -lean_inc(x_22); -lean_dec(x_20); -x_23 = l_Lean_LocalDecl_type(x_21); -lean_dec(x_21); -lean_inc(x_5); -lean_inc(x_23); -x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_5, x_22); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -switch (lean_obj_tag(x_25)) { -case 0: -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_dec(x_23); -lean_dec(x_19); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_4, x_27); -lean_dec(x_4); -x_4 = x_28; -x_6 = x_26; -goto _start; -} -case 1: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 1); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_4, x_32); -lean_dec(x_4); -x_34 = !lean_is_exclusive(x_5); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_5, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_31); -lean_ctor_set(x_36, 1, x_19); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_5, 2, x_37); -x_4 = x_33; -x_6 = x_30; -goto _start; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_5, 0); -x_40 = lean_ctor_get(x_5, 1); -x_41 = lean_ctor_get(x_5, 2); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_5); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_31); -lean_ctor_set(x_42, 1, x_19); -x_43 = lean_array_push(x_41, x_42); -x_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_43); -x_4 = x_33; -x_5 = x_44; -x_6 = x_30; -goto _start; -} -} -default: -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_24, 1); -lean_inc(x_46); -lean_dec(x_24); -lean_inc(x_5); -lean_inc(x_1); -x_47 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__6(x_1, x_23, x_5, x_46); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_19); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -x_50 = lean_unsigned_to_nat(1u); -x_51 = lean_nat_add(x_4, x_50); -lean_dec(x_4); -x_4 = x_51; -x_6 = x_49; -goto _start; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; -x_53 = lean_ctor_get(x_47, 1); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_ctor_get(x_48, 0); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_unsigned_to_nat(1u); -x_56 = lean_nat_add(x_4, x_55); -lean_dec(x_4); -x_57 = !lean_is_exclusive(x_5); -if (x_57 == 0) -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_5, 2); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_54); -lean_ctor_set(x_59, 1, x_19); -x_60 = lean_array_push(x_58, x_59); -lean_ctor_set(x_5, 2, x_60); -x_4 = x_56; -x_6 = x_53; -goto _start; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_62 = lean_ctor_get(x_5, 0); -x_63 = lean_ctor_get(x_5, 1); -x_64 = lean_ctor_get(x_5, 2); -lean_inc(x_64); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_5); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_54); -lean_ctor_set(x_65, 1, x_19); -x_66 = lean_array_push(x_64, x_65); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_63); -lean_ctor_set(x_67, 2, x_66); -x_4 = x_56; -x_5 = x_67; -x_6 = x_53; -goto _start; -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_69 = !lean_is_exclusive(x_47); -if (x_69 == 0) -{ -return x_47; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_47, 0); -x_71 = lean_ctor_get(x_47, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_47); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_73 = !lean_is_exclusive(x_24); -if (x_73 == 0) -{ -return x_24; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_24, 0); -x_75 = lean_ctor_get(x_24, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_24); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_77 = !lean_is_exclusive(x_20); -if (x_77 == 0) -{ -return x_20; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_20, 0); -x_79 = lean_ctor_get(x_20, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_20); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -if (lean_obj_tag(x_7) == 7) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; uint64_t x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_23 = lean_ctor_get(x_7, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_7, 1); -lean_inc(x_24); -x_25 = lean_ctor_get(x_7, 2); -lean_inc(x_25); -x_26 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); -lean_dec(x_7); -x_27 = lean_array_get_size(x_5); -lean_inc(x_5); -x_28 = lean_expr_instantiate_rev_range(x_24, x_6, x_27, x_5); -lean_dec(x_27); -lean_dec(x_24); -x_29 = l_Lean_Meta_mkFreshId___rarg(x_9); -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_29, 1); -lean_inc(x_31); -lean_dec(x_29); -x_32 = (uint8_t)((x_26 << 24) >> 61); -lean_inc(x_30); -x_33 = lean_local_ctx_mk_local_decl(x_4, x_30, x_23, x_28, x_32); -x_34 = l_Lean_mkFVar(x_30); -x_35 = lean_array_push(x_5, x_34); -if (lean_obj_tag(x_3) == 0) -{ -x_4 = x_33; -x_5 = x_35; -x_7 = x_25; -x_9 = x_31; -goto _start; -} -else -{ -lean_object* x_37; lean_object* x_38; uint8_t x_39; -x_37 = lean_ctor_get(x_3, 0); -lean_inc(x_37); -x_38 = lean_array_get_size(x_35); -x_39 = lean_nat_dec_lt(x_38, x_37); -lean_dec(x_37); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; -lean_dec(x_3); -lean_inc(x_35); -x_40 = lean_expr_instantiate_rev_range(x_25, x_6, x_38, x_35); -lean_dec(x_38); -lean_dec(x_25); -x_41 = !lean_is_exclusive(x_8); -if (x_41 == 0) -{ -lean_object* x_42; lean_object* x_43; -x_42 = lean_ctor_get(x_8, 1); -lean_dec(x_42); -lean_ctor_set(x_8, 1, x_33); -x_43 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__11(x_1, x_40, x_35, x_6, x_8, x_31); -lean_dec(x_35); -lean_dec(x_40); -return x_43; -} -else -{ -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_44 = lean_ctor_get(x_8, 0); -x_45 = lean_ctor_get(x_8, 2); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_8); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_33); -lean_ctor_set(x_46, 2, x_45); -x_47 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__11(x_1, x_40, x_35, x_6, x_46, x_31); -lean_dec(x_35); -lean_dec(x_40); -return x_47; -} -} -else -{ -lean_dec(x_38); -x_4 = x_33; -x_5 = x_35; -x_7 = x_25; -x_9 = x_31; -goto _start; -} -} -} -else -{ -lean_object* x_49; -x_49 = lean_box(0); -x_10 = x_49; -goto block_22; -} -block_22: -{ -lean_object* x_11; lean_object* x_12; uint8_t x_13; -lean_dec(x_10); -x_11 = lean_array_get_size(x_5); -lean_inc(x_5); -x_12 = lean_expr_instantiate_rev_range(x_7, x_6, x_11, x_5); -x_13 = !lean_is_exclusive(x_8); -if (x_13 == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_8, 1); -lean_dec(x_14); -lean_inc(x_4); -lean_ctor_set(x_8, 1, x_4); -if (x_2 == 0) -{ -lean_object* x_15; -lean_dec(x_11); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__9(x_1, x_12, x_5, x_6, x_8, x_9); -lean_dec(x_5); -lean_dec(x_12); -return x_15; -} -else -{ -lean_object* x_16; -lean_inc(x_6); -lean_inc(x_5); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_8, x_9); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_8, 0); -x_18 = lean_ctor_get(x_8, 2); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_8); -lean_inc(x_4); -x_19 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_4); -lean_ctor_set(x_19, 2, x_18); -if (x_2 == 0) -{ -lean_object* x_20; -lean_dec(x_11); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__9(x_1, x_12, x_5, x_6, x_19, x_9); -lean_dec(x_5); -lean_dec(x_12); -return x_20; -} -else -{ -lean_object* x_21; -lean_inc(x_6); -lean_inc(x_5); -x_21 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_19, x_9); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -return x_21; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_9; -x_6 = lean_ctor_get(x_4, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -x_8 = lean_ctor_get(x_4, 2); -lean_inc(x_8); -x_9 = !lean_is_exclusive(x_6); -if (x_9 == 0) -{ -uint8_t x_10; lean_object* x_11; lean_object* x_12; -x_10 = 1; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_10); -lean_inc(x_7); -x_11 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_11, 0, x_6); -lean_ctor_set(x_11, 1, x_7); -lean_ctor_set(x_11, 2, x_8); -lean_inc(x_1); -lean_inc(x_2); -x_12 = lean_apply_3(x_1, x_2, x_11, x_5); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; uint8_t x_16; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_ctor_get(x_12, 1); -x_16 = l_Lean_Expr_isForall(x_14); -if (x_16 == 0) -{ -lean_object* x_17; -lean_dec(x_14); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_17 = l_Lean_Expr_getAppFn___main(x_2); -lean_dec(x_2); -if (lean_obj_tag(x_17) == 4) -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -lean_dec(x_17); -x_19 = lean_ctor_get(x_15, 0); -lean_inc(x_19); -lean_inc(x_18); -x_20 = lean_is_class(x_19, x_18); -if (x_20 == 0) -{ -lean_object* x_21; -lean_dec(x_18); -x_21 = lean_box(0); -lean_ctor_set(x_12, 0, x_21); -return x_12; -} -else -{ -lean_object* x_22; -x_22 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_22, 0, x_18); -lean_ctor_set(x_12, 0, x_22); -return x_12; -} -} -else -{ -lean_object* x_23; -lean_dec(x_17); -x_23 = lean_box(0); -lean_ctor_set(x_12, 0, x_23); -return x_12; -} -} -else -{ -lean_object* x_24; uint8_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_free_object(x_12); -lean_dec(x_2); -x_24 = lean_ctor_get(x_15, 2); -lean_inc(x_24); -x_25 = 1; -x_26 = l_Array_empty___closed__1; -x_27 = lean_unsigned_to_nat(0u); -x_28 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8(x_1, x_25, x_3, x_7, x_26, x_27, x_14, x_4, x_15); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_28); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_28, 1); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = lean_ctor_get(x_30, 2); -lean_dec(x_32); -lean_ctor_set(x_30, 2, x_24); -return x_28; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_33 = lean_ctor_get(x_30, 0); -x_34 = lean_ctor_get(x_30, 1); -x_35 = lean_ctor_get(x_30, 3); -x_36 = lean_ctor_get(x_30, 4); -x_37 = lean_ctor_get(x_30, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_30); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_34); -lean_ctor_set(x_38, 2, x_24); -lean_ctor_set(x_38, 3, x_35); -lean_ctor_set(x_38, 4, x_36); -lean_ctor_set(x_38, 5, x_37); -lean_ctor_set(x_28, 1, x_38); -return x_28; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_39 = lean_ctor_get(x_28, 1); -x_40 = lean_ctor_get(x_28, 0); -lean_inc(x_39); -lean_inc(x_40); -lean_dec(x_28); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_39, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_39, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_46 = x_39; -} else { - lean_dec_ref(x_39); - x_46 = lean_box(0); -} -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_46; -} -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); -lean_ctor_set(x_47, 2, x_24); -lean_ctor_set(x_47, 3, x_43); -lean_ctor_set(x_47, 4, x_44); -lean_ctor_set(x_47, 5, x_45); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_40); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -else -{ -uint8_t x_49; -x_49 = !lean_is_exclusive(x_28); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_28, 1); -x_51 = !lean_is_exclusive(x_50); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_50, 2); -lean_dec(x_52); -lean_ctor_set(x_50, 2, x_24); -return x_28; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_53 = lean_ctor_get(x_50, 0); -x_54 = lean_ctor_get(x_50, 1); -x_55 = lean_ctor_get(x_50, 3); -x_56 = lean_ctor_get(x_50, 4); -x_57 = lean_ctor_get(x_50, 5); -lean_inc(x_57); -lean_inc(x_56); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_50); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_54); -lean_ctor_set(x_58, 2, x_24); -lean_ctor_set(x_58, 3, x_55); -lean_ctor_set(x_58, 4, x_56); -lean_ctor_set(x_58, 5, x_57); -lean_ctor_set(x_28, 1, x_58); -return x_28; -} -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_59 = lean_ctor_get(x_28, 1); -x_60 = lean_ctor_get(x_28, 0); -lean_inc(x_59); -lean_inc(x_60); -lean_dec(x_28); -x_61 = lean_ctor_get(x_59, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_59, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_59, 3); -lean_inc(x_63); -x_64 = lean_ctor_get(x_59, 4); -lean_inc(x_64); -x_65 = lean_ctor_get(x_59, 5); -lean_inc(x_65); -if (lean_is_exclusive(x_59)) { - lean_ctor_release(x_59, 0); - lean_ctor_release(x_59, 1); - lean_ctor_release(x_59, 2); - lean_ctor_release(x_59, 3); - lean_ctor_release(x_59, 4); - lean_ctor_release(x_59, 5); - x_66 = x_59; -} else { - lean_dec_ref(x_59); - x_66 = lean_box(0); -} -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 6, 0); -} else { - x_67 = x_66; -} -lean_ctor_set(x_67, 0, x_61); -lean_ctor_set(x_67, 1, x_62); -lean_ctor_set(x_67, 2, x_24); -lean_ctor_set(x_67, 3, x_63); -lean_ctor_set(x_67, 4, x_64); -lean_ctor_set(x_67, 5, x_65); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_60); -lean_ctor_set(x_68, 1, x_67); -return x_68; -} -} -} -} -else -{ -lean_object* x_69; lean_object* x_70; uint8_t x_71; -x_69 = lean_ctor_get(x_12, 0); -x_70 = lean_ctor_get(x_12, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_12); -x_71 = l_Lean_Expr_isForall(x_69); -if (x_71 == 0) -{ -lean_object* x_72; -lean_dec(x_69); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_72 = l_Lean_Expr_getAppFn___main(x_2); -lean_dec(x_2); -if (lean_obj_tag(x_72) == 4) -{ -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -lean_dec(x_72); -x_74 = lean_ctor_get(x_70, 0); -lean_inc(x_74); -lean_inc(x_73); -x_75 = lean_is_class(x_74, x_73); -if (x_75 == 0) -{ -lean_object* x_76; lean_object* x_77; -lean_dec(x_73); -x_76 = lean_box(0); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_70); -return x_77; -} -else -{ -lean_object* x_78; lean_object* x_79; -x_78 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_78, 0, x_73); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_70); -return x_79; -} -} -else -{ -lean_object* x_80; lean_object* x_81; -lean_dec(x_72); -x_80 = lean_box(0); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_70); -return x_81; -} -} -else -{ -lean_object* x_82; uint8_t x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_2); -x_82 = lean_ctor_get(x_70, 2); -lean_inc(x_82); -x_83 = 1; -x_84 = l_Array_empty___closed__1; -x_85 = lean_unsigned_to_nat(0u); -x_86 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8(x_1, x_83, x_3, x_7, x_84, x_85, x_69, x_4, x_70); -if (lean_obj_tag(x_86) == 0) -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_87 = lean_ctor_get(x_86, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_86, 0); -lean_inc(x_88); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_89 = x_86; -} else { - lean_dec_ref(x_86); - x_89 = lean_box(0); -} -x_90 = lean_ctor_get(x_87, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_87, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_87, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_87, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_87, 5); -lean_inc(x_94); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - lean_ctor_release(x_87, 4); - lean_ctor_release(x_87, 5); - x_95 = x_87; -} else { - lean_dec_ref(x_87); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 6, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_90); -lean_ctor_set(x_96, 1, x_91); -lean_ctor_set(x_96, 2, x_82); -lean_ctor_set(x_96, 3, x_92); -lean_ctor_set(x_96, 4, x_93); -lean_ctor_set(x_96, 5, x_94); -if (lean_is_scalar(x_89)) { - x_97 = lean_alloc_ctor(0, 2, 0); -} else { - x_97 = x_89; -} -lean_ctor_set(x_97, 0, x_88); -lean_ctor_set(x_97, 1, x_96); -return x_97; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_86, 0); -lean_inc(x_99); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_100 = x_86; -} else { - lean_dec_ref(x_86); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_98, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_98, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_98, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_98, 5); -lean_inc(x_105); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - lean_ctor_release(x_98, 2); - lean_ctor_release(x_98, 3); - lean_ctor_release(x_98, 4); - lean_ctor_release(x_98, 5); - x_106 = x_98; -} else { - lean_dec_ref(x_98); - x_106 = lean_box(0); -} -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 6, 0); -} else { - x_107 = x_106; -} -lean_ctor_set(x_107, 0, x_101); -lean_ctor_set(x_107, 1, x_102); -lean_ctor_set(x_107, 2, x_82); -lean_ctor_set(x_107, 3, x_103); -lean_ctor_set(x_107, 4, x_104); -lean_ctor_set(x_107, 5, x_105); -if (lean_is_scalar(x_100)) { - x_108 = lean_alloc_ctor(1, 2, 0); -} else { - x_108 = x_100; -} -lean_ctor_set(x_108, 0, x_99); -lean_ctor_set(x_108, 1, x_107); -return x_108; -} -} -} -} -else -{ -uint8_t x_109; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_109 = !lean_is_exclusive(x_12); -if (x_109 == 0) -{ -return x_12; -} -else -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_12, 0); -x_111 = lean_ctor_get(x_12, 1); -lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_12); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_110); -lean_ctor_set(x_112, 1, x_111); -return x_112; -} -} -} -else -{ -lean_object* x_113; uint8_t x_114; uint8_t x_115; uint8_t x_116; uint8_t x_117; uint8_t x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_113 = lean_ctor_get(x_6, 0); -x_114 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_115 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_116 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_117 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_113); -lean_dec(x_6); -x_118 = 1; -x_119 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_119, 0, x_113); -lean_ctor_set_uint8(x_119, sizeof(void*)*1, x_114); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 1, x_115); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 2, x_116); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 3, x_117); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 4, x_118); -lean_inc(x_7); -x_120 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_7); -lean_ctor_set(x_120, 2, x_8); -lean_inc(x_1); -lean_inc(x_2); -x_121 = lean_apply_3(x_1, x_2, x_120, x_5); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; uint8_t x_125; -x_122 = lean_ctor_get(x_121, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_121, 1); -lean_inc(x_123); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_124 = x_121; -} else { - lean_dec_ref(x_121); - x_124 = lean_box(0); -} -x_125 = l_Lean_Expr_isForall(x_122); -if (x_125 == 0) -{ -lean_object* x_126; -lean_dec(x_122); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_126 = l_Lean_Expr_getAppFn___main(x_2); -lean_dec(x_2); -if (lean_obj_tag(x_126) == 4) -{ -lean_object* x_127; lean_object* x_128; uint8_t x_129; -x_127 = lean_ctor_get(x_126, 0); -lean_inc(x_127); -lean_dec(x_126); -x_128 = lean_ctor_get(x_123, 0); -lean_inc(x_128); -lean_inc(x_127); -x_129 = lean_is_class(x_128, x_127); -if (x_129 == 0) -{ -lean_object* x_130; lean_object* x_131; -lean_dec(x_127); -x_130 = lean_box(0); -if (lean_is_scalar(x_124)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_124; -} -lean_ctor_set(x_131, 0, x_130); -lean_ctor_set(x_131, 1, x_123); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; -x_132 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_132, 0, x_127); -if (lean_is_scalar(x_124)) { - x_133 = lean_alloc_ctor(0, 2, 0); -} else { - x_133 = x_124; -} -lean_ctor_set(x_133, 0, x_132); -lean_ctor_set(x_133, 1, x_123); -return x_133; -} -} -else -{ -lean_object* x_134; lean_object* x_135; -lean_dec(x_126); -x_134 = lean_box(0); -if (lean_is_scalar(x_124)) { - x_135 = lean_alloc_ctor(0, 2, 0); -} else { - x_135 = x_124; -} -lean_ctor_set(x_135, 0, x_134); -lean_ctor_set(x_135, 1, x_123); -return x_135; -} -} -else -{ -lean_object* x_136; uint8_t x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; -lean_dec(x_124); -lean_dec(x_2); -x_136 = lean_ctor_get(x_123, 2); -lean_inc(x_136); -x_137 = 1; -x_138 = l_Array_empty___closed__1; -x_139 = lean_unsigned_to_nat(0u); -x_140 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8(x_1, x_137, x_3, x_7, x_138, x_139, x_122, x_4, x_123); -if (lean_obj_tag(x_140) == 0) -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -x_141 = lean_ctor_get(x_140, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_140, 0); -lean_inc(x_142); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - x_143 = x_140; -} else { - lean_dec_ref(x_140); - x_143 = lean_box(0); -} -x_144 = lean_ctor_get(x_141, 0); -lean_inc(x_144); -x_145 = lean_ctor_get(x_141, 1); -lean_inc(x_145); -x_146 = lean_ctor_get(x_141, 3); -lean_inc(x_146); -x_147 = lean_ctor_get(x_141, 4); -lean_inc(x_147); -x_148 = lean_ctor_get(x_141, 5); -lean_inc(x_148); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - lean_ctor_release(x_141, 4); - lean_ctor_release(x_141, 5); - x_149 = x_141; -} else { - lean_dec_ref(x_141); - x_149 = lean_box(0); -} -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_144); -lean_ctor_set(x_150, 1, x_145); -lean_ctor_set(x_150, 2, x_136); -lean_ctor_set(x_150, 3, x_146); -lean_ctor_set(x_150, 4, x_147); -lean_ctor_set(x_150, 5, x_148); -if (lean_is_scalar(x_143)) { - x_151 = lean_alloc_ctor(0, 2, 0); -} else { - x_151 = x_143; -} -lean_ctor_set(x_151, 0, x_142); -lean_ctor_set(x_151, 1, x_150); -return x_151; -} -else -{ -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_152 = lean_ctor_get(x_140, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_140, 0); -lean_inc(x_153); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - x_154 = x_140; -} else { - lean_dec_ref(x_140); - x_154 = lean_box(0); -} -x_155 = lean_ctor_get(x_152, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_152, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_152, 3); -lean_inc(x_157); -x_158 = lean_ctor_get(x_152, 4); -lean_inc(x_158); -x_159 = lean_ctor_get(x_152, 5); -lean_inc(x_159); -if (lean_is_exclusive(x_152)) { - lean_ctor_release(x_152, 0); - lean_ctor_release(x_152, 1); - lean_ctor_release(x_152, 2); - lean_ctor_release(x_152, 3); - lean_ctor_release(x_152, 4); - lean_ctor_release(x_152, 5); - x_160 = x_152; -} else { - lean_dec_ref(x_152); - x_160 = lean_box(0); -} -if (lean_is_scalar(x_160)) { - x_161 = lean_alloc_ctor(0, 6, 0); -} else { - x_161 = x_160; -} -lean_ctor_set(x_161, 0, x_155); -lean_ctor_set(x_161, 1, x_156); -lean_ctor_set(x_161, 2, x_136); -lean_ctor_set(x_161, 3, x_157); -lean_ctor_set(x_161, 4, x_158); -lean_ctor_set(x_161, 5, x_159); -if (lean_is_scalar(x_154)) { - x_162 = lean_alloc_ctor(1, 2, 0); -} else { - x_162 = x_154; -} -lean_ctor_set(x_162, 0, x_153); -lean_ctor_set(x_162, 1, x_161); -return x_162; -} -} -} -else -{ -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_163 = lean_ctor_get(x_121, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_121, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_165 = x_121; -} else { - lean_dec_ref(x_121); - x_165 = lean_box(0); -} -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(1, 2, 0); -} else { - x_166 = x_165; -} -lean_ctor_set(x_166, 0, x_163); -lean_ctor_set(x_166, 1, x_164); -return x_166; -} -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; uint8_t x_6; -x_5 = lean_box(0); -x_6 = !lean_is_exclusive(x_3); -if (x_6 == 0) -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_ctor_get(x_3, 0); -x_8 = !lean_is_exclusive(x_7); -if (x_8 == 0) -{ -uint8_t x_9; lean_object* x_10; -x_9 = 2; -lean_ctor_set_uint8(x_7, sizeof(void*)*1 + 4, x_9); -x_10 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__7(x_1, x_2, x_5, x_3, x_4); -return x_10; -} -else -{ -lean_object* x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; -x_11 = lean_ctor_get(x_7, 0); -x_12 = lean_ctor_get_uint8(x_7, sizeof(void*)*1); -x_13 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 1); -x_14 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 2); -x_15 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 3); -lean_inc(x_11); -lean_dec(x_7); -x_16 = 2; -x_17 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_17, 0, x_11); -lean_ctor_set_uint8(x_17, sizeof(void*)*1, x_12); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 1, x_13); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 2, x_14); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 3, x_15); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 4, x_16); -lean_ctor_set(x_3, 0, x_17); -x_18 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__7(x_1, x_2, x_5, x_3, x_4); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_19 = lean_ctor_get(x_3, 0); -x_20 = lean_ctor_get(x_3, 1); -x_21 = lean_ctor_get(x_3, 2); -lean_inc(x_21); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_3); -x_22 = lean_ctor_get(x_19, 0); -lean_inc(x_22); -x_23 = lean_ctor_get_uint8(x_19, sizeof(void*)*1); -x_24 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 1); -x_25 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 2); -x_26 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_19)) { - lean_ctor_release(x_19, 0); - x_27 = x_19; -} else { - lean_dec_ref(x_19); - x_27 = lean_box(0); -} -x_28 = 2; -if (lean_is_scalar(x_27)) { - x_29 = lean_alloc_ctor(0, 1, 5); -} else { - x_29 = x_27; -} -lean_ctor_set(x_29, 0, x_22); -lean_ctor_set_uint8(x_29, sizeof(void*)*1, x_23); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 1, x_24); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 2, x_25); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 3, x_26); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_28); -x_30 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_30, 0, x_29); -lean_ctor_set(x_30, 1, x_20); -lean_ctor_set(x_30, 2, x_21); -x_31 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__7(x_1, x_2, x_5, x_30, x_4); -return x_31; -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_inferTypeAux___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__6(x_1, x_2, x_3, x_4); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__12(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; uint8_t x_9; -x_8 = lean_array_get_size(x_4); -x_9 = lean_nat_dec_lt(x_5, x_8); -lean_dec(x_8); -if (x_9 == 0) -{ -lean_object* x_10; -lean_dec(x_5); -lean_inc(x_6); -x_10 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_3, x_6, x_7); -if (lean_obj_tag(x_10) == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_11 = lean_ctor_get(x_10, 0); -lean_inc(x_11); -x_12 = lean_ctor_get(x_10, 1); -lean_inc(x_12); -lean_dec(x_10); -x_13 = l_Lean_Meta_mkForall(x_2, x_11, x_6, x_12); -return x_13; -} -else -{ -uint8_t x_14; -lean_dec(x_6); -lean_dec(x_2); -x_14 = !lean_is_exclusive(x_10); -if (x_14 == 0) -{ -return x_10; -} -else -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_10, 0); -x_16 = lean_ctor_get(x_10, 1); -lean_inc(x_16); -lean_inc(x_15); -lean_dec(x_10); -x_17 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_17, 0, x_15); -lean_ctor_set(x_17, 1, x_16); -return x_17; -} -} -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_array_fget(x_4, x_5); -lean_inc(x_6); -x_19 = l_Lean_Meta_getFVarLocalDecl(x_18, x_6, x_7); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_19, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_19, 1); -lean_inc(x_21); -lean_dec(x_19); -x_22 = l_Lean_LocalDecl_type(x_20); -lean_dec(x_20); -lean_inc(x_6); -lean_inc(x_22); -x_23 = l_Lean_Meta_isClassQuick___main(x_22, x_6, x_21); -if (lean_obj_tag(x_23) == 0) -{ -lean_object* x_24; -x_24 = lean_ctor_get(x_23, 0); -lean_inc(x_24); -switch (lean_obj_tag(x_24)) { -case 0: -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_22); -lean_dec(x_18); -x_25 = lean_ctor_get(x_23, 1); -lean_inc(x_25); -lean_dec(x_23); -x_26 = lean_unsigned_to_nat(1u); -x_27 = lean_nat_add(x_5, x_26); -lean_dec(x_5); -x_5 = x_27; -x_7 = x_25; -goto _start; -} -case 1: -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; uint8_t x_33; -lean_dec(x_22); -x_29 = lean_ctor_get(x_23, 1); -lean_inc(x_29); -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 0); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_unsigned_to_nat(1u); -x_32 = lean_nat_add(x_5, x_31); -lean_dec(x_5); -x_33 = !lean_is_exclusive(x_6); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_34 = lean_ctor_get(x_6, 2); -x_35 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_35, 0, x_30); -lean_ctor_set(x_35, 1, x_18); -x_36 = lean_array_push(x_34, x_35); -lean_ctor_set(x_6, 2, x_36); -x_5 = x_32; -x_7 = x_29; -goto _start; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_6, 0); -x_39 = lean_ctor_get(x_6, 1); -x_40 = lean_ctor_get(x_6, 2); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_dec(x_6); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_30); -lean_ctor_set(x_41, 1, x_18); -x_42 = lean_array_push(x_40, x_41); -x_43 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_43, 0, x_38); -lean_ctor_set(x_43, 1, x_39); -lean_ctor_set(x_43, 2, x_42); -x_5 = x_32; -x_6 = x_43; -x_7 = x_29; -goto _start; -} -} -default: -{ -lean_object* x_45; lean_object* x_46; -x_45 = lean_ctor_get(x_23, 1); -lean_inc(x_45); -lean_dec(x_23); -lean_inc(x_6); -lean_inc(x_1); -x_46 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__6(x_1, x_22, x_6, x_45); -if (lean_obj_tag(x_46) == 0) -{ -lean_object* x_47; -x_47 = lean_ctor_get(x_46, 0); -lean_inc(x_47); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -lean_dec(x_18); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -x_49 = lean_unsigned_to_nat(1u); -x_50 = lean_nat_add(x_5, x_49); -lean_dec(x_5); -x_5 = x_50; -x_7 = x_48; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; uint8_t x_56; -x_52 = lean_ctor_get(x_46, 1); -lean_inc(x_52); -lean_dec(x_46); -x_53 = lean_ctor_get(x_47, 0); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_unsigned_to_nat(1u); -x_55 = lean_nat_add(x_5, x_54); -lean_dec(x_5); -x_56 = !lean_is_exclusive(x_6); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_6, 2); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_18); -x_59 = lean_array_push(x_57, x_58); -lean_ctor_set(x_6, 2, x_59); -x_5 = x_55; -x_7 = x_52; -goto _start; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_61 = lean_ctor_get(x_6, 0); -x_62 = lean_ctor_get(x_6, 1); -x_63 = lean_ctor_get(x_6, 2); -lean_inc(x_63); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_6); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_53); -lean_ctor_set(x_64, 1, x_18); -x_65 = lean_array_push(x_63, x_64); -x_66 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_66, 0, x_61); -lean_ctor_set(x_66, 1, x_62); -lean_ctor_set(x_66, 2, x_65); -x_5 = x_55; -x_6 = x_66; -x_7 = x_52; -goto _start; -} -} -} -else -{ -uint8_t x_68; -lean_dec(x_18); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_68 = !lean_is_exclusive(x_46); -if (x_68 == 0) -{ -return x_46; -} -else -{ -lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_69 = lean_ctor_get(x_46, 0); -x_70 = lean_ctor_get(x_46, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_46); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_69); -lean_ctor_set(x_71, 1, x_70); -return x_71; -} -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_22); -lean_dec(x_18); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_72 = !lean_is_exclusive(x_23); -if (x_72 == 0) -{ -return x_23; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_23, 0); -x_74 = lean_ctor_get(x_23, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_23); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -uint8_t x_76; -lean_dec(x_18); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_76 = !lean_is_exclusive(x_19); -if (x_76 == 0) -{ -return x_19; -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; -x_77 = lean_ctor_get(x_19, 0); -x_78 = lean_ctor_get(x_19, 1); -lean_inc(x_78); -lean_inc(x_77); -lean_dec(x_19); -x_79 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_79, 0, x_77); -lean_ctor_set(x_79, 1, x_78); -return x_79; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_inferTypeAux___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -switch (lean_obj_tag(x_5)) { -case 6: -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; uint64_t x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_19 = lean_ctor_get(x_5, 0); -lean_inc(x_19); -x_20 = lean_ctor_get(x_5, 1); -lean_inc(x_20); -x_21 = lean_ctor_get(x_5, 2); -lean_inc(x_21); -x_22 = lean_ctor_get_uint64(x_5, sizeof(void*)*3); -lean_dec(x_5); -x_23 = lean_array_get_size(x_3); -lean_inc(x_3); -x_24 = lean_expr_instantiate_rev_range(x_20, x_4, x_23, x_3); -lean_dec(x_23); -lean_dec(x_20); -x_25 = l_Lean_Meta_mkFreshId___rarg(x_7); -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = (uint8_t)((x_22 << 24) >> 61); -lean_inc(x_26); -x_29 = lean_local_ctx_mk_local_decl(x_2, x_26, x_19, x_24, x_28); -x_30 = l_Lean_mkFVar(x_26); -x_31 = lean_array_push(x_3, x_30); -x_2 = x_29; -x_3 = x_31; -x_5 = x_21; -x_7 = x_27; -goto _start; -} -case 8: -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_33 = lean_ctor_get(x_5, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_5, 1); -lean_inc(x_34); -x_35 = lean_ctor_get(x_5, 2); -lean_inc(x_35); -x_36 = lean_ctor_get(x_5, 3); -lean_inc(x_36); -lean_dec(x_5); -x_37 = lean_array_get_size(x_3); -lean_inc(x_3); -x_38 = lean_expr_instantiate_rev_range(x_34, x_4, x_37, x_3); -lean_dec(x_34); -lean_inc(x_3); -x_39 = lean_expr_instantiate_rev_range(x_35, x_4, x_37, x_3); -lean_dec(x_37); -lean_dec(x_35); -x_40 = l_Lean_Meta_mkFreshId___rarg(x_7); -x_41 = lean_ctor_get(x_40, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_40, 1); -lean_inc(x_42); -lean_dec(x_40); -lean_inc(x_41); -x_43 = lean_local_ctx_mk_let_decl(x_2, x_41, x_33, x_38, x_39); -x_44 = l_Lean_mkFVar(x_41); -x_45 = lean_array_push(x_3, x_44); -x_2 = x_43; -x_3 = x_45; -x_5 = x_36; -x_7 = x_42; -goto _start; -} -default: -{ -lean_object* x_47; -x_47 = lean_box(0); -x_8 = x_47; -goto block_18; -} -} -block_18: -{ -lean_object* x_9; lean_object* x_10; uint8_t x_11; -lean_dec(x_8); -x_9 = lean_array_get_size(x_3); -lean_inc(x_3); -x_10 = lean_expr_instantiate_rev_range(x_5, x_4, x_9, x_3); -lean_dec(x_9); -lean_dec(x_5); -x_11 = !lean_is_exclusive(x_6); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; -x_12 = lean_ctor_get(x_6, 1); -lean_dec(x_12); -lean_ctor_set(x_6, 1, x_2); -lean_inc(x_3); -x_13 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__12(x_1, x_3, x_10, x_3, x_4, x_6, x_7); -lean_dec(x_3); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_6, 0); -x_15 = lean_ctor_get(x_6, 2); -lean_inc(x_15); -lean_inc(x_14); -lean_dec(x_6); -x_16 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_16, 0, x_14); -lean_ctor_set(x_16, 1, x_2); -lean_ctor_set(x_16, 2, x_15); -lean_inc(x_3); -x_17 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__12(x_1, x_3, x_10, x_3, x_4, x_16, x_7); -lean_dec(x_3); -return x_17; -} -} -} -} -lean_object* l_Lean_Meta_lambdaTelescope___at_Lean_Meta_inferTypeAux___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; -x_5 = lean_ctor_get(x_4, 2); -lean_inc(x_5); -x_6 = lean_ctor_get(x_3, 1); -lean_inc(x_6); -x_7 = l_Array_empty___closed__1; -x_8 = lean_unsigned_to_nat(0u); -x_9 = l___private_Init_Lean_Meta_Basic_7__lambdaTelescopeAux___main___at_Lean_Meta_inferTypeAux___spec__4(x_1, x_6, x_7, x_8, x_2, x_3, x_4); -if (lean_obj_tag(x_9) == 0) -{ -uint8_t x_10; -x_10 = !lean_is_exclusive(x_9); -if (x_10 == 0) -{ -lean_object* x_11; uint8_t x_12; -x_11 = lean_ctor_get(x_9, 1); -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; -x_13 = lean_ctor_get(x_11, 2); -lean_dec(x_13); -lean_ctor_set(x_11, 2, x_5); -return x_9; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_14 = lean_ctor_get(x_11, 0); -x_15 = lean_ctor_get(x_11, 1); -x_16 = lean_ctor_get(x_11, 3); -x_17 = lean_ctor_get(x_11, 4); -x_18 = lean_ctor_get(x_11, 5); -lean_inc(x_18); -lean_inc(x_17); -lean_inc(x_16); -lean_inc(x_15); -lean_inc(x_14); -lean_dec(x_11); -x_19 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_19, 0, x_14); -lean_ctor_set(x_19, 1, x_15); -lean_ctor_set(x_19, 2, x_5); -lean_ctor_set(x_19, 3, x_16); -lean_ctor_set(x_19, 4, x_17); -lean_ctor_set(x_19, 5, x_18); -lean_ctor_set(x_9, 1, x_19); -return x_9; -} -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_20 = lean_ctor_get(x_9, 1); -x_21 = lean_ctor_get(x_9, 0); -lean_inc(x_20); -lean_inc(x_21); -lean_dec(x_9); -x_22 = lean_ctor_get(x_20, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_20, 1); -lean_inc(x_23); -x_24 = lean_ctor_get(x_20, 3); -lean_inc(x_24); -x_25 = lean_ctor_get(x_20, 4); -lean_inc(x_25); -x_26 = lean_ctor_get(x_20, 5); -lean_inc(x_26); -if (lean_is_exclusive(x_20)) { - lean_ctor_release(x_20, 0); - lean_ctor_release(x_20, 1); - lean_ctor_release(x_20, 2); - lean_ctor_release(x_20, 3); - lean_ctor_release(x_20, 4); - lean_ctor_release(x_20, 5); - x_27 = x_20; -} else { - lean_dec_ref(x_20); - x_27 = lean_box(0); -} -if (lean_is_scalar(x_27)) { - x_28 = lean_alloc_ctor(0, 6, 0); -} else { - x_28 = x_27; -} -lean_ctor_set(x_28, 0, x_22); -lean_ctor_set(x_28, 1, x_23); -lean_ctor_set(x_28, 2, x_5); -lean_ctor_set(x_28, 3, x_24); -lean_ctor_set(x_28, 4, x_25); -lean_ctor_set(x_28, 5, x_26); -x_29 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_29, 0, x_21); -lean_ctor_set(x_29, 1, x_28); -return x_29; -} -} -else -{ -uint8_t x_30; -x_30 = !lean_is_exclusive(x_9); -if (x_30 == 0) -{ -lean_object* x_31; uint8_t x_32; -x_31 = lean_ctor_get(x_9, 1); -x_32 = !lean_is_exclusive(x_31); -if (x_32 == 0) -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_31, 2); -lean_dec(x_33); -lean_ctor_set(x_31, 2, x_5); -return x_9; -} -else -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_34 = lean_ctor_get(x_31, 0); -x_35 = lean_ctor_get(x_31, 1); -x_36 = lean_ctor_get(x_31, 3); -x_37 = lean_ctor_get(x_31, 4); -x_38 = lean_ctor_get(x_31, 5); -lean_inc(x_38); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_dec(x_31); -x_39 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_39, 0, x_34); -lean_ctor_set(x_39, 1, x_35); -lean_ctor_set(x_39, 2, x_5); -lean_ctor_set(x_39, 3, x_36); -lean_ctor_set(x_39, 4, x_37); -lean_ctor_set(x_39, 5, x_38); -lean_ctor_set(x_9, 1, x_39); -return x_9; -} -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_40 = lean_ctor_get(x_9, 1); -x_41 = lean_ctor_get(x_9, 0); -lean_inc(x_40); -lean_inc(x_41); -lean_dec(x_9); -x_42 = lean_ctor_get(x_40, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_40, 1); -lean_inc(x_43); -x_44 = lean_ctor_get(x_40, 3); -lean_inc(x_44); -x_45 = lean_ctor_get(x_40, 4); -lean_inc(x_45); -x_46 = lean_ctor_get(x_40, 5); -lean_inc(x_46); -if (lean_is_exclusive(x_40)) { - lean_ctor_release(x_40, 0); - lean_ctor_release(x_40, 1); - lean_ctor_release(x_40, 2); - lean_ctor_release(x_40, 3); - lean_ctor_release(x_40, 4); - lean_ctor_release(x_40, 5); - x_47 = x_40; -} else { - lean_dec_ref(x_40); - x_47 = lean_box(0); -} -if (lean_is_scalar(x_47)) { - x_48 = lean_alloc_ctor(0, 6, 0); -} else { - x_48 = x_47; -} -lean_ctor_set(x_48, 0, x_42); -lean_ctor_set(x_48, 1, x_43); -lean_ctor_set(x_48, 2, x_5); -lean_ctor_set(x_48, 3, x_44); -lean_ctor_set(x_48, 4, x_45); -lean_ctor_set(x_48, 5, x_46); -x_49 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_49, 0, x_41); -lean_ctor_set(x_49, 1, x_48); -return x_49; -} -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_5__inferLambdaType___at_Lean_Meta_inferTypeAux___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Meta_lambdaTelescope___at_Lean_Meta_inferTypeAux___spec__3(x_1, x_2, x_3, x_4); -return x_5; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__14(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_nat_dec_eq(x_5, x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_sub(x_5, x_11); -lean_dec(x_5); -x_22 = lean_nat_sub(x_4, x_12); -x_23 = lean_nat_sub(x_22, x_11); -lean_dec(x_22); -x_24 = lean_ctor_get(x_6, 0); -lean_inc(x_24); -x_25 = lean_ctor_get(x_6, 1); -lean_inc(x_25); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_26 = x_6; -} else { - lean_dec_ref(x_6); - x_26 = lean_box(0); -} -if (lean_obj_tag(x_25) == 7) -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; -lean_dec(x_26); -lean_dec(x_23); -x_88 = lean_ctor_get(x_25, 2); -lean_inc(x_88); -lean_dec(x_25); -x_89 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_89, 0, x_24); -lean_ctor_set(x_89, 1, x_88); -x_90 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_90, 0, x_89); -lean_ctor_set(x_90, 1, x_8); -x_13 = x_90; -goto block_21; -} -else -{ -lean_object* x_91; -x_91 = lean_box(0); -x_27 = x_91; -goto block_87; -} -block_21: -{ -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -x_5 = x_12; -x_6 = x_14; -x_8 = x_15; -goto _start; -} -else -{ -uint8_t x_17; -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_17 = !lean_is_exclusive(x_13); -if (x_17 == 0) -{ -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_13, 0); -x_19 = lean_ctor_get(x_13, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_13); -x_20 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_19); -return x_20; -} -} -} -block_87: -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; -lean_dec(x_27); -lean_inc(x_3); -x_28 = lean_expr_instantiate_rev_range(x_25, x_24, x_23, x_3); -lean_dec(x_24); -lean_dec(x_25); -x_29 = lean_ctor_get(x_7, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_7, 1); -lean_inc(x_30); -x_31 = lean_ctor_get(x_7, 2); -lean_inc(x_31); -x_32 = !lean_is_exclusive(x_29); -if (x_32 == 0) -{ -uint8_t x_33; lean_object* x_34; lean_object* x_35; -x_33 = 1; -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_33); -lean_inc(x_30); -x_34 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_34, 0, x_29); -lean_ctor_set(x_34, 1, x_30); -lean_ctor_set(x_34, 2, x_31); -lean_inc(x_1); -x_35 = lean_apply_3(x_1, x_28, x_34, x_8); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_35, 1); -lean_inc(x_37); -if (lean_is_exclusive(x_35)) { - lean_ctor_release(x_35, 0); - lean_ctor_release(x_35, 1); - x_38 = x_35; -} else { - lean_dec_ref(x_35); - x_38 = lean_box(0); -} -if (lean_obj_tag(x_36) == 7) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_38); -lean_dec(x_30); -x_49 = lean_ctor_get(x_36, 2); -lean_inc(x_49); -lean_dec(x_36); -if (lean_is_scalar(x_26)) { - x_50 = lean_alloc_ctor(0, 2, 0); -} else { - x_50 = x_26; -} -lean_ctor_set(x_50, 0, x_23); -lean_ctor_set(x_50, 1, x_49); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_37); -x_13 = x_51; -goto block_21; -} -else -{ -lean_object* x_52; -lean_dec(x_36); -lean_dec(x_26); -x_52 = lean_box(0); -x_39 = x_52; -goto block_48; -} -block_48: -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -lean_dec(x_39); -x_40 = lean_ctor_get(x_37, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_37, 1); -lean_inc(x_41); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_40); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set(x_42, 2, x_30); -lean_inc(x_2); -x_43 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_23, x_3, x_9, x_2); -x_44 = l_Lean_Expr_Inhabited; -x_45 = lean_array_get(x_44, x_3, x_23); -lean_dec(x_23); -x_46 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_42); -if (lean_is_scalar(x_38)) { - x_47 = lean_alloc_ctor(1, 2, 0); -} else { - x_47 = x_38; - lean_ctor_set_tag(x_47, 1); -} -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_37); -x_13 = x_47; -goto block_21; -} -} -else -{ -uint8_t x_53; -lean_dec(x_30); -lean_dec(x_26); -lean_dec(x_23); -x_53 = !lean_is_exclusive(x_35); -if (x_53 == 0) -{ -x_13 = x_35; -goto block_21; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_35, 0); -x_55 = lean_ctor_get(x_35, 1); -lean_inc(x_55); -lean_inc(x_54); -lean_dec(x_35); -x_56 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_56, 0, x_54); -lean_ctor_set(x_56, 1, x_55); -x_13 = x_56; -goto block_21; -} -} -} -else -{ -lean_object* x_57; uint8_t x_58; uint8_t x_59; uint8_t x_60; uint8_t x_61; uint8_t x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_57 = lean_ctor_get(x_29, 0); -x_58 = lean_ctor_get_uint8(x_29, sizeof(void*)*1); -x_59 = lean_ctor_get_uint8(x_29, sizeof(void*)*1 + 1); -x_60 = lean_ctor_get_uint8(x_29, sizeof(void*)*1 + 2); -x_61 = lean_ctor_get_uint8(x_29, sizeof(void*)*1 + 3); -lean_inc(x_57); -lean_dec(x_29); -x_62 = 1; -x_63 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_63, 0, x_57); -lean_ctor_set_uint8(x_63, sizeof(void*)*1, x_58); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 1, x_59); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 2, x_60); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 3, x_61); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 4, x_62); -lean_inc(x_30); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_63); -lean_ctor_set(x_64, 1, x_30); -lean_ctor_set(x_64, 2, x_31); -lean_inc(x_1); -x_65 = lean_apply_3(x_1, x_28, x_64, x_8); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_65, 1); -lean_inc(x_67); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_68 = x_65; -} else { - lean_dec_ref(x_65); - x_68 = lean_box(0); -} -if (lean_obj_tag(x_66) == 7) -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -lean_dec(x_68); -lean_dec(x_30); -x_79 = lean_ctor_get(x_66, 2); -lean_inc(x_79); -lean_dec(x_66); -if (lean_is_scalar(x_26)) { - x_80 = lean_alloc_ctor(0, 2, 0); -} else { - x_80 = x_26; -} -lean_ctor_set(x_80, 0, x_23); -lean_ctor_set(x_80, 1, x_79); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_67); -x_13 = x_81; -goto block_21; -} -else -{ -lean_object* x_82; -lean_dec(x_66); -lean_dec(x_26); -x_82 = lean_box(0); -x_69 = x_82; -goto block_78; -} -block_78: -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -lean_dec(x_69); -x_70 = lean_ctor_get(x_67, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_67, 1); -lean_inc(x_71); -x_72 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -lean_ctor_set(x_72, 2, x_30); -lean_inc(x_2); -x_73 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_23, x_3, x_9, x_2); -x_74 = l_Lean_Expr_Inhabited; -x_75 = lean_array_get(x_74, x_3, x_23); -lean_dec(x_23); -x_76 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_75); -lean_ctor_set(x_76, 2, x_72); -if (lean_is_scalar(x_68)) { - x_77 = lean_alloc_ctor(1, 2, 0); -} else { - x_77 = x_68; - lean_ctor_set_tag(x_77, 1); -} -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_67); -x_13 = x_77; -goto block_21; -} -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_30); -lean_dec(x_26); -lean_dec(x_23); -x_83 = lean_ctor_get(x_65, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_65, 1); -lean_inc(x_84); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_85 = x_65; -} else { - lean_dec_ref(x_65); - x_85 = lean_box(0); -} -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(1, 2, 0); -} else { - x_86 = x_85; -} -lean_ctor_set(x_86, 0, x_83); -lean_ctor_set(x_86, 1, x_84); -x_13 = x_86; -goto block_21; -} -} -} -} -else -{ -lean_object* x_92; -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_92 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_92, 0, x_6); -lean_ctor_set(x_92, 1, x_8); -return x_92; -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__13(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_1); -x_6 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_2, x_4, x_5); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); -lean_dec(x_6); -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_7); -x_11 = lean_array_get_size(x_3); -lean_inc(x_11); -lean_inc(x_3); -x_12 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__14(x_1, x_2, x_3, x_11, x_11, x_10, x_4, x_8); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -x_17 = lean_expr_instantiate_rev_range(x_16, x_15, x_11, x_3); -lean_dec(x_11); -lean_dec(x_15); -lean_dec(x_16); -lean_ctor_set(x_12, 0, x_17); -return x_12; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_12); -x_20 = lean_ctor_get(x_18, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -lean_dec(x_18); -x_22 = lean_expr_instantiate_rev_range(x_21, x_20, x_11, x_3); -lean_dec(x_11); -lean_dec(x_20); -lean_dec(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); -return x_23; -} -} -else -{ -uint8_t x_24; -lean_dec(x_11); -lean_dec(x_3); -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) -{ -return x_12; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -uint8_t x_28; -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_28 = !lean_is_exclusive(x_6); -if (x_28 == 0) -{ -return x_6; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_6, 0); -x_30 = lean_ctor_get(x_6, 1); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_6); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -} -} -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__16(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_1); -x_5 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_2, x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_6 = lean_ctor_get(x_3, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_5, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_5, 1); -lean_inc(x_8); -lean_dec(x_5); -x_9 = lean_ctor_get(x_3, 1); -lean_inc(x_9); -x_10 = lean_ctor_get(x_3, 2); -lean_inc(x_10); -x_11 = !lean_is_exclusive(x_6); -if (x_11 == 0) -{ -uint8_t x_12; lean_object* x_13; lean_object* x_14; -x_12 = 1; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_12); -lean_inc(x_9); -x_13 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_13, 0, x_6); -lean_ctor_set(x_13, 1, x_9); -lean_ctor_set(x_13, 2, x_10); -x_14 = lean_apply_3(x_1, x_7, x_13, x_8); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -switch (lean_obj_tag(x_15)) { -case 2: -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -x_17 = lean_ctor_get(x_15, 0); -lean_inc(x_17); -lean_dec(x_15); -lean_inc(x_17); -x_18 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_17, x_3, x_16); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; uint8_t x_20; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_unbox(x_19); -lean_dec(x_19); -if (x_20 == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_9); -lean_dec(x_2); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -lean_dec(x_18); -x_22 = l_Lean_Meta_mkFreshId___rarg(x_21); -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = l_Lean_mkLevelMVar(x_23); -lean_inc(x_25); -x_26 = l_Lean_mkSort(x_25); -x_27 = l_Lean_Meta_assignExprMVar(x_17, x_26, x_3, x_24); -lean_dec(x_3); -if (lean_obj_tag(x_27) == 0) -{ -uint8_t x_28; -x_28 = !lean_is_exclusive(x_27); -if (x_28 == 0) -{ -lean_object* x_29; -x_29 = lean_ctor_get(x_27, 0); -lean_dec(x_29); -lean_ctor_set(x_27, 0, x_25); -return x_27; -} -else -{ -lean_object* x_30; lean_object* x_31; -x_30 = lean_ctor_get(x_27, 1); -lean_inc(x_30); -lean_dec(x_27); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_25); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -else -{ -uint8_t x_32; -lean_dec(x_25); -x_32 = !lean_is_exclusive(x_27); -if (x_32 == 0) -{ -return x_27; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_27, 0); -x_34 = lean_ctor_get(x_27, 1); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_27); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_33); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -} -else -{ -uint8_t x_36; -lean_dec(x_17); -lean_dec(x_3); -x_36 = !lean_is_exclusive(x_18); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_18, 1); -x_38 = lean_ctor_get(x_18, 0); -lean_dec(x_38); -x_39 = lean_ctor_get(x_37, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_37, 1); -lean_inc(x_40); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -lean_ctor_set(x_41, 2, x_9); -x_42 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_42, 0, x_2); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set_tag(x_18, 1); -lean_ctor_set(x_18, 0, x_42); -return x_18; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_43 = lean_ctor_get(x_18, 1); -lean_inc(x_43); -lean_dec(x_18); -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_9); -x_47 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_47, 0, x_2); -lean_ctor_set(x_47, 1, x_46); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_47); -lean_ctor_set(x_48, 1, x_43); -return x_48; -} -} -} -else -{ -uint8_t x_49; -lean_dec(x_17); -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_49 = !lean_is_exclusive(x_18); -if (x_49 == 0) -{ -return x_18; -} -else -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_18, 0); -x_51 = lean_ctor_get(x_18, 1); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_18); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); -return x_52; -} -} -} -case 3: -{ -uint8_t x_53; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_53 = !lean_is_exclusive(x_14); -if (x_53 == 0) -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_14, 0); -lean_dec(x_54); -x_55 = lean_ctor_get(x_15, 0); -lean_inc(x_55); -lean_dec(x_15); -lean_ctor_set(x_14, 0, x_55); -return x_14; -} -else -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_14, 1); -lean_inc(x_56); -lean_dec(x_14); -x_57 = lean_ctor_get(x_15, 0); -lean_inc(x_57); -lean_dec(x_15); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_56); -return x_58; -} -} -default: -{ -uint8_t x_59; -lean_dec(x_15); -lean_dec(x_3); -x_59 = !lean_is_exclusive(x_14); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_60 = lean_ctor_get(x_14, 1); -x_61 = lean_ctor_get(x_14, 0); -lean_dec(x_61); -x_62 = lean_ctor_get(x_60, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_60, 1); -lean_inc(x_63); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_62); -lean_ctor_set(x_64, 1, x_63); -lean_ctor_set(x_64, 2, x_9); -x_65 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_65, 0, x_2); -lean_ctor_set(x_65, 1, x_64); -lean_ctor_set_tag(x_14, 1); -lean_ctor_set(x_14, 0, x_65); -return x_14; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_14, 1); -lean_inc(x_66); -lean_dec(x_14); -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_66, 1); -lean_inc(x_68); -x_69 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_69, 0, x_67); -lean_ctor_set(x_69, 1, x_68); -lean_ctor_set(x_69, 2, x_9); -x_70 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_70, 0, x_2); -lean_ctor_set(x_70, 1, x_69); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_66); -return x_71; -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_72 = !lean_is_exclusive(x_14); -if (x_72 == 0) -{ -return x_14; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_14, 0); -x_74 = lean_ctor_get(x_14, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_14); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -lean_object* x_76; uint8_t x_77; uint8_t x_78; uint8_t x_79; uint8_t x_80; uint8_t x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_76 = lean_ctor_get(x_6, 0); -x_77 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_78 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_79 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_80 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_76); -lean_dec(x_6); -x_81 = 1; -x_82 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_82, 0, x_76); -lean_ctor_set_uint8(x_82, sizeof(void*)*1, x_77); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 1, x_78); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 2, x_79); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 3, x_80); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 4, x_81); -lean_inc(x_9); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_9); -lean_ctor_set(x_83, 2, x_10); -x_84 = lean_apply_3(x_1, x_7, x_83, x_8); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; -x_85 = lean_ctor_get(x_84, 0); -lean_inc(x_85); -switch (lean_obj_tag(x_85)) { -case 2: -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_84, 1); -lean_inc(x_86); -lean_dec(x_84); -x_87 = lean_ctor_get(x_85, 0); -lean_inc(x_87); -lean_dec(x_85); -lean_inc(x_87); -x_88 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_87, x_3, x_86); -if (lean_obj_tag(x_88) == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_88, 0); -lean_inc(x_89); -x_90 = lean_unbox(x_89); -lean_dec(x_89); -if (x_90 == 0) -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -lean_dec(x_9); -lean_dec(x_2); -x_91 = lean_ctor_get(x_88, 1); -lean_inc(x_91); -lean_dec(x_88); -x_92 = l_Lean_Meta_mkFreshId___rarg(x_91); -x_93 = lean_ctor_get(x_92, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_92, 1); -lean_inc(x_94); -lean_dec(x_92); -x_95 = l_Lean_mkLevelMVar(x_93); -lean_inc(x_95); -x_96 = l_Lean_mkSort(x_95); -x_97 = l_Lean_Meta_assignExprMVar(x_87, x_96, x_3, x_94); -lean_dec(x_3); -if (lean_obj_tag(x_97) == 0) -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_98 = lean_ctor_get(x_97, 1); -lean_inc(x_98); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - x_99 = x_97; -} else { - lean_dec_ref(x_97); - x_99 = lean_box(0); -} -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(0, 2, 0); -} else { - x_100 = x_99; -} -lean_ctor_set(x_100, 0, x_95); -lean_ctor_set(x_100, 1, x_98); -return x_100; -} -else -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -lean_dec(x_95); -x_101 = lean_ctor_get(x_97, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_97, 1); -lean_inc(x_102); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - x_103 = x_97; -} else { - lean_dec_ref(x_97); - x_103 = lean_box(0); -} -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(1, 2, 0); -} else { - x_104 = x_103; -} -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -return x_104; -} -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -lean_dec(x_87); -lean_dec(x_3); -x_105 = lean_ctor_get(x_88, 1); -lean_inc(x_105); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_106 = x_88; -} else { - lean_dec_ref(x_88); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_105, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_105, 1); -lean_inc(x_108); -x_109 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_109, 0, x_107); -lean_ctor_set(x_109, 1, x_108); -lean_ctor_set(x_109, 2, x_9); -x_110 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_110, 0, x_2); -lean_ctor_set(x_110, 1, x_109); -if (lean_is_scalar(x_106)) { - x_111 = lean_alloc_ctor(1, 2, 0); -} else { - x_111 = x_106; - lean_ctor_set_tag(x_111, 1); -} -lean_ctor_set(x_111, 0, x_110); -lean_ctor_set(x_111, 1, x_105); -return x_111; -} -} -else -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -lean_dec(x_87); -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_112 = lean_ctor_get(x_88, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_88, 1); -lean_inc(x_113); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_114 = x_88; -} else { - lean_dec_ref(x_88); - x_114 = lean_box(0); -} -if (lean_is_scalar(x_114)) { - x_115 = lean_alloc_ctor(1, 2, 0); -} else { - x_115 = x_114; -} -lean_ctor_set(x_115, 0, x_112); -lean_ctor_set(x_115, 1, x_113); -return x_115; -} -} -case 3: -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_116 = lean_ctor_get(x_84, 1); -lean_inc(x_116); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_117 = x_84; -} else { - lean_dec_ref(x_84); - x_117 = lean_box(0); -} -x_118 = lean_ctor_get(x_85, 0); -lean_inc(x_118); -lean_dec(x_85); -if (lean_is_scalar(x_117)) { - x_119 = lean_alloc_ctor(0, 2, 0); -} else { - x_119 = x_117; -} -lean_ctor_set(x_119, 0, x_118); -lean_ctor_set(x_119, 1, x_116); -return x_119; -} -default: -{ -lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; -lean_dec(x_85); -lean_dec(x_3); -x_120 = lean_ctor_get(x_84, 1); -lean_inc(x_120); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_121 = x_84; -} else { - lean_dec_ref(x_84); - x_121 = lean_box(0); -} -x_122 = lean_ctor_get(x_120, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_120, 1); -lean_inc(x_123); -x_124 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_124, 0, x_122); -lean_ctor_set(x_124, 1, x_123); -lean_ctor_set(x_124, 2, x_9); -x_125 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_125, 0, x_2); -lean_ctor_set(x_125, 1, x_124); -if (lean_is_scalar(x_121)) { - x_126 = lean_alloc_ctor(1, 2, 0); -} else { - x_126 = x_121; - lean_ctor_set_tag(x_126, 1); -} -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_120); -return x_126; -} -} -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_127 = lean_ctor_get(x_84, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_84, 1); -lean_inc(x_128); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_129 = x_84; -} else { - lean_dec_ref(x_84); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(1, 2, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_127); -lean_ctor_set(x_130, 1, x_128); -return x_130; -} -} -} -else -{ -uint8_t x_131; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_131 = !lean_is_exclusive(x_5); -if (x_131 == 0) -{ -return x_5; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_132 = lean_ctor_get(x_5, 0); -x_133 = lean_ctor_get(x_5, 1); -lean_inc(x_133); -lean_inc(x_132); -lean_dec(x_5); -x_134 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_134, 0, x_132); -lean_ctor_set(x_134, 1, x_133); -return x_134; -} -} -} -} -lean_object* l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__17(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_1); -x_5 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_2, x_3, x_4); -if (lean_obj_tag(x_5) == 0) -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; -x_6 = lean_ctor_get(x_3, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_5, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_5, 1); -lean_inc(x_8); -lean_dec(x_5); -x_9 = lean_ctor_get(x_3, 1); -lean_inc(x_9); -x_10 = lean_ctor_get(x_3, 2); -lean_inc(x_10); -x_11 = !lean_is_exclusive(x_6); -if (x_11 == 0) -{ -uint8_t x_12; lean_object* x_13; lean_object* x_14; -x_12 = 1; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_12); -lean_inc(x_9); -x_13 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_13, 0, x_6); -lean_ctor_set(x_13, 1, x_9); -lean_ctor_set(x_13, 2, x_10); -x_14 = lean_apply_3(x_1, x_7, x_13, x_8); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -switch (lean_obj_tag(x_15)) { -case 2: -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -x_17 = lean_ctor_get(x_15, 0); -lean_inc(x_17); -lean_dec(x_15); -lean_inc(x_17); -x_18 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_17, x_3, x_16); -if (lean_obj_tag(x_18) == 0) -{ -lean_object* x_19; uint8_t x_20; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -x_20 = lean_unbox(x_19); -lean_dec(x_19); -if (x_20 == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_9); -lean_dec(x_2); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -lean_dec(x_18); -x_22 = l_Lean_Meta_mkFreshId___rarg(x_21); -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = l_Lean_mkLevelMVar(x_23); -lean_inc(x_25); -x_26 = l_Lean_mkSort(x_25); -x_27 = l_Lean_Meta_assignExprMVar(x_17, x_26, x_3, x_24); -lean_dec(x_3); -if (lean_obj_tag(x_27) == 0) -{ -uint8_t x_28; -x_28 = !lean_is_exclusive(x_27); -if (x_28 == 0) -{ -lean_object* x_29; -x_29 = lean_ctor_get(x_27, 0); -lean_dec(x_29); -lean_ctor_set(x_27, 0, x_25); -return x_27; -} -else -{ -lean_object* x_30; lean_object* x_31; -x_30 = lean_ctor_get(x_27, 1); -lean_inc(x_30); -lean_dec(x_27); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_25); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -else -{ -uint8_t x_32; -lean_dec(x_25); -x_32 = !lean_is_exclusive(x_27); -if (x_32 == 0) -{ -return x_27; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_33 = lean_ctor_get(x_27, 0); -x_34 = lean_ctor_get(x_27, 1); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_27); -x_35 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_35, 0, x_33); -lean_ctor_set(x_35, 1, x_34); -return x_35; -} -} -} -else -{ -uint8_t x_36; -lean_dec(x_17); -lean_dec(x_3); -x_36 = !lean_is_exclusive(x_18); -if (x_36 == 0) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; -x_37 = lean_ctor_get(x_18, 1); -x_38 = lean_ctor_get(x_18, 0); -lean_dec(x_38); -x_39 = lean_ctor_get(x_37, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_37, 1); -lean_inc(x_40); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -lean_ctor_set(x_41, 2, x_9); -x_42 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_42, 0, x_2); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set_tag(x_18, 1); -lean_ctor_set(x_18, 0, x_42); -return x_18; -} -else -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_43 = lean_ctor_get(x_18, 1); -lean_inc(x_43); -lean_dec(x_18); -x_44 = lean_ctor_get(x_43, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_43, 1); -lean_inc(x_45); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_9); -x_47 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_47, 0, x_2); -lean_ctor_set(x_47, 1, x_46); -x_48 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_48, 0, x_47); -lean_ctor_set(x_48, 1, x_43); -return x_48; -} -} -} -else -{ -uint8_t x_49; -lean_dec(x_17); -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_49 = !lean_is_exclusive(x_18); -if (x_49 == 0) -{ -return x_18; -} -else -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_18, 0); -x_51 = lean_ctor_get(x_18, 1); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_18); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); -return x_52; -} -} -} -case 3: -{ -uint8_t x_53; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_53 = !lean_is_exclusive(x_14); -if (x_53 == 0) -{ -lean_object* x_54; lean_object* x_55; -x_54 = lean_ctor_get(x_14, 0); -lean_dec(x_54); -x_55 = lean_ctor_get(x_15, 0); -lean_inc(x_55); -lean_dec(x_15); -lean_ctor_set(x_14, 0, x_55); -return x_14; -} -else -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_56 = lean_ctor_get(x_14, 1); -lean_inc(x_56); -lean_dec(x_14); -x_57 = lean_ctor_get(x_15, 0); -lean_inc(x_57); -lean_dec(x_15); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_56); -return x_58; -} -} -default: -{ -uint8_t x_59; -lean_dec(x_15); -lean_dec(x_3); -x_59 = !lean_is_exclusive(x_14); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_60 = lean_ctor_get(x_14, 1); -x_61 = lean_ctor_get(x_14, 0); -lean_dec(x_61); -x_62 = lean_ctor_get(x_60, 0); -lean_inc(x_62); -x_63 = lean_ctor_get(x_60, 1); -lean_inc(x_63); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_62); -lean_ctor_set(x_64, 1, x_63); -lean_ctor_set(x_64, 2, x_9); -x_65 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_65, 0, x_2); -lean_ctor_set(x_65, 1, x_64); -lean_ctor_set_tag(x_14, 1); -lean_ctor_set(x_14, 0, x_65); -return x_14; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_14, 1); -lean_inc(x_66); -lean_dec(x_14); -x_67 = lean_ctor_get(x_66, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_66, 1); -lean_inc(x_68); -x_69 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_69, 0, x_67); -lean_ctor_set(x_69, 1, x_68); -lean_ctor_set(x_69, 2, x_9); -x_70 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_70, 0, x_2); -lean_ctor_set(x_70, 1, x_69); -x_71 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_66); -return x_71; -} -} -} -} -else -{ -uint8_t x_72; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_72 = !lean_is_exclusive(x_14); -if (x_72 == 0) -{ -return x_14; -} -else -{ -lean_object* x_73; lean_object* x_74; lean_object* x_75; -x_73 = lean_ctor_get(x_14, 0); -x_74 = lean_ctor_get(x_14, 1); -lean_inc(x_74); -lean_inc(x_73); -lean_dec(x_14); -x_75 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -return x_75; -} -} -} -else -{ -lean_object* x_76; uint8_t x_77; uint8_t x_78; uint8_t x_79; uint8_t x_80; uint8_t x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_76 = lean_ctor_get(x_6, 0); -x_77 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_78 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_79 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_80 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_76); -lean_dec(x_6); -x_81 = 1; -x_82 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_82, 0, x_76); -lean_ctor_set_uint8(x_82, sizeof(void*)*1, x_77); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 1, x_78); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 2, x_79); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 3, x_80); -lean_ctor_set_uint8(x_82, sizeof(void*)*1 + 4, x_81); -lean_inc(x_9); -x_83 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_83, 0, x_82); -lean_ctor_set(x_83, 1, x_9); -lean_ctor_set(x_83, 2, x_10); -x_84 = lean_apply_3(x_1, x_7, x_83, x_8); -if (lean_obj_tag(x_84) == 0) -{ -lean_object* x_85; -x_85 = lean_ctor_get(x_84, 0); -lean_inc(x_85); -switch (lean_obj_tag(x_85)) { -case 2: -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; -x_86 = lean_ctor_get(x_84, 1); -lean_inc(x_86); -lean_dec(x_84); -x_87 = lean_ctor_get(x_85, 0); -lean_inc(x_87); -lean_dec(x_85); -lean_inc(x_87); -x_88 = l_Lean_Meta_isReadOnlyOrSyntheticExprMVar(x_87, x_3, x_86); -if (lean_obj_tag(x_88) == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_88, 0); -lean_inc(x_89); -x_90 = lean_unbox(x_89); -lean_dec(x_89); -if (x_90 == 0) -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -lean_dec(x_9); -lean_dec(x_2); -x_91 = lean_ctor_get(x_88, 1); -lean_inc(x_91); -lean_dec(x_88); -x_92 = l_Lean_Meta_mkFreshId___rarg(x_91); -x_93 = lean_ctor_get(x_92, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_92, 1); -lean_inc(x_94); -lean_dec(x_92); -x_95 = l_Lean_mkLevelMVar(x_93); -lean_inc(x_95); -x_96 = l_Lean_mkSort(x_95); -x_97 = l_Lean_Meta_assignExprMVar(x_87, x_96, x_3, x_94); -lean_dec(x_3); -if (lean_obj_tag(x_97) == 0) -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_98 = lean_ctor_get(x_97, 1); -lean_inc(x_98); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - x_99 = x_97; -} else { - lean_dec_ref(x_97); - x_99 = lean_box(0); -} -if (lean_is_scalar(x_99)) { - x_100 = lean_alloc_ctor(0, 2, 0); -} else { - x_100 = x_99; -} -lean_ctor_set(x_100, 0, x_95); -lean_ctor_set(x_100, 1, x_98); -return x_100; -} -else -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -lean_dec(x_95); -x_101 = lean_ctor_get(x_97, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_97, 1); -lean_inc(x_102); -if (lean_is_exclusive(x_97)) { - lean_ctor_release(x_97, 0); - lean_ctor_release(x_97, 1); - x_103 = x_97; -} else { - lean_dec_ref(x_97); - x_103 = lean_box(0); -} -if (lean_is_scalar(x_103)) { - x_104 = lean_alloc_ctor(1, 2, 0); -} else { - x_104 = x_103; -} -lean_ctor_set(x_104, 0, x_101); -lean_ctor_set(x_104, 1, x_102); -return x_104; -} -} -else -{ -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; -lean_dec(x_87); -lean_dec(x_3); -x_105 = lean_ctor_get(x_88, 1); -lean_inc(x_105); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_106 = x_88; -} else { - lean_dec_ref(x_88); - x_106 = lean_box(0); -} -x_107 = lean_ctor_get(x_105, 0); -lean_inc(x_107); -x_108 = lean_ctor_get(x_105, 1); -lean_inc(x_108); -x_109 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_109, 0, x_107); -lean_ctor_set(x_109, 1, x_108); -lean_ctor_set(x_109, 2, x_9); -x_110 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_110, 0, x_2); -lean_ctor_set(x_110, 1, x_109); -if (lean_is_scalar(x_106)) { - x_111 = lean_alloc_ctor(1, 2, 0); -} else { - x_111 = x_106; - lean_ctor_set_tag(x_111, 1); -} -lean_ctor_set(x_111, 0, x_110); -lean_ctor_set(x_111, 1, x_105); -return x_111; -} -} -else -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; -lean_dec(x_87); -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_112 = lean_ctor_get(x_88, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_88, 1); -lean_inc(x_113); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_114 = x_88; -} else { - lean_dec_ref(x_88); - x_114 = lean_box(0); -} -if (lean_is_scalar(x_114)) { - x_115 = lean_alloc_ctor(1, 2, 0); -} else { - x_115 = x_114; -} -lean_ctor_set(x_115, 0, x_112); -lean_ctor_set(x_115, 1, x_113); -return x_115; -} -} -case 3: -{ -lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_116 = lean_ctor_get(x_84, 1); -lean_inc(x_116); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_117 = x_84; -} else { - lean_dec_ref(x_84); - x_117 = lean_box(0); -} -x_118 = lean_ctor_get(x_85, 0); -lean_inc(x_118); -lean_dec(x_85); -if (lean_is_scalar(x_117)) { - x_119 = lean_alloc_ctor(0, 2, 0); -} else { - x_119 = x_117; -} -lean_ctor_set(x_119, 0, x_118); -lean_ctor_set(x_119, 1, x_116); -return x_119; -} -default: -{ -lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; -lean_dec(x_85); -lean_dec(x_3); -x_120 = lean_ctor_get(x_84, 1); -lean_inc(x_120); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_121 = x_84; -} else { - lean_dec_ref(x_84); - x_121 = lean_box(0); -} -x_122 = lean_ctor_get(x_120, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_120, 1); -lean_inc(x_123); -x_124 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_124, 0, x_122); -lean_ctor_set(x_124, 1, x_123); -lean_ctor_set(x_124, 2, x_9); -x_125 = lean_alloc_ctor(6, 2, 0); -lean_ctor_set(x_125, 0, x_2); -lean_ctor_set(x_125, 1, x_124); -if (lean_is_scalar(x_121)) { - x_126 = lean_alloc_ctor(1, 2, 0); -} else { - x_126 = x_121; - lean_ctor_set_tag(x_126, 1); -} -lean_ctor_set(x_126, 0, x_125); -lean_ctor_set(x_126, 1, x_120); -return x_126; -} -} -} -else -{ -lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; -lean_dec(x_9); -lean_dec(x_3); -lean_dec(x_2); -x_127 = lean_ctor_get(x_84, 0); -lean_inc(x_127); -x_128 = lean_ctor_get(x_84, 1); -lean_inc(x_128); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_129 = x_84; -} else { - lean_dec_ref(x_84); - x_129 = lean_box(0); -} -if (lean_is_scalar(x_129)) { - x_130 = lean_alloc_ctor(1, 2, 0); -} else { - x_130 = x_129; -} -lean_ctor_set(x_130, 0, x_127); -lean_ctor_set(x_130, 1, x_128); -return x_130; -} -} -} -else -{ -uint8_t x_131; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_131 = !lean_is_exclusive(x_5); -if (x_131 == 0) -{ -return x_5; -} -else -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; -x_132 = lean_ctor_get(x_5, 0); -x_133 = lean_ctor_get(x_5, 1); -lean_inc(x_133); -lean_inc(x_132); -lean_dec(x_5); -x_134 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_134, 0, x_132); -lean_ctor_set(x_134, 1, x_133); -return x_134; -} -} -} -} -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_nat_dec_eq(x_4, x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_sub(x_4, x_11); -lean_dec(x_4); -x_13 = lean_array_fget(x_3, x_12); -lean_inc(x_7); -lean_inc(x_1); -x_14 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_13, x_7, x_8); -if (lean_obj_tag(x_14) == 0) -{ -lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -lean_inc(x_7); -lean_inc(x_1); -x_17 = l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__17(x_1, x_15, x_7, x_16); -if (lean_obj_tag(x_17) == 0) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -x_19 = lean_ctor_get(x_17, 1); -lean_inc(x_19); -lean_dec(x_17); -x_20 = l_Lean_mkLevelIMax(x_18, x_6); -x_4 = x_12; -x_5 = lean_box(0); -x_6 = x_20; -x_8 = x_19; -goto _start; -} -else -{ -uint8_t x_22; -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_1); -x_22 = !lean_is_exclusive(x_17); -if (x_22 == 0) -{ -return x_17; -} -else -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_23 = lean_ctor_get(x_17, 0); -x_24 = lean_ctor_get(x_17, 1); -lean_inc(x_24); -lean_inc(x_23); -lean_dec(x_17); -x_25 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_25, 0, x_23); -lean_ctor_set(x_25, 1, x_24); -return x_25; -} -} -} -else -{ -uint8_t x_26; -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_1); -x_26 = !lean_is_exclusive(x_14); -if (x_26 == 0) -{ -return x_14; -} -else -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_27 = lean_ctor_get(x_14, 0); -x_28 = lean_ctor_get(x_14, 1); -lean_inc(x_28); -lean_inc(x_27); -lean_dec(x_14); -x_29 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_29, 0, x_27); -lean_ctor_set(x_29, 1, x_28); -return x_29; -} -} -} -else -{ -lean_object* x_30; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_1); -x_30 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_30, 0, x_6); -lean_ctor_set(x_30, 1, x_8); -return x_30; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__23(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_9 = l_Lean_Expr_getAppFn___main(x_2); -if (lean_obj_tag(x_9) == 4) -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -lean_dec(x_9); -x_11 = lean_ctor_get(x_6, 0); -lean_inc(x_11); -lean_inc(x_10); -x_12 = lean_is_class(x_11, x_10); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; -lean_dec(x_10); -x_13 = lean_box(0); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_6); -return x_14; -} -else -{ -lean_object* x_15; lean_object* x_16; -x_15 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_15, 0, x_10); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_6); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; -lean_dec(x_9); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_6); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; -x_19 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_5, x_6); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_20, 1); -lean_inc(x_22); -lean_dec(x_20); -x_23 = l_Lean_LocalDecl_type(x_21); -lean_dec(x_21); -lean_inc(x_5); -lean_inc(x_23); -x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_5, x_22); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -switch (lean_obj_tag(x_25)) { -case 0: -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_dec(x_23); -lean_dec(x_19); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_4, x_27); -lean_dec(x_4); -x_4 = x_28; -x_6 = x_26; -goto _start; -} -case 1: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 1); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_4, x_32); -lean_dec(x_4); -x_34 = !lean_is_exclusive(x_5); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_5, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_31); -lean_ctor_set(x_36, 1, x_19); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_5, 2, x_37); -x_4 = x_33; -x_6 = x_30; -goto _start; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_5, 0); -x_40 = lean_ctor_get(x_5, 1); -x_41 = lean_ctor_get(x_5, 2); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_5); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_31); -lean_ctor_set(x_42, 1, x_19); -x_43 = lean_array_push(x_41, x_42); -x_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_43); -x_4 = x_33; -x_5 = x_44; -x_6 = x_30; -goto _start; -} -} -default: -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_24, 1); -lean_inc(x_46); -lean_dec(x_24); -lean_inc(x_5); -lean_inc(x_1); -x_47 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(x_1, x_23, x_5, x_46); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_19); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -x_50 = lean_unsigned_to_nat(1u); -x_51 = lean_nat_add(x_4, x_50); -lean_dec(x_4); -x_4 = x_51; -x_6 = x_49; -goto _start; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; -x_53 = lean_ctor_get(x_47, 1); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_ctor_get(x_48, 0); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_unsigned_to_nat(1u); -x_56 = lean_nat_add(x_4, x_55); -lean_dec(x_4); -x_57 = !lean_is_exclusive(x_5); -if (x_57 == 0) -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_5, 2); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_54); -lean_ctor_set(x_59, 1, x_19); -x_60 = lean_array_push(x_58, x_59); -lean_ctor_set(x_5, 2, x_60); -x_4 = x_56; -x_6 = x_53; -goto _start; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_62 = lean_ctor_get(x_5, 0); -x_63 = lean_ctor_get(x_5, 1); -x_64 = lean_ctor_get(x_5, 2); -lean_inc(x_64); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_5); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_54); -lean_ctor_set(x_65, 1, x_19); -x_66 = lean_array_push(x_64, x_65); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_63); -lean_ctor_set(x_67, 2, x_66); -x_4 = x_56; -x_5 = x_67; -x_6 = x_53; -goto _start; -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_69 = !lean_is_exclusive(x_47); -if (x_69 == 0) -{ -return x_47; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_47, 0); -x_71 = lean_ctor_get(x_47, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_47); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_73 = !lean_is_exclusive(x_24); -if (x_73 == 0) -{ -return x_24; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_24, 0); -x_75 = lean_ctor_get(x_24, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_24); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_77 = !lean_is_exclusive(x_20); -if (x_77 == 0) -{ -return x_20; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_20, 0); -x_79 = lean_ctor_get(x_20, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_20); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___lambda__1(lean_object* x_1, lean_object* x_2, uint8_t x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -uint8_t x_11; -x_11 = l_Lean_Expr_isForall(x_8); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_2); -x_12 = l_Lean_Expr_getAppFn___main(x_1); -if (lean_obj_tag(x_12) == 4) -{ -lean_object* x_13; lean_object* x_14; uint8_t x_15; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -lean_dec(x_12); -x_14 = lean_ctor_get(x_10, 0); -lean_inc(x_14); -lean_inc(x_13); -x_15 = lean_is_class(x_14, x_13); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; -lean_dec(x_13); -x_16 = lean_box(0); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_16); -lean_ctor_set(x_17, 1, x_10); -return x_17; -} -else -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_18, 0, x_13); -x_19 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_19, 0, x_18); -lean_ctor_set(x_19, 1, x_10); -return x_19; -} -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_12); -x_20 = lean_box(0); -x_21 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_21, 0, x_20); -lean_ctor_set(x_21, 1, x_10); -return x_21; -} -} -else -{ -lean_object* x_22; -x_22 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22(x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -return x_22; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { -_start: -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -lean_inc(x_9); -lean_inc(x_1); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_1); -lean_closure_set(x_14, 1, x_9); -x_15 = lean_box(x_2); -lean_inc(x_8); -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_1); -lean_inc(x_9); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___lambda__1___boxed), 10, 7); -lean_closure_set(x_16, 0, x_9); -lean_closure_set(x_16, 1, x_1); -lean_closure_set(x_16, 2, x_15); -lean_closure_set(x_16, 3, x_3); -lean_closure_set(x_16, 4, x_4); -lean_closure_set(x_16, 5, x_5); -lean_closure_set(x_16, 6, x_8); -x_17 = lean_array_get_size(x_10); -x_18 = lean_nat_dec_lt(x_11, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_12, x_13); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_10, x_11); -lean_inc(x_12); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_12, x_13); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_12); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_12, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_11, x_28); -lean_dec(x_11); -x_11 = x_29; -x_13 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_11, x_33); -lean_dec(x_11); -x_35 = !lean_is_exclusive(x_12); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_12, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_12, 2, x_38); -x_11 = x_34; -x_13 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_12, 0); -x_41 = lean_ctor_get(x_12, 1); -x_42 = lean_ctor_get(x_12, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_12); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_11 = x_34; -x_12 = x_45; -x_13 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_12); -lean_inc(x_1); -x_48 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(x_1, x_24, x_12, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_11, x_51); -lean_dec(x_11); -x_11 = x_52; -x_13 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_11, x_56); -lean_dec(x_11); -x_58 = !lean_is_exclusive(x_12); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_12, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_12, 2, x_61); -x_11 = x_57; -x_13 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_12, 0); -x_64 = lean_ctor_get(x_12, 1); -x_65 = lean_ctor_get(x_12, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_12); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_11 = x_57; -x_12 = x_68; -x_13 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__25(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_array_get_size(x_3); -x_8 = lean_nat_dec_lt(x_4, x_7); -lean_dec(x_7); -if (x_8 == 0) -{ -lean_object* x_9; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_9 = l_Lean_Expr_getAppFn___main(x_2); -if (lean_obj_tag(x_9) == 4) -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_10 = lean_ctor_get(x_9, 0); -lean_inc(x_10); -lean_dec(x_9); -x_11 = lean_ctor_get(x_6, 0); -lean_inc(x_11); -lean_inc(x_10); -x_12 = lean_is_class(x_11, x_10); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; -lean_dec(x_10); -x_13 = lean_box(0); -x_14 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_14, 0, x_13); -lean_ctor_set(x_14, 1, x_6); -return x_14; -} -else -{ -lean_object* x_15; lean_object* x_16; -x_15 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_15, 0, x_10); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_6); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; -lean_dec(x_9); -x_17 = lean_box(0); -x_18 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_18, 0, x_17); -lean_ctor_set(x_18, 1, x_6); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; -x_19 = lean_array_fget(x_3, x_4); -lean_inc(x_5); -x_20 = l_Lean_Meta_getFVarLocalDecl(x_19, x_5, x_6); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_ctor_get(x_20, 1); -lean_inc(x_22); -lean_dec(x_20); -x_23 = l_Lean_LocalDecl_type(x_21); -lean_dec(x_21); -lean_inc(x_5); -lean_inc(x_23); -x_24 = l_Lean_Meta_isClassQuick___main(x_23, x_5, x_22); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; -x_25 = lean_ctor_get(x_24, 0); -lean_inc(x_25); -switch (lean_obj_tag(x_25)) { -case 0: -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_dec(x_23); -lean_dec(x_19); -x_26 = lean_ctor_get(x_24, 1); -lean_inc(x_26); -lean_dec(x_24); -x_27 = lean_unsigned_to_nat(1u); -x_28 = lean_nat_add(x_4, x_27); -lean_dec(x_4); -x_4 = x_28; -x_6 = x_26; -goto _start; -} -case 1: -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; -lean_dec(x_23); -x_30 = lean_ctor_get(x_24, 1); -lean_inc(x_30); -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 0); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_unsigned_to_nat(1u); -x_33 = lean_nat_add(x_4, x_32); -lean_dec(x_4); -x_34 = !lean_is_exclusive(x_5); -if (x_34 == 0) -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_5, 2); -x_36 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_36, 0, x_31); -lean_ctor_set(x_36, 1, x_19); -x_37 = lean_array_push(x_35, x_36); -lean_ctor_set(x_5, 2, x_37); -x_4 = x_33; -x_6 = x_30; -goto _start; -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; -x_39 = lean_ctor_get(x_5, 0); -x_40 = lean_ctor_get(x_5, 1); -x_41 = lean_ctor_get(x_5, 2); -lean_inc(x_41); -lean_inc(x_40); -lean_inc(x_39); -lean_dec(x_5); -x_42 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_42, 0, x_31); -lean_ctor_set(x_42, 1, x_19); -x_43 = lean_array_push(x_41, x_42); -x_44 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_44, 0, x_39); -lean_ctor_set(x_44, 1, x_40); -lean_ctor_set(x_44, 2, x_43); -x_4 = x_33; -x_5 = x_44; -x_6 = x_30; -goto _start; -} -} -default: -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_24, 1); -lean_inc(x_46); -lean_dec(x_24); -lean_inc(x_5); -lean_inc(x_1); -x_47 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(x_1, x_23, x_5, x_46); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; -x_48 = lean_ctor_get(x_47, 0); -lean_inc(x_48); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_19); -x_49 = lean_ctor_get(x_47, 1); -lean_inc(x_49); -lean_dec(x_47); -x_50 = lean_unsigned_to_nat(1u); -x_51 = lean_nat_add(x_4, x_50); -lean_dec(x_4); -x_4 = x_51; -x_6 = x_49; -goto _start; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; uint8_t x_57; -x_53 = lean_ctor_get(x_47, 1); -lean_inc(x_53); -lean_dec(x_47); -x_54 = lean_ctor_get(x_48, 0); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_unsigned_to_nat(1u); -x_56 = lean_nat_add(x_4, x_55); -lean_dec(x_4); -x_57 = !lean_is_exclusive(x_5); -if (x_57 == 0) -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_5, 2); -x_59 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_59, 0, x_54); -lean_ctor_set(x_59, 1, x_19); -x_60 = lean_array_push(x_58, x_59); -lean_ctor_set(x_5, 2, x_60); -x_4 = x_56; -x_6 = x_53; -goto _start; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_62 = lean_ctor_get(x_5, 0); -x_63 = lean_ctor_get(x_5, 1); -x_64 = lean_ctor_get(x_5, 2); -lean_inc(x_64); -lean_inc(x_63); -lean_inc(x_62); -lean_dec(x_5); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_54); -lean_ctor_set(x_65, 1, x_19); -x_66 = lean_array_push(x_64, x_65); -x_67 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_67, 0, x_62); -lean_ctor_set(x_67, 1, x_63); -lean_ctor_set(x_67, 2, x_66); -x_4 = x_56; -x_5 = x_67; -x_6 = x_53; -goto _start; -} -} -} -else -{ -uint8_t x_69; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_69 = !lean_is_exclusive(x_47); -if (x_69 == 0) -{ -return x_47; -} -else -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = lean_ctor_get(x_47, 0); -x_71 = lean_ctor_get(x_47, 1); -lean_inc(x_71); -lean_inc(x_70); -lean_dec(x_47); -x_72 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -return x_72; -} -} -} -} -} -else -{ -uint8_t x_73; -lean_dec(x_23); -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_73 = !lean_is_exclusive(x_24); -if (x_73 == 0) -{ -return x_24; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_24, 0); -x_75 = lean_ctor_get(x_24, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_24); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -else -{ -uint8_t x_77; -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_77 = !lean_is_exclusive(x_20); -if (x_77 == 0) -{ -return x_20; -} -else -{ -lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_78 = lean_ctor_get(x_20, 0); -x_79 = lean_ctor_get(x_20, 1); -lean_inc(x_79); -lean_inc(x_78); -lean_dec(x_20); -x_80 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_80, 0, x_78); -lean_ctor_set(x_80, 1, x_79); -return x_80; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -if (lean_obj_tag(x_7) == 7) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; uint64_t x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_23 = lean_ctor_get(x_7, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_7, 1); -lean_inc(x_24); -x_25 = lean_ctor_get(x_7, 2); -lean_inc(x_25); -x_26 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); -lean_dec(x_7); -x_27 = lean_array_get_size(x_5); -lean_inc(x_5); -x_28 = lean_expr_instantiate_rev_range(x_24, x_6, x_27, x_5); -lean_dec(x_27); -lean_dec(x_24); -x_29 = l_Lean_Meta_mkFreshId___rarg(x_9); -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_29, 1); -lean_inc(x_31); -lean_dec(x_29); -x_32 = (uint8_t)((x_26 << 24) >> 61); -lean_inc(x_30); -x_33 = lean_local_ctx_mk_local_decl(x_4, x_30, x_23, x_28, x_32); -x_34 = l_Lean_mkFVar(x_30); -x_35 = lean_array_push(x_5, x_34); -if (lean_obj_tag(x_3) == 0) -{ -x_4 = x_33; -x_5 = x_35; -x_7 = x_25; -x_9 = x_31; -goto _start; -} -else -{ -lean_object* x_37; lean_object* x_38; uint8_t x_39; -x_37 = lean_ctor_get(x_3, 0); -lean_inc(x_37); -x_38 = lean_array_get_size(x_35); -x_39 = lean_nat_dec_lt(x_38, x_37); -lean_dec(x_37); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; -lean_dec(x_3); -lean_inc(x_35); -x_40 = lean_expr_instantiate_rev_range(x_25, x_6, x_38, x_35); -lean_dec(x_38); -lean_dec(x_25); -x_41 = !lean_is_exclusive(x_8); -if (x_41 == 0) -{ -lean_object* x_42; lean_object* x_43; -x_42 = lean_ctor_get(x_8, 1); -lean_dec(x_42); -lean_ctor_set(x_8, 1, x_33); -x_43 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__25(x_1, x_40, x_35, x_6, x_8, x_31); -lean_dec(x_35); -lean_dec(x_40); -return x_43; -} -else -{ -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_44 = lean_ctor_get(x_8, 0); -x_45 = lean_ctor_get(x_8, 2); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_8); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_33); -lean_ctor_set(x_46, 2, x_45); -x_47 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__25(x_1, x_40, x_35, x_6, x_46, x_31); -lean_dec(x_35); -lean_dec(x_40); -return x_47; -} -} -else -{ -lean_dec(x_38); -x_4 = x_33; -x_5 = x_35; -x_7 = x_25; -x_9 = x_31; -goto _start; -} -} -} -else -{ -lean_object* x_49; -x_49 = lean_box(0); -x_10 = x_49; -goto block_22; -} -block_22: -{ -lean_object* x_11; lean_object* x_12; uint8_t x_13; -lean_dec(x_10); -x_11 = lean_array_get_size(x_5); -lean_inc(x_5); -x_12 = lean_expr_instantiate_rev_range(x_7, x_6, x_11, x_5); -x_13 = !lean_is_exclusive(x_8); -if (x_13 == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_8, 1); -lean_dec(x_14); -lean_inc(x_4); -lean_ctor_set(x_8, 1, x_4); -if (x_2 == 0) -{ -lean_object* x_15; -lean_dec(x_11); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__23(x_1, x_12, x_5, x_6, x_8, x_9); -lean_dec(x_5); -lean_dec(x_12); -return x_15; -} -else -{ -lean_object* x_16; -lean_inc(x_6); -lean_inc(x_5); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_8, x_9); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_8, 0); -x_18 = lean_ctor_get(x_8, 2); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_8); -lean_inc(x_4); -x_19 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_4); -lean_ctor_set(x_19, 2, x_18); -if (x_2 == 0) -{ -lean_object* x_20; -lean_dec(x_11); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__23(x_1, x_12, x_5, x_6, x_19, x_9); -lean_dec(x_5); -lean_dec(x_12); -return x_20; -} -else -{ -lean_object* x_21; -lean_inc(x_6); -lean_inc(x_5); -x_21 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_19, x_9); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -return x_21; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__21(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_9; -x_6 = lean_ctor_get(x_4, 0); -lean_inc(x_6); -x_7 = lean_ctor_get(x_4, 1); -lean_inc(x_7); -x_8 = lean_ctor_get(x_4, 2); -lean_inc(x_8); -x_9 = !lean_is_exclusive(x_6); -if (x_9 == 0) -{ -uint8_t x_10; lean_object* x_11; lean_object* x_12; -x_10 = 1; -lean_ctor_set_uint8(x_6, sizeof(void*)*1 + 4, x_10); -lean_inc(x_7); -x_11 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_11, 0, x_6); -lean_ctor_set(x_11, 1, x_7); -lean_ctor_set(x_11, 2, x_8); -lean_inc(x_1); -lean_inc(x_2); -x_12 = lean_apply_3(x_1, x_2, x_11, x_5); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; uint8_t x_16; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_ctor_get(x_12, 1); -x_16 = l_Lean_Expr_isForall(x_14); -if (x_16 == 0) -{ -lean_object* x_17; -lean_dec(x_14); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_17 = l_Lean_Expr_getAppFn___main(x_2); -lean_dec(x_2); -if (lean_obj_tag(x_17) == 4) -{ -lean_object* x_18; lean_object* x_19; uint8_t x_20; -x_18 = lean_ctor_get(x_17, 0); -lean_inc(x_18); -lean_dec(x_17); -x_19 = lean_ctor_get(x_15, 0); -lean_inc(x_19); -lean_inc(x_18); -x_20 = lean_is_class(x_19, x_18); -if (x_20 == 0) -{ -lean_object* x_21; -lean_dec(x_18); -x_21 = lean_box(0); -lean_ctor_set(x_12, 0, x_21); -return x_12; -} -else -{ -lean_object* x_22; -x_22 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_22, 0, x_18); -lean_ctor_set(x_12, 0, x_22); -return x_12; -} -} -else -{ -lean_object* x_23; -lean_dec(x_17); -x_23 = lean_box(0); -lean_ctor_set(x_12, 0, x_23); -return x_12; -} -} -else -{ -lean_object* x_24; uint8_t x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; -lean_free_object(x_12); -lean_dec(x_2); -x_24 = lean_ctor_get(x_15, 2); -lean_inc(x_24); -x_25 = 1; -x_26 = l_Array_empty___closed__1; -x_27 = lean_unsigned_to_nat(0u); -x_28 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22(x_1, x_25, x_3, x_7, x_26, x_27, x_14, x_4, x_15); -if (lean_obj_tag(x_28) == 0) -{ -uint8_t x_29; -x_29 = !lean_is_exclusive(x_28); -if (x_29 == 0) -{ -lean_object* x_30; uint8_t x_31; -x_30 = lean_ctor_get(x_28, 1); -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) -{ -lean_object* x_32; -x_32 = lean_ctor_get(x_30, 2); -lean_dec(x_32); -lean_ctor_set(x_30, 2, x_24); -return x_28; -} -else -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_33 = lean_ctor_get(x_30, 0); -x_34 = lean_ctor_get(x_30, 1); -x_35 = lean_ctor_get(x_30, 3); -x_36 = lean_ctor_get(x_30, 4); -x_37 = lean_ctor_get(x_30, 5); -lean_inc(x_37); -lean_inc(x_36); -lean_inc(x_35); -lean_inc(x_34); -lean_inc(x_33); -lean_dec(x_30); -x_38 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_38, 0, x_33); -lean_ctor_set(x_38, 1, x_34); -lean_ctor_set(x_38, 2, x_24); -lean_ctor_set(x_38, 3, x_35); -lean_ctor_set(x_38, 4, x_36); -lean_ctor_set(x_38, 5, x_37); -lean_ctor_set(x_28, 1, x_38); -return x_28; -} -} -else -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_39 = lean_ctor_get(x_28, 1); -x_40 = lean_ctor_get(x_28, 0); -lean_inc(x_39); -lean_inc(x_40); -lean_dec(x_28); -x_41 = lean_ctor_get(x_39, 0); -lean_inc(x_41); -x_42 = lean_ctor_get(x_39, 1); -lean_inc(x_42); -x_43 = lean_ctor_get(x_39, 3); -lean_inc(x_43); -x_44 = lean_ctor_get(x_39, 4); -lean_inc(x_44); -x_45 = lean_ctor_get(x_39, 5); -lean_inc(x_45); -if (lean_is_exclusive(x_39)) { - lean_ctor_release(x_39, 0); - lean_ctor_release(x_39, 1); - lean_ctor_release(x_39, 2); - lean_ctor_release(x_39, 3); - lean_ctor_release(x_39, 4); - lean_ctor_release(x_39, 5); - x_46 = x_39; -} else { - lean_dec_ref(x_39); - x_46 = lean_box(0); -} -if (lean_is_scalar(x_46)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_46; -} -lean_ctor_set(x_47, 0, x_41); -lean_ctor_set(x_47, 1, x_42); -lean_ctor_set(x_47, 2, x_24); -lean_ctor_set(x_47, 3, x_43); -lean_ctor_set(x_47, 4, x_44); -lean_ctor_set(x_47, 5, x_45); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_40); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -else -{ -uint8_t x_49; -x_49 = !lean_is_exclusive(x_28); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; -x_50 = lean_ctor_get(x_28, 1); -x_51 = !lean_is_exclusive(x_50); -if (x_51 == 0) -{ -lean_object* x_52; -x_52 = lean_ctor_get(x_50, 2); -lean_dec(x_52); -lean_ctor_set(x_50, 2, x_24); -return x_28; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_53 = lean_ctor_get(x_50, 0); -x_54 = lean_ctor_get(x_50, 1); -x_55 = lean_ctor_get(x_50, 3); -x_56 = lean_ctor_get(x_50, 4); -x_57 = lean_ctor_get(x_50, 5); -lean_inc(x_57); -lean_inc(x_56); -lean_inc(x_55); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_50); -x_58 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_58, 0, x_53); -lean_ctor_set(x_58, 1, x_54); -lean_ctor_set(x_58, 2, x_24); -lean_ctor_set(x_58, 3, x_55); -lean_ctor_set(x_58, 4, x_56); -lean_ctor_set(x_58, 5, x_57); -lean_ctor_set(x_28, 1, x_58); -return x_28; -} -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_59 = lean_ctor_get(x_28, 1); -x_60 = lean_ctor_get(x_28, 0); -lean_inc(x_59); -lean_inc(x_60); -lean_dec(x_28); -x_61 = lean_ctor_get(x_59, 0); -lean_inc(x_61); -x_62 = lean_ctor_get(x_59, 1); -lean_inc(x_62); -x_63 = lean_ctor_get(x_59, 3); -lean_inc(x_63); -x_64 = lean_ctor_get(x_59, 4); -lean_inc(x_64); -x_65 = lean_ctor_get(x_59, 5); -lean_inc(x_65); -if (lean_is_exclusive(x_59)) { - lean_ctor_release(x_59, 0); - lean_ctor_release(x_59, 1); - lean_ctor_release(x_59, 2); - lean_ctor_release(x_59, 3); - lean_ctor_release(x_59, 4); - lean_ctor_release(x_59, 5); - x_66 = x_59; -} else { - lean_dec_ref(x_59); - x_66 = lean_box(0); -} -if (lean_is_scalar(x_66)) { - x_67 = lean_alloc_ctor(0, 6, 0); -} else { - x_67 = x_66; -} -lean_ctor_set(x_67, 0, x_61); -lean_ctor_set(x_67, 1, x_62); -lean_ctor_set(x_67, 2, x_24); -lean_ctor_set(x_67, 3, x_63); -lean_ctor_set(x_67, 4, x_64); -lean_ctor_set(x_67, 5, x_65); -x_68 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_68, 0, x_60); -lean_ctor_set(x_68, 1, x_67); -return x_68; -} -} -} -} -else -{ -lean_object* x_69; lean_object* x_70; uint8_t x_71; -x_69 = lean_ctor_get(x_12, 0); -x_70 = lean_ctor_get(x_12, 1); -lean_inc(x_70); -lean_inc(x_69); -lean_dec(x_12); -x_71 = l_Lean_Expr_isForall(x_69); -if (x_71 == 0) -{ -lean_object* x_72; -lean_dec(x_69); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_72 = l_Lean_Expr_getAppFn___main(x_2); -lean_dec(x_2); -if (lean_obj_tag(x_72) == 4) -{ -lean_object* x_73; lean_object* x_74; uint8_t x_75; -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -lean_dec(x_72); -x_74 = lean_ctor_get(x_70, 0); -lean_inc(x_74); -lean_inc(x_73); -x_75 = lean_is_class(x_74, x_73); -if (x_75 == 0) -{ -lean_object* x_76; lean_object* x_77; -lean_dec(x_73); -x_76 = lean_box(0); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_70); -return x_77; -} -else -{ -lean_object* x_78; lean_object* x_79; -x_78 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_78, 0, x_73); -x_79 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_70); -return x_79; -} -} -else -{ -lean_object* x_80; lean_object* x_81; -lean_dec(x_72); -x_80 = lean_box(0); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_70); -return x_81; -} -} -else -{ -lean_object* x_82; uint8_t x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_2); -x_82 = lean_ctor_get(x_70, 2); -lean_inc(x_82); -x_83 = 1; -x_84 = l_Array_empty___closed__1; -x_85 = lean_unsigned_to_nat(0u); -x_86 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22(x_1, x_83, x_3, x_7, x_84, x_85, x_69, x_4, x_70); -if (lean_obj_tag(x_86) == 0) -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; -x_87 = lean_ctor_get(x_86, 1); -lean_inc(x_87); -x_88 = lean_ctor_get(x_86, 0); -lean_inc(x_88); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_89 = x_86; -} else { - lean_dec_ref(x_86); - x_89 = lean_box(0); -} -x_90 = lean_ctor_get(x_87, 0); -lean_inc(x_90); -x_91 = lean_ctor_get(x_87, 1); -lean_inc(x_91); -x_92 = lean_ctor_get(x_87, 3); -lean_inc(x_92); -x_93 = lean_ctor_get(x_87, 4); -lean_inc(x_93); -x_94 = lean_ctor_get(x_87, 5); -lean_inc(x_94); -if (lean_is_exclusive(x_87)) { - lean_ctor_release(x_87, 0); - lean_ctor_release(x_87, 1); - lean_ctor_release(x_87, 2); - lean_ctor_release(x_87, 3); - lean_ctor_release(x_87, 4); - lean_ctor_release(x_87, 5); - x_95 = x_87; -} else { - lean_dec_ref(x_87); - x_95 = lean_box(0); -} -if (lean_is_scalar(x_95)) { - x_96 = lean_alloc_ctor(0, 6, 0); -} else { - x_96 = x_95; -} -lean_ctor_set(x_96, 0, x_90); -lean_ctor_set(x_96, 1, x_91); -lean_ctor_set(x_96, 2, x_82); -lean_ctor_set(x_96, 3, x_92); -lean_ctor_set(x_96, 4, x_93); -lean_ctor_set(x_96, 5, x_94); -if (lean_is_scalar(x_89)) { - x_97 = lean_alloc_ctor(0, 2, 0); -} else { - x_97 = x_89; -} -lean_ctor_set(x_97, 0, x_88); -lean_ctor_set(x_97, 1, x_96); -return x_97; -} -else -{ -lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; -x_98 = lean_ctor_get(x_86, 1); -lean_inc(x_98); -x_99 = lean_ctor_get(x_86, 0); -lean_inc(x_99); -if (lean_is_exclusive(x_86)) { - lean_ctor_release(x_86, 0); - lean_ctor_release(x_86, 1); - x_100 = x_86; -} else { - lean_dec_ref(x_86); - x_100 = lean_box(0); -} -x_101 = lean_ctor_get(x_98, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_98, 1); -lean_inc(x_102); -x_103 = lean_ctor_get(x_98, 3); -lean_inc(x_103); -x_104 = lean_ctor_get(x_98, 4); -lean_inc(x_104); -x_105 = lean_ctor_get(x_98, 5); -lean_inc(x_105); -if (lean_is_exclusive(x_98)) { - lean_ctor_release(x_98, 0); - lean_ctor_release(x_98, 1); - lean_ctor_release(x_98, 2); - lean_ctor_release(x_98, 3); - lean_ctor_release(x_98, 4); - lean_ctor_release(x_98, 5); - x_106 = x_98; -} else { - lean_dec_ref(x_98); - x_106 = lean_box(0); -} -if (lean_is_scalar(x_106)) { - x_107 = lean_alloc_ctor(0, 6, 0); -} else { - x_107 = x_106; -} -lean_ctor_set(x_107, 0, x_101); -lean_ctor_set(x_107, 1, x_102); -lean_ctor_set(x_107, 2, x_82); -lean_ctor_set(x_107, 3, x_103); -lean_ctor_set(x_107, 4, x_104); -lean_ctor_set(x_107, 5, x_105); -if (lean_is_scalar(x_100)) { - x_108 = lean_alloc_ctor(1, 2, 0); -} else { - x_108 = x_100; -} -lean_ctor_set(x_108, 0, x_99); -lean_ctor_set(x_108, 1, x_107); -return x_108; -} -} -} -} -else -{ -uint8_t x_109; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_109 = !lean_is_exclusive(x_12); -if (x_109 == 0) -{ -return x_12; -} -else -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -x_110 = lean_ctor_get(x_12, 0); -x_111 = lean_ctor_get(x_12, 1); -lean_inc(x_111); -lean_inc(x_110); -lean_dec(x_12); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_110); -lean_ctor_set(x_112, 1, x_111); -return x_112; -} -} -} -else -{ -lean_object* x_113; uint8_t x_114; uint8_t x_115; uint8_t x_116; uint8_t x_117; uint8_t x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_113 = lean_ctor_get(x_6, 0); -x_114 = lean_ctor_get_uint8(x_6, sizeof(void*)*1); -x_115 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 1); -x_116 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 2); -x_117 = lean_ctor_get_uint8(x_6, sizeof(void*)*1 + 3); -lean_inc(x_113); -lean_dec(x_6); -x_118 = 1; -x_119 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_119, 0, x_113); -lean_ctor_set_uint8(x_119, sizeof(void*)*1, x_114); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 1, x_115); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 2, x_116); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 3, x_117); -lean_ctor_set_uint8(x_119, sizeof(void*)*1 + 4, x_118); -lean_inc(x_7); -x_120 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_120, 0, x_119); -lean_ctor_set(x_120, 1, x_7); -lean_ctor_set(x_120, 2, x_8); -lean_inc(x_1); -lean_inc(x_2); -x_121 = lean_apply_3(x_1, x_2, x_120, x_5); -if (lean_obj_tag(x_121) == 0) -{ -lean_object* x_122; lean_object* x_123; lean_object* x_124; uint8_t x_125; -x_122 = lean_ctor_get(x_121, 0); -lean_inc(x_122); -x_123 = lean_ctor_get(x_121, 1); -lean_inc(x_123); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_124 = x_121; -} else { - lean_dec_ref(x_121); - x_124 = lean_box(0); -} -x_125 = l_Lean_Expr_isForall(x_122); -if (x_125 == 0) -{ -lean_object* x_126; -lean_dec(x_122); -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_126 = l_Lean_Expr_getAppFn___main(x_2); -lean_dec(x_2); -if (lean_obj_tag(x_126) == 4) -{ -lean_object* x_127; lean_object* x_128; uint8_t x_129; -x_127 = lean_ctor_get(x_126, 0); -lean_inc(x_127); -lean_dec(x_126); -x_128 = lean_ctor_get(x_123, 0); -lean_inc(x_128); -lean_inc(x_127); -x_129 = lean_is_class(x_128, x_127); -if (x_129 == 0) -{ -lean_object* x_130; lean_object* x_131; -lean_dec(x_127); -x_130 = lean_box(0); -if (lean_is_scalar(x_124)) { - x_131 = lean_alloc_ctor(0, 2, 0); -} else { - x_131 = x_124; -} -lean_ctor_set(x_131, 0, x_130); -lean_ctor_set(x_131, 1, x_123); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; -x_132 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_132, 0, x_127); -if (lean_is_scalar(x_124)) { - x_133 = lean_alloc_ctor(0, 2, 0); -} else { - x_133 = x_124; -} -lean_ctor_set(x_133, 0, x_132); -lean_ctor_set(x_133, 1, x_123); -return x_133; -} -} -else -{ -lean_object* x_134; lean_object* x_135; -lean_dec(x_126); -x_134 = lean_box(0); -if (lean_is_scalar(x_124)) { - x_135 = lean_alloc_ctor(0, 2, 0); -} else { - x_135 = x_124; -} -lean_ctor_set(x_135, 0, x_134); -lean_ctor_set(x_135, 1, x_123); -return x_135; -} -} -else -{ -lean_object* x_136; uint8_t x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; -lean_dec(x_124); -lean_dec(x_2); -x_136 = lean_ctor_get(x_123, 2); -lean_inc(x_136); -x_137 = 1; -x_138 = l_Array_empty___closed__1; -x_139 = lean_unsigned_to_nat(0u); -x_140 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22(x_1, x_137, x_3, x_7, x_138, x_139, x_122, x_4, x_123); -if (lean_obj_tag(x_140) == 0) -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -x_141 = lean_ctor_get(x_140, 1); -lean_inc(x_141); -x_142 = lean_ctor_get(x_140, 0); -lean_inc(x_142); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - x_143 = x_140; -} else { - lean_dec_ref(x_140); - x_143 = lean_box(0); -} -x_144 = lean_ctor_get(x_141, 0); -lean_inc(x_144); -x_145 = lean_ctor_get(x_141, 1); -lean_inc(x_145); -x_146 = lean_ctor_get(x_141, 3); -lean_inc(x_146); -x_147 = lean_ctor_get(x_141, 4); -lean_inc(x_147); -x_148 = lean_ctor_get(x_141, 5); -lean_inc(x_148); -if (lean_is_exclusive(x_141)) { - lean_ctor_release(x_141, 0); - lean_ctor_release(x_141, 1); - lean_ctor_release(x_141, 2); - lean_ctor_release(x_141, 3); - lean_ctor_release(x_141, 4); - lean_ctor_release(x_141, 5); - x_149 = x_141; -} else { - lean_dec_ref(x_141); - x_149 = lean_box(0); -} -if (lean_is_scalar(x_149)) { - x_150 = lean_alloc_ctor(0, 6, 0); -} else { - x_150 = x_149; -} -lean_ctor_set(x_150, 0, x_144); -lean_ctor_set(x_150, 1, x_145); -lean_ctor_set(x_150, 2, x_136); -lean_ctor_set(x_150, 3, x_146); -lean_ctor_set(x_150, 4, x_147); -lean_ctor_set(x_150, 5, x_148); -if (lean_is_scalar(x_143)) { - x_151 = lean_alloc_ctor(0, 2, 0); -} else { - x_151 = x_143; -} -lean_ctor_set(x_151, 0, x_142); -lean_ctor_set(x_151, 1, x_150); -return x_151; -} -else -{ -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; -x_152 = lean_ctor_get(x_140, 1); -lean_inc(x_152); -x_153 = lean_ctor_get(x_140, 0); -lean_inc(x_153); -if (lean_is_exclusive(x_140)) { - lean_ctor_release(x_140, 0); - lean_ctor_release(x_140, 1); - x_154 = x_140; -} else { - lean_dec_ref(x_140); - x_154 = lean_box(0); -} -x_155 = lean_ctor_get(x_152, 0); -lean_inc(x_155); -x_156 = lean_ctor_get(x_152, 1); -lean_inc(x_156); -x_157 = lean_ctor_get(x_152, 3); -lean_inc(x_157); -x_158 = lean_ctor_get(x_152, 4); -lean_inc(x_158); -x_159 = lean_ctor_get(x_152, 5); -lean_inc(x_159); -if (lean_is_exclusive(x_152)) { - lean_ctor_release(x_152, 0); - lean_ctor_release(x_152, 1); - lean_ctor_release(x_152, 2); - lean_ctor_release(x_152, 3); - lean_ctor_release(x_152, 4); - lean_ctor_release(x_152, 5); - x_160 = x_152; -} else { - lean_dec_ref(x_152); - x_160 = lean_box(0); -} -if (lean_is_scalar(x_160)) { - x_161 = lean_alloc_ctor(0, 6, 0); -} else { - x_161 = x_160; -} -lean_ctor_set(x_161, 0, x_155); -lean_ctor_set(x_161, 1, x_156); -lean_ctor_set(x_161, 2, x_136); -lean_ctor_set(x_161, 3, x_157); -lean_ctor_set(x_161, 4, x_158); -lean_ctor_set(x_161, 5, x_159); -if (lean_is_scalar(x_154)) { - x_162 = lean_alloc_ctor(1, 2, 0); -} else { - x_162 = x_154; -} -lean_ctor_set(x_162, 0, x_153); -lean_ctor_set(x_162, 1, x_161); -return x_162; -} -} -} -else -{ -lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_163 = lean_ctor_get(x_121, 0); -lean_inc(x_163); -x_164 = lean_ctor_get(x_121, 1); -lean_inc(x_164); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - lean_ctor_release(x_121, 1); - x_165 = x_121; -} else { - lean_dec_ref(x_121); - x_165 = lean_box(0); -} -if (lean_is_scalar(x_165)) { - x_166 = lean_alloc_ctor(1, 2, 0); -} else { - x_166 = x_165; -} -lean_ctor_set(x_166, 0, x_163); -lean_ctor_set(x_166, 1, x_164); -return x_166; -} -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; uint8_t x_6; -x_5 = lean_box(0); -x_6 = !lean_is_exclusive(x_3); -if (x_6 == 0) -{ -lean_object* x_7; uint8_t x_8; -x_7 = lean_ctor_get(x_3, 0); -x_8 = !lean_is_exclusive(x_7); -if (x_8 == 0) -{ -uint8_t x_9; lean_object* x_10; -x_9 = 2; -lean_ctor_set_uint8(x_7, sizeof(void*)*1 + 4, x_9); -x_10 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__21(x_1, x_2, x_5, x_3, x_4); -return x_10; -} -else -{ -lean_object* x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; uint8_t x_16; lean_object* x_17; lean_object* x_18; -x_11 = lean_ctor_get(x_7, 0); -x_12 = lean_ctor_get_uint8(x_7, sizeof(void*)*1); -x_13 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 1); -x_14 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 2); -x_15 = lean_ctor_get_uint8(x_7, sizeof(void*)*1 + 3); -lean_inc(x_11); -lean_dec(x_7); -x_16 = 2; -x_17 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_17, 0, x_11); -lean_ctor_set_uint8(x_17, sizeof(void*)*1, x_12); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 1, x_13); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 2, x_14); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 3, x_15); -lean_ctor_set_uint8(x_17, sizeof(void*)*1 + 4, x_16); -lean_ctor_set(x_3, 0, x_17); -x_18 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__21(x_1, x_2, x_5, x_3, x_4); -return x_18; -} -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_19 = lean_ctor_get(x_3, 0); -x_20 = lean_ctor_get(x_3, 1); -x_21 = lean_ctor_get(x_3, 2); -lean_inc(x_21); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_3); -x_22 = lean_ctor_get(x_19, 0); -lean_inc(x_22); -x_23 = lean_ctor_get_uint8(x_19, sizeof(void*)*1); -x_24 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 1); -x_25 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 2); -x_26 = lean_ctor_get_uint8(x_19, sizeof(void*)*1 + 3); -if (lean_is_exclusive(x_19)) { - lean_ctor_release(x_19, 0); - x_27 = x_19; -} else { - lean_dec_ref(x_19); - x_27 = lean_box(0); -} -x_28 = 2; -if (lean_is_scalar(x_27)) { - x_29 = lean_alloc_ctor(0, 1, 5); -} else { - x_29 = x_27; -} -lean_ctor_set(x_29, 0, x_22); -lean_ctor_set_uint8(x_29, sizeof(void*)*1, x_23); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 1, x_24); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 2, x_25); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 3, x_26); -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_28); -x_30 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_30, 0, x_29); -lean_ctor_set(x_30, 1, x_20); -lean_ctor_set(x_30, 2, x_21); -x_31 = l___private_Init_Lean_Meta_Basic_6__forallTelescopeReducingAux___at_Lean_Meta_inferTypeAux___spec__21(x_1, x_2, x_5, x_30, x_4); -return x_31; -} -} -} -lean_object* l_Lean_Meta_isClassExpensive___at_Lean_Meta_inferTypeAux___spec__19(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -x_5 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(x_1, x_2, x_3, x_4); -return x_5; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__27(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_array_get_size(x_5); -x_10 = lean_nat_dec_lt(x_6, x_9); -lean_dec(x_9); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_6); -lean_inc(x_7); -lean_inc(x_1); -x_11 = l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__16(x_1, x_4, x_7, x_8); -if (lean_obj_tag(x_11) == 0) -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -x_13 = lean_ctor_get(x_11, 1); -lean_inc(x_13); -lean_dec(x_11); -x_14 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18(x_1, x_2, x_2, x_3, lean_box(0), x_12, x_7, x_13); -if (lean_obj_tag(x_14) == 0) -{ -uint8_t x_15; -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 0); -x_17 = l_Lean_Level_normalize___main(x_16); -lean_dec(x_16); -x_18 = l_Lean_mkSort(x_17); -lean_ctor_set(x_14, 0, x_18); -return x_14; -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_19 = lean_ctor_get(x_14, 0); -x_20 = lean_ctor_get(x_14, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_14); -x_21 = l_Lean_Level_normalize___main(x_19); -lean_dec(x_19); -x_22 = l_Lean_mkSort(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_20); -return x_23; -} -} -else -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_14); -if (x_24 == 0) -{ -return x_14; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_14, 0); -x_26 = lean_ctor_get(x_14, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_14); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -uint8_t x_28; -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_1); -x_28 = !lean_is_exclusive(x_11); -if (x_28 == 0) -{ -return x_11; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_11, 0); -x_30 = lean_ctor_get(x_11, 1); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_11); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -} -else -{ -lean_object* x_32; lean_object* x_33; -x_32 = lean_array_fget(x_5, x_6); -lean_inc(x_7); -x_33 = l_Lean_Meta_getFVarLocalDecl(x_32, x_7, x_8); -if (lean_obj_tag(x_33) == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_34 = lean_ctor_get(x_33, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_33, 1); -lean_inc(x_35); -lean_dec(x_33); -x_36 = l_Lean_LocalDecl_type(x_34); -lean_dec(x_34); -lean_inc(x_7); -lean_inc(x_36); -x_37 = l_Lean_Meta_isClassQuick___main(x_36, x_7, x_35); -if (lean_obj_tag(x_37) == 0) -{ -lean_object* x_38; -x_38 = lean_ctor_get(x_37, 0); -lean_inc(x_38); -switch (lean_obj_tag(x_38)) { -case 0: -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; -lean_dec(x_36); -lean_dec(x_32); -x_39 = lean_ctor_get(x_37, 1); -lean_inc(x_39); -lean_dec(x_37); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_add(x_6, x_40); -lean_dec(x_6); -x_6 = x_41; -x_8 = x_39; -goto _start; -} -case 1: -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; uint8_t x_47; -lean_dec(x_36); -x_43 = lean_ctor_get(x_37, 1); -lean_inc(x_43); -lean_dec(x_37); -x_44 = lean_ctor_get(x_38, 0); -lean_inc(x_44); -lean_dec(x_38); -x_45 = lean_unsigned_to_nat(1u); -x_46 = lean_nat_add(x_6, x_45); -lean_dec(x_6); -x_47 = !lean_is_exclusive(x_7); -if (x_47 == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_48 = lean_ctor_get(x_7, 2); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_44); -lean_ctor_set(x_49, 1, x_32); -x_50 = lean_array_push(x_48, x_49); -lean_ctor_set(x_7, 2, x_50); -x_6 = x_46; -x_8 = x_43; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_52 = lean_ctor_get(x_7, 0); -x_53 = lean_ctor_get(x_7, 1); -x_54 = lean_ctor_get(x_7, 2); -lean_inc(x_54); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_7); -x_55 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_55, 0, x_44); -lean_ctor_set(x_55, 1, x_32); -x_56 = lean_array_push(x_54, x_55); -x_57 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_57, 0, x_52); -lean_ctor_set(x_57, 1, x_53); -lean_ctor_set(x_57, 2, x_56); -x_6 = x_46; -x_7 = x_57; -x_8 = x_43; -goto _start; -} -} -default: -{ -lean_object* x_59; lean_object* x_60; -x_59 = lean_ctor_get(x_37, 1); -lean_inc(x_59); -lean_dec(x_37); -lean_inc(x_7); -lean_inc(x_1); -x_60 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(x_1, x_36, x_7, x_59); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; -x_61 = lean_ctor_get(x_60, 0); -lean_inc(x_61); -if (lean_obj_tag(x_61) == 0) -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -lean_dec(x_32); -x_62 = lean_ctor_get(x_60, 1); -lean_inc(x_62); -lean_dec(x_60); -x_63 = lean_unsigned_to_nat(1u); -x_64 = lean_nat_add(x_6, x_63); -lean_dec(x_6); -x_6 = x_64; -x_8 = x_62; -goto _start; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_66 = lean_ctor_get(x_60, 1); -lean_inc(x_66); -lean_dec(x_60); -x_67 = lean_ctor_get(x_61, 0); -lean_inc(x_67); -lean_dec(x_61); -x_68 = lean_unsigned_to_nat(1u); -x_69 = lean_nat_add(x_6, x_68); -lean_dec(x_6); -x_70 = !lean_is_exclusive(x_7); -if (x_70 == 0) -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_7, 2); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_32); -x_73 = lean_array_push(x_71, x_72); -lean_ctor_set(x_7, 2, x_73); -x_6 = x_69; -x_8 = x_66; -goto _start; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_75 = lean_ctor_get(x_7, 0); -x_76 = lean_ctor_get(x_7, 1); -x_77 = lean_ctor_get(x_7, 2); -lean_inc(x_77); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_7); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_67); -lean_ctor_set(x_78, 1, x_32); -x_79 = lean_array_push(x_77, x_78); -x_80 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_80, 0, x_75); -lean_ctor_set(x_80, 1, x_76); -lean_ctor_set(x_80, 2, x_79); -x_6 = x_69; -x_7 = x_80; -x_8 = x_66; -goto _start; -} -} -} -else -{ -uint8_t x_82; -lean_dec(x_32); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_82 = !lean_is_exclusive(x_60); -if (x_82 == 0) -{ -return x_60; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_60, 0); -x_84 = lean_ctor_get(x_60, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_60); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; -} -} -} -} -} -else -{ -uint8_t x_86; -lean_dec(x_36); -lean_dec(x_32); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_86 = !lean_is_exclusive(x_37); -if (x_86 == 0) -{ -return x_37; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_37, 0); -x_88 = lean_ctor_get(x_37, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_37); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} -} -} -else -{ -uint8_t x_90; -lean_dec(x_32); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_90 = !lean_is_exclusive(x_33); -if (x_90 == 0) -{ -return x_33; -} -else -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_33, 0); -x_92 = lean_ctor_get(x_33, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_33); -x_93 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -return x_93; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, uint8_t x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -uint8_t x_11; -x_11 = l_Lean_Expr_isForall(x_8); -if (x_11 == 0) -{ -lean_object* x_12; -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_inc(x_9); -lean_inc(x_1); -x_12 = l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__16(x_1, x_2, x_9, x_10); -if (lean_obj_tag(x_12) == 0) -{ -lean_object* x_13; lean_object* x_14; lean_object* x_15; -x_13 = lean_ctor_get(x_12, 0); -lean_inc(x_13); -x_14 = lean_ctor_get(x_12, 1); -lean_inc(x_14); -lean_dec(x_12); -x_15 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18(x_1, x_3, x_3, x_4, lean_box(0), x_13, x_9, x_14); -lean_dec(x_3); -if (lean_obj_tag(x_15) == 0) -{ -uint8_t x_16; -x_16 = !lean_is_exclusive(x_15); -if (x_16 == 0) -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_15, 0); -x_18 = l_Lean_Level_normalize___main(x_17); -lean_dec(x_17); -x_19 = l_Lean_mkSort(x_18); -lean_ctor_set(x_15, 0, x_19); -return x_15; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; -x_20 = lean_ctor_get(x_15, 0); -x_21 = lean_ctor_get(x_15, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_15); -x_22 = l_Lean_Level_normalize___main(x_20); -lean_dec(x_20); -x_23 = l_Lean_mkSort(x_22); -x_24 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_24, 0, x_23); -lean_ctor_set(x_24, 1, x_21); -return x_24; -} -} -else -{ -uint8_t x_25; -x_25 = !lean_is_exclusive(x_15); -if (x_25 == 0) -{ -return x_15; -} -else -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -x_26 = lean_ctor_get(x_15, 0); -x_27 = lean_ctor_get(x_15, 1); -lean_inc(x_27); -lean_inc(x_26); -lean_dec(x_15); -x_28 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_28, 0, x_26); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -} -else -{ -uint8_t x_29; -lean_dec(x_9); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_29 = !lean_is_exclusive(x_12); -if (x_29 == 0) -{ -return x_12; -} -else -{ -lean_object* x_30; lean_object* x_31; lean_object* x_32; -x_30 = lean_ctor_get(x_12, 0); -x_31 = lean_ctor_get(x_12, 1); -lean_inc(x_31); -lean_inc(x_30); -lean_dec(x_12); -x_32 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_32, 0, x_30); -lean_ctor_set(x_32, 1, x_31); -return x_32; -} -} -} -else -{ -lean_object* x_33; -lean_dec(x_2); -x_33 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__26(x_1, x_5, x_6, x_7, x_3, x_4, x_8, x_9, x_10); -return x_33; -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { -_start: -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; uint8_t x_18; -lean_inc(x_9); -lean_inc(x_1); -x_14 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 2); -lean_closure_set(x_14, 0, x_1); -lean_closure_set(x_14, 1, x_9); -x_15 = lean_box(x_2); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_8); -lean_inc(x_5); -lean_inc(x_9); -lean_inc(x_1); -x_16 = lean_alloc_closure((void*)(l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___lambda__1___boxed), 10, 7); -lean_closure_set(x_16, 0, x_1); -lean_closure_set(x_16, 1, x_9); -lean_closure_set(x_16, 2, x_5); -lean_closure_set(x_16, 3, x_8); -lean_closure_set(x_16, 4, x_15); -lean_closure_set(x_16, 5, x_3); -lean_closure_set(x_16, 6, x_4); -x_17 = lean_array_get_size(x_10); -x_18 = lean_nat_dec_lt(x_11, x_17); -lean_dec(x_17); -if (x_18 == 0) -{ -lean_object* x_19; -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_19 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_14, x_16, x_12, x_13); -return x_19; -} -else -{ -lean_object* x_20; lean_object* x_21; -lean_dec(x_16); -lean_dec(x_14); -x_20 = lean_array_fget(x_10, x_11); -lean_inc(x_12); -x_21 = l_Lean_Meta_getFVarLocalDecl(x_20, x_12, x_13); -if (lean_obj_tag(x_21) == 0) -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_22 = lean_ctor_get(x_21, 0); -lean_inc(x_22); -x_23 = lean_ctor_get(x_21, 1); -lean_inc(x_23); -lean_dec(x_21); -x_24 = l_Lean_LocalDecl_type(x_22); -lean_dec(x_22); -lean_inc(x_12); -lean_inc(x_24); -x_25 = l_Lean_Meta_isClassQuick___main(x_24, x_12, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_25, 0); -lean_inc(x_26); -switch (lean_obj_tag(x_26)) { -case 0: -{ -lean_object* x_27; lean_object* x_28; lean_object* x_29; -lean_dec(x_24); -lean_dec(x_20); -x_27 = lean_ctor_get(x_25, 1); -lean_inc(x_27); -lean_dec(x_25); -x_28 = lean_unsigned_to_nat(1u); -x_29 = lean_nat_add(x_11, x_28); -lean_dec(x_11); -x_11 = x_29; -x_13 = x_27; -goto _start; -} -case 1: -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; -lean_dec(x_24); -x_31 = lean_ctor_get(x_25, 1); -lean_inc(x_31); -lean_dec(x_25); -x_32 = lean_ctor_get(x_26, 0); -lean_inc(x_32); -lean_dec(x_26); -x_33 = lean_unsigned_to_nat(1u); -x_34 = lean_nat_add(x_11, x_33); -lean_dec(x_11); -x_35 = !lean_is_exclusive(x_12); -if (x_35 == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; -x_36 = lean_ctor_get(x_12, 2); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_32); -lean_ctor_set(x_37, 1, x_20); -x_38 = lean_array_push(x_36, x_37); -lean_ctor_set(x_12, 2, x_38); -x_11 = x_34; -x_13 = x_31; -goto _start; -} -else -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_40 = lean_ctor_get(x_12, 0); -x_41 = lean_ctor_get(x_12, 1); -x_42 = lean_ctor_get(x_12, 2); -lean_inc(x_42); -lean_inc(x_41); -lean_inc(x_40); -lean_dec(x_12); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_20); -x_44 = lean_array_push(x_42, x_43); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_40); -lean_ctor_set(x_45, 1, x_41); -lean_ctor_set(x_45, 2, x_44); -x_11 = x_34; -x_12 = x_45; -x_13 = x_31; -goto _start; -} -} -default: -{ -lean_object* x_47; lean_object* x_48; -x_47 = lean_ctor_get(x_25, 1); -lean_inc(x_47); -lean_dec(x_25); -lean_inc(x_12); -lean_inc(x_1); -x_48 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(x_1, x_24, x_12, x_47); -if (lean_obj_tag(x_48) == 0) -{ -lean_object* x_49; -x_49 = lean_ctor_get(x_48, 0); -lean_inc(x_49); -if (lean_obj_tag(x_49) == 0) -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -lean_dec(x_20); -x_50 = lean_ctor_get(x_48, 1); -lean_inc(x_50); -lean_dec(x_48); -x_51 = lean_unsigned_to_nat(1u); -x_52 = lean_nat_add(x_11, x_51); -lean_dec(x_11); -x_11 = x_52; -x_13 = x_50; -goto _start; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; uint8_t x_58; -x_54 = lean_ctor_get(x_48, 1); -lean_inc(x_54); -lean_dec(x_48); -x_55 = lean_ctor_get(x_49, 0); -lean_inc(x_55); -lean_dec(x_49); -x_56 = lean_unsigned_to_nat(1u); -x_57 = lean_nat_add(x_11, x_56); -lean_dec(x_11); -x_58 = !lean_is_exclusive(x_12); -if (x_58 == 0) -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_12, 2); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_55); -lean_ctor_set(x_60, 1, x_20); -x_61 = lean_array_push(x_59, x_60); -lean_ctor_set(x_12, 2, x_61); -x_11 = x_57; -x_13 = x_54; -goto _start; -} -else -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; -x_63 = lean_ctor_get(x_12, 0); -x_64 = lean_ctor_get(x_12, 1); -x_65 = lean_ctor_get(x_12, 2); -lean_inc(x_65); -lean_inc(x_64); -lean_inc(x_63); -lean_dec(x_12); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_55); -lean_ctor_set(x_66, 1, x_20); -x_67 = lean_array_push(x_65, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_63); -lean_ctor_set(x_68, 1, x_64); -lean_ctor_set(x_68, 2, x_67); -x_11 = x_57; -x_12 = x_68; -x_13 = x_54; -goto _start; -} -} -} -else -{ -uint8_t x_70; -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_70 = !lean_is_exclusive(x_48); -if (x_70 == 0) -{ -return x_48; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_48, 0); -x_72 = lean_ctor_get(x_48, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_48); -x_73 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_73, 0, x_71); -lean_ctor_set(x_73, 1, x_72); -return x_73; -} -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_24); -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_74 = !lean_is_exclusive(x_25); -if (x_74 == 0) -{ -return x_25; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_25, 0); -x_76 = lean_ctor_get(x_25, 1); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_25); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_20); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_78 = !lean_is_exclusive(x_21); -if (x_78 == 0) -{ -return x_21; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_21, 0); -x_80 = lean_ctor_get(x_21, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_21); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__29(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_array_get_size(x_5); -x_10 = lean_nat_dec_lt(x_6, x_9); -lean_dec(x_9); -if (x_10 == 0) -{ -lean_object* x_11; -lean_dec(x_6); -lean_inc(x_7); -lean_inc(x_1); -x_11 = l_Lean_Meta_getLevelAux___at_Lean_Meta_inferTypeAux___spec__16(x_1, x_4, x_7, x_8); -if (lean_obj_tag(x_11) == 0) -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -x_13 = lean_ctor_get(x_11, 1); -lean_inc(x_13); -lean_dec(x_11); -x_14 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18(x_1, x_2, x_2, x_3, lean_box(0), x_12, x_7, x_13); -if (lean_obj_tag(x_14) == 0) -{ -uint8_t x_15; -x_15 = !lean_is_exclusive(x_14); -if (x_15 == 0) -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_16 = lean_ctor_get(x_14, 0); -x_17 = l_Lean_Level_normalize___main(x_16); -lean_dec(x_16); -x_18 = l_Lean_mkSort(x_17); -lean_ctor_set(x_14, 0, x_18); -return x_14; -} -else -{ -lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_19 = lean_ctor_get(x_14, 0); -x_20 = lean_ctor_get(x_14, 1); -lean_inc(x_20); -lean_inc(x_19); -lean_dec(x_14); -x_21 = l_Lean_Level_normalize___main(x_19); -lean_dec(x_19); -x_22 = l_Lean_mkSort(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_20); -return x_23; -} -} -else -{ -uint8_t x_24; -x_24 = !lean_is_exclusive(x_14); -if (x_24 == 0) -{ -return x_14; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_14, 0); -x_26 = lean_ctor_get(x_14, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_14); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -uint8_t x_28; -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_1); -x_28 = !lean_is_exclusive(x_11); -if (x_28 == 0) -{ -return x_11; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_11, 0); -x_30 = lean_ctor_get(x_11, 1); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_11); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -} -else -{ -lean_object* x_32; lean_object* x_33; -x_32 = lean_array_fget(x_5, x_6); -lean_inc(x_7); -x_33 = l_Lean_Meta_getFVarLocalDecl(x_32, x_7, x_8); -if (lean_obj_tag(x_33) == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_34 = lean_ctor_get(x_33, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_33, 1); -lean_inc(x_35); -lean_dec(x_33); -x_36 = l_Lean_LocalDecl_type(x_34); -lean_dec(x_34); -lean_inc(x_7); -lean_inc(x_36); -x_37 = l_Lean_Meta_isClassQuick___main(x_36, x_7, x_35); -if (lean_obj_tag(x_37) == 0) -{ -lean_object* x_38; -x_38 = lean_ctor_get(x_37, 0); -lean_inc(x_38); -switch (lean_obj_tag(x_38)) { -case 0: -{ -lean_object* x_39; lean_object* x_40; lean_object* x_41; -lean_dec(x_36); -lean_dec(x_32); -x_39 = lean_ctor_get(x_37, 1); -lean_inc(x_39); -lean_dec(x_37); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_add(x_6, x_40); -lean_dec(x_6); -x_6 = x_41; -x_8 = x_39; -goto _start; -} -case 1: -{ -lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; uint8_t x_47; -lean_dec(x_36); -x_43 = lean_ctor_get(x_37, 1); -lean_inc(x_43); -lean_dec(x_37); -x_44 = lean_ctor_get(x_38, 0); -lean_inc(x_44); -lean_dec(x_38); -x_45 = lean_unsigned_to_nat(1u); -x_46 = lean_nat_add(x_6, x_45); -lean_dec(x_6); -x_47 = !lean_is_exclusive(x_7); -if (x_47 == 0) -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_48 = lean_ctor_get(x_7, 2); -x_49 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_49, 0, x_44); -lean_ctor_set(x_49, 1, x_32); -x_50 = lean_array_push(x_48, x_49); -lean_ctor_set(x_7, 2, x_50); -x_6 = x_46; -x_8 = x_43; -goto _start; -} -else -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_52 = lean_ctor_get(x_7, 0); -x_53 = lean_ctor_get(x_7, 1); -x_54 = lean_ctor_get(x_7, 2); -lean_inc(x_54); -lean_inc(x_53); -lean_inc(x_52); -lean_dec(x_7); -x_55 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_55, 0, x_44); -lean_ctor_set(x_55, 1, x_32); -x_56 = lean_array_push(x_54, x_55); -x_57 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_57, 0, x_52); -lean_ctor_set(x_57, 1, x_53); -lean_ctor_set(x_57, 2, x_56); -x_6 = x_46; -x_7 = x_57; -x_8 = x_43; -goto _start; -} -} -default: -{ -lean_object* x_59; lean_object* x_60; -x_59 = lean_ctor_get(x_37, 1); -lean_inc(x_59); -lean_dec(x_37); -lean_inc(x_7); -lean_inc(x_1); -x_60 = l_Lean_Meta_isClassExpensive___main___at_Lean_Meta_inferTypeAux___spec__20(x_1, x_36, x_7, x_59); -if (lean_obj_tag(x_60) == 0) -{ -lean_object* x_61; -x_61 = lean_ctor_get(x_60, 0); -lean_inc(x_61); -if (lean_obj_tag(x_61) == 0) -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -lean_dec(x_32); -x_62 = lean_ctor_get(x_60, 1); -lean_inc(x_62); -lean_dec(x_60); -x_63 = lean_unsigned_to_nat(1u); -x_64 = lean_nat_add(x_6, x_63); -lean_dec(x_6); -x_6 = x_64; -x_8 = x_62; -goto _start; -} -else -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; uint8_t x_70; -x_66 = lean_ctor_get(x_60, 1); -lean_inc(x_66); -lean_dec(x_60); -x_67 = lean_ctor_get(x_61, 0); -lean_inc(x_67); -lean_dec(x_61); -x_68 = lean_unsigned_to_nat(1u); -x_69 = lean_nat_add(x_6, x_68); -lean_dec(x_6); -x_70 = !lean_is_exclusive(x_7); -if (x_70 == 0) -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_7, 2); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_67); -lean_ctor_set(x_72, 1, x_32); -x_73 = lean_array_push(x_71, x_72); -lean_ctor_set(x_7, 2, x_73); -x_6 = x_69; -x_8 = x_66; -goto _start; -} -else -{ -lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; -x_75 = lean_ctor_get(x_7, 0); -x_76 = lean_ctor_get(x_7, 1); -x_77 = lean_ctor_get(x_7, 2); -lean_inc(x_77); -lean_inc(x_76); -lean_inc(x_75); -lean_dec(x_7); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_67); -lean_ctor_set(x_78, 1, x_32); -x_79 = lean_array_push(x_77, x_78); -x_80 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_80, 0, x_75); -lean_ctor_set(x_80, 1, x_76); -lean_ctor_set(x_80, 2, x_79); -x_6 = x_69; -x_7 = x_80; -x_8 = x_66; -goto _start; -} -} -} -else -{ -uint8_t x_82; -lean_dec(x_32); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_82 = !lean_is_exclusive(x_60); -if (x_82 == 0) -{ -return x_60; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_60, 0); -x_84 = lean_ctor_get(x_60, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_60); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; -} -} -} -} -} -else -{ -uint8_t x_86; -lean_dec(x_36); -lean_dec(x_32); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_86 = !lean_is_exclusive(x_37); -if (x_86 == 0) -{ -return x_37; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_37, 0); -x_88 = lean_ctor_get(x_37, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_37); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} -} -} -else -{ -uint8_t x_90; -lean_dec(x_32); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_1); -x_90 = !lean_is_exclusive(x_33); -if (x_90 == 0) -{ -return x_33; -} -else -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; -x_91 = lean_ctor_get(x_33, 0); -x_92 = lean_ctor_get(x_33, 1); -lean_inc(x_92); -lean_inc(x_91); -lean_dec(x_33); -x_93 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_93, 0, x_91); -lean_ctor_set(x_93, 1, x_92); -return x_93; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__26(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -if (lean_obj_tag(x_7) == 7) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; uint64_t x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; -x_23 = lean_ctor_get(x_7, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_7, 1); -lean_inc(x_24); -x_25 = lean_ctor_get(x_7, 2); -lean_inc(x_25); -x_26 = lean_ctor_get_uint64(x_7, sizeof(void*)*3); -lean_dec(x_7); -x_27 = lean_array_get_size(x_5); -lean_inc(x_5); -x_28 = lean_expr_instantiate_rev_range(x_24, x_6, x_27, x_5); -lean_dec(x_27); -lean_dec(x_24); -x_29 = l_Lean_Meta_mkFreshId___rarg(x_9); -x_30 = lean_ctor_get(x_29, 0); -lean_inc(x_30); -x_31 = lean_ctor_get(x_29, 1); -lean_inc(x_31); -lean_dec(x_29); -x_32 = (uint8_t)((x_26 << 24) >> 61); -lean_inc(x_30); -x_33 = lean_local_ctx_mk_local_decl(x_4, x_30, x_23, x_28, x_32); -x_34 = l_Lean_mkFVar(x_30); -x_35 = lean_array_push(x_5, x_34); -if (lean_obj_tag(x_3) == 0) -{ -x_4 = x_33; -x_5 = x_35; -x_7 = x_25; -x_9 = x_31; -goto _start; -} -else -{ -lean_object* x_37; lean_object* x_38; uint8_t x_39; -x_37 = lean_ctor_get(x_3, 0); -lean_inc(x_37); -x_38 = lean_array_get_size(x_35); -x_39 = lean_nat_dec_lt(x_38, x_37); -lean_dec(x_37); -if (x_39 == 0) -{ -lean_object* x_40; uint8_t x_41; -lean_dec(x_3); -lean_inc(x_35); -x_40 = lean_expr_instantiate_rev_range(x_25, x_6, x_38, x_35); -lean_dec(x_25); -x_41 = !lean_is_exclusive(x_8); -if (x_41 == 0) -{ -lean_object* x_42; lean_object* x_43; -x_42 = lean_ctor_get(x_8, 1); -lean_dec(x_42); -lean_ctor_set(x_8, 1, x_33); -x_43 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__29(x_1, x_35, x_38, x_40, x_35, x_6, x_8, x_31); -lean_dec(x_35); -return x_43; -} -else -{ -lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_44 = lean_ctor_get(x_8, 0); -x_45 = lean_ctor_get(x_8, 2); -lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_8); -x_46 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_46, 0, x_44); -lean_ctor_set(x_46, 1, x_33); -lean_ctor_set(x_46, 2, x_45); -x_47 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__29(x_1, x_35, x_38, x_40, x_35, x_6, x_46, x_31); -lean_dec(x_35); -return x_47; -} -} -else -{ -lean_dec(x_38); -x_4 = x_33; -x_5 = x_35; -x_7 = x_25; -x_9 = x_31; -goto _start; -} -} -} -else -{ -lean_object* x_49; -x_49 = lean_box(0); -x_10 = x_49; -goto block_22; -} -block_22: -{ -lean_object* x_11; lean_object* x_12; uint8_t x_13; -lean_dec(x_10); -x_11 = lean_array_get_size(x_5); -lean_inc(x_5); -x_12 = lean_expr_instantiate_rev_range(x_7, x_6, x_11, x_5); -x_13 = !lean_is_exclusive(x_8); -if (x_13 == 0) -{ -lean_object* x_14; -x_14 = lean_ctor_get(x_8, 1); -lean_dec(x_14); -lean_inc(x_4); -lean_ctor_set(x_8, 1, x_4); -if (x_2 == 0) -{ -lean_object* x_15; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__27(x_1, x_5, x_11, x_12, x_5, x_6, x_8, x_9); -lean_dec(x_5); -return x_15; -} -else -{ -lean_object* x_16; -lean_inc(x_6); -lean_inc(x_5); -x_16 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_8, x_9); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -return x_16; -} -} -else -{ -lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_8, 0); -x_18 = lean_ctor_get(x_8, 2); -lean_inc(x_18); -lean_inc(x_17); -lean_dec(x_8); -lean_inc(x_4); -x_19 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_19, 0, x_17); -lean_ctor_set(x_19, 1, x_4); -lean_ctor_set(x_19, 2, x_18); -if (x_2 == 0) -{ -lean_object* x_20; -lean_dec(x_7); -lean_dec(x_4); -lean_dec(x_3); -x_20 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__27(x_1, x_5, x_11, x_12, x_5, x_6, x_19, x_9); -lean_dec(x_5); -return x_20; -} -else -{ -lean_object* x_21; -lean_inc(x_6); -lean_inc(x_5); -x_21 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_11, x_12, x_5, x_6, x_19, x_9); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -return x_21; -} -} -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_4__inferForallType___at_Lean_Meta_inferTypeAux___spec__15(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; -x_5 = lean_ctor_get(x_4, 2); -lean_inc(x_5); -x_6 = lean_ctor_get(x_3, 1); -lean_inc(x_6); -x_7 = lean_box(0); -x_8 = 0; -x_9 = l_Array_empty___closed__1; -x_10 = lean_unsigned_to_nat(0u); -x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__26(x_1, x_8, x_7, x_6, x_9, x_10, x_2, x_3, x_4); -if (lean_obj_tag(x_11) == 0) -{ -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; uint8_t x_14; -x_13 = lean_ctor_get(x_11, 1); -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_13, 2); -lean_dec(x_15); -lean_ctor_set(x_13, 2, x_5); -return x_11; -} -else -{ -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; -x_16 = lean_ctor_get(x_13, 0); -x_17 = lean_ctor_get(x_13, 1); -x_18 = lean_ctor_get(x_13, 3); -x_19 = lean_ctor_get(x_13, 4); -x_20 = lean_ctor_get(x_13, 5); -lean_inc(x_20); -lean_inc(x_19); -lean_inc(x_18); -lean_inc(x_17); -lean_inc(x_16); -lean_dec(x_13); -x_21 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_21, 0, x_16); -lean_ctor_set(x_21, 1, x_17); -lean_ctor_set(x_21, 2, x_5); -lean_ctor_set(x_21, 3, x_18); -lean_ctor_set(x_21, 4, x_19); -lean_ctor_set(x_21, 5, x_20); -lean_ctor_set(x_11, 1, x_21); -return x_11; -} -} -else -{ -lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_22 = lean_ctor_get(x_11, 1); -x_23 = lean_ctor_get(x_11, 0); -lean_inc(x_22); -lean_inc(x_23); -lean_dec(x_11); -x_24 = lean_ctor_get(x_22, 0); -lean_inc(x_24); -x_25 = lean_ctor_get(x_22, 1); -lean_inc(x_25); -x_26 = lean_ctor_get(x_22, 3); -lean_inc(x_26); -x_27 = lean_ctor_get(x_22, 4); -lean_inc(x_27); -x_28 = lean_ctor_get(x_22, 5); -lean_inc(x_28); -if (lean_is_exclusive(x_22)) { - lean_ctor_release(x_22, 0); - lean_ctor_release(x_22, 1); - lean_ctor_release(x_22, 2); - lean_ctor_release(x_22, 3); - lean_ctor_release(x_22, 4); - lean_ctor_release(x_22, 5); - x_29 = x_22; -} else { - lean_dec_ref(x_22); - x_29 = lean_box(0); -} -if (lean_is_scalar(x_29)) { - x_30 = lean_alloc_ctor(0, 6, 0); -} else { - x_30 = x_29; -} -lean_ctor_set(x_30, 0, x_24); -lean_ctor_set(x_30, 1, x_25); -lean_ctor_set(x_30, 2, x_5); -lean_ctor_set(x_30, 3, x_26); -lean_ctor_set(x_30, 4, x_27); -lean_ctor_set(x_30, 5, x_28); -x_31 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_31, 0, x_23); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -else -{ -uint8_t x_32; -x_32 = !lean_is_exclusive(x_11); -if (x_32 == 0) -{ -lean_object* x_33; uint8_t x_34; -x_33 = lean_ctor_get(x_11, 1); -x_34 = !lean_is_exclusive(x_33); -if (x_34 == 0) -{ -lean_object* x_35; -x_35 = lean_ctor_get(x_33, 2); -lean_dec(x_35); -lean_ctor_set(x_33, 2, x_5); -return x_11; -} -else -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; -x_36 = lean_ctor_get(x_33, 0); -x_37 = lean_ctor_get(x_33, 1); -x_38 = lean_ctor_get(x_33, 3); -x_39 = lean_ctor_get(x_33, 4); -x_40 = lean_ctor_get(x_33, 5); -lean_inc(x_40); -lean_inc(x_39); -lean_inc(x_38); -lean_inc(x_37); -lean_inc(x_36); -lean_dec(x_33); -x_41 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_41, 0, x_36); -lean_ctor_set(x_41, 1, x_37); -lean_ctor_set(x_41, 2, x_5); -lean_ctor_set(x_41, 3, x_38); -lean_ctor_set(x_41, 4, x_39); -lean_ctor_set(x_41, 5, x_40); -lean_ctor_set(x_11, 1, x_41); -return x_11; -} -} -else -{ -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_42 = lean_ctor_get(x_11, 1); -x_43 = lean_ctor_get(x_11, 0); -lean_inc(x_42); -lean_inc(x_43); -lean_dec(x_11); -x_44 = lean_ctor_get(x_42, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_42, 1); -lean_inc(x_45); -x_46 = lean_ctor_get(x_42, 3); -lean_inc(x_46); -x_47 = lean_ctor_get(x_42, 4); -lean_inc(x_47); -x_48 = lean_ctor_get(x_42, 5); -lean_inc(x_48); -if (lean_is_exclusive(x_42)) { - lean_ctor_release(x_42, 0); - lean_ctor_release(x_42, 1); - lean_ctor_release(x_42, 2); - lean_ctor_release(x_42, 3); - lean_ctor_release(x_42, 4); - lean_ctor_release(x_42, 5); - x_49 = x_42; -} else { - lean_dec_ref(x_42); - x_49 = lean_box(0); -} -if (lean_is_scalar(x_49)) { - x_50 = lean_alloc_ctor(0, 6, 0); -} else { - x_50 = x_49; -} -lean_ctor_set(x_50, 0, x_44); -lean_ctor_set(x_50, 1, x_45); -lean_ctor_set(x_50, 2, x_5); -lean_ctor_set(x_50, 3, x_46); -lean_ctor_set(x_50, 4, x_47); -lean_ctor_set(x_50, 5, x_48); -x_51 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_51, 0, x_43); -lean_ctor_set(x_51, 1, x_50); -return x_51; -} -} -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__32(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; uint8_t x_10; -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_nat_dec_eq(x_5, x_9); -if (x_10 == 0) -{ -lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_11 = lean_unsigned_to_nat(1u); -x_12 = lean_nat_sub(x_5, x_11); -lean_dec(x_5); -x_22 = lean_nat_sub(x_4, x_12); -x_23 = lean_nat_sub(x_22, x_11); -lean_dec(x_22); -x_24 = lean_ctor_get(x_6, 0); -lean_inc(x_24); -x_25 = lean_ctor_get(x_6, 1); -lean_inc(x_25); -if (lean_is_exclusive(x_6)) { - lean_ctor_release(x_6, 0); - lean_ctor_release(x_6, 1); - x_26 = x_6; -} else { - lean_dec_ref(x_6); - x_26 = lean_box(0); -} -if (lean_obj_tag(x_25) == 7) -{ -lean_object* x_88; lean_object* x_89; lean_object* x_90; -lean_dec(x_26); -lean_dec(x_23); -x_88 = lean_ctor_get(x_25, 2); -lean_inc(x_88); -lean_dec(x_25); -x_89 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_89, 0, x_24); -lean_ctor_set(x_89, 1, x_88); -x_90 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_90, 0, x_89); -lean_ctor_set(x_90, 1, x_8); -x_13 = x_90; -goto block_21; -} -else -{ -lean_object* x_91; -x_91 = lean_box(0); -x_27 = x_91; -goto block_87; -} -block_21: -{ -if (lean_obj_tag(x_13) == 0) -{ -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_13, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_13, 1); -lean_inc(x_15); -lean_dec(x_13); -x_5 = x_12; -x_6 = x_14; -x_8 = x_15; -goto _start; -} -else -{ -uint8_t x_17; -lean_dec(x_12); -lean_dec(x_7); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_17 = !lean_is_exclusive(x_13); -if (x_17 == 0) -{ -return x_13; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; -x_18 = lean_ctor_get(x_13, 0); -x_19 = lean_ctor_get(x_13, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_13); -x_20 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_20, 0, x_18); -lean_ctor_set(x_20, 1, x_19); -return x_20; -} -} -} -block_87: -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; -lean_dec(x_27); -lean_inc(x_3); -x_28 = lean_expr_instantiate_rev_range(x_25, x_24, x_23, x_3); -lean_dec(x_24); -lean_dec(x_25); -x_29 = lean_ctor_get(x_7, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_7, 1); -lean_inc(x_30); -x_31 = lean_ctor_get(x_7, 2); -lean_inc(x_31); -x_32 = !lean_is_exclusive(x_29); -if (x_32 == 0) -{ -uint8_t x_33; lean_object* x_34; lean_object* x_35; -x_33 = 1; -lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_33); -lean_inc(x_30); -x_34 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_34, 0, x_29); -lean_ctor_set(x_34, 1, x_30); -lean_ctor_set(x_34, 2, x_31); -lean_inc(x_1); -x_35 = lean_apply_3(x_1, x_28, x_34, x_8); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_35, 1); -lean_inc(x_37); -if (lean_is_exclusive(x_35)) { - lean_ctor_release(x_35, 0); - lean_ctor_release(x_35, 1); - x_38 = x_35; -} else { - lean_dec_ref(x_35); - x_38 = lean_box(0); -} -if (lean_obj_tag(x_36) == 7) -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -lean_dec(x_38); -lean_dec(x_30); -x_49 = lean_ctor_get(x_36, 2); -lean_inc(x_49); -lean_dec(x_36); -if (lean_is_scalar(x_26)) { - x_50 = lean_alloc_ctor(0, 2, 0); -} else { - x_50 = x_26; -} -lean_ctor_set(x_50, 0, x_23); -lean_ctor_set(x_50, 1, x_49); -x_51 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_51, 0, x_50); -lean_ctor_set(x_51, 1, x_37); -x_13 = x_51; -goto block_21; -} -else -{ -lean_object* x_52; -lean_dec(x_36); -lean_dec(x_26); -x_52 = lean_box(0); -x_39 = x_52; -goto block_48; -} -block_48: -{ -lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; -lean_dec(x_39); -x_40 = lean_ctor_get(x_37, 0); -lean_inc(x_40); -x_41 = lean_ctor_get(x_37, 1); -lean_inc(x_41); -x_42 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_42, 0, x_40); -lean_ctor_set(x_42, 1, x_41); -lean_ctor_set(x_42, 2, x_30); -lean_inc(x_2); -x_43 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_23, x_3, x_9, x_2); -x_44 = l_Lean_Expr_Inhabited; -x_45 = lean_array_get(x_44, x_3, x_23); -lean_dec(x_23); -x_46 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_46, 0, x_43); -lean_ctor_set(x_46, 1, x_45); -lean_ctor_set(x_46, 2, x_42); -if (lean_is_scalar(x_38)) { - x_47 = lean_alloc_ctor(1, 2, 0); -} else { - x_47 = x_38; - lean_ctor_set_tag(x_47, 1); -} -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_37); -x_13 = x_47; -goto block_21; -} -} -else -{ -uint8_t x_53; -lean_dec(x_30); -lean_dec(x_26); -lean_dec(x_23); -x_53 = !lean_is_exclusive(x_35); -if (x_53 == 0) -{ -x_13 = x_35; -goto block_21; -} -else -{ -lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_54 = lean_ctor_get(x_35, 0); -x_55 = lean_ctor_get(x_35, 1); -lean_inc(x_55); -lean_inc(x_54); -lean_dec(x_35); -x_56 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_56, 0, x_54); -lean_ctor_set(x_56, 1, x_55); -x_13 = x_56; -goto block_21; -} -} -} -else -{ -lean_object* x_57; uint8_t x_58; uint8_t x_59; uint8_t x_60; uint8_t x_61; uint8_t x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; -x_57 = lean_ctor_get(x_29, 0); -x_58 = lean_ctor_get_uint8(x_29, sizeof(void*)*1); -x_59 = lean_ctor_get_uint8(x_29, sizeof(void*)*1 + 1); -x_60 = lean_ctor_get_uint8(x_29, sizeof(void*)*1 + 2); -x_61 = lean_ctor_get_uint8(x_29, sizeof(void*)*1 + 3); -lean_inc(x_57); -lean_dec(x_29); -x_62 = 1; -x_63 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_63, 0, x_57); -lean_ctor_set_uint8(x_63, sizeof(void*)*1, x_58); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 1, x_59); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 2, x_60); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 3, x_61); -lean_ctor_set_uint8(x_63, sizeof(void*)*1 + 4, x_62); -lean_inc(x_30); -x_64 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_64, 0, x_63); -lean_ctor_set(x_64, 1, x_30); -lean_ctor_set(x_64, 2, x_31); -lean_inc(x_1); -x_65 = lean_apply_3(x_1, x_28, x_64, x_8); -if (lean_obj_tag(x_65) == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_66 = lean_ctor_get(x_65, 0); -lean_inc(x_66); -x_67 = lean_ctor_get(x_65, 1); -lean_inc(x_67); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_68 = x_65; -} else { - lean_dec_ref(x_65); - x_68 = lean_box(0); -} -if (lean_obj_tag(x_66) == 7) -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -lean_dec(x_68); -lean_dec(x_30); -x_79 = lean_ctor_get(x_66, 2); -lean_inc(x_79); -lean_dec(x_66); -if (lean_is_scalar(x_26)) { - x_80 = lean_alloc_ctor(0, 2, 0); -} else { - x_80 = x_26; -} -lean_ctor_set(x_80, 0, x_23); -lean_ctor_set(x_80, 1, x_79); -x_81 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_81, 0, x_80); -lean_ctor_set(x_81, 1, x_67); -x_13 = x_81; -goto block_21; -} -else -{ -lean_object* x_82; -lean_dec(x_66); -lean_dec(x_26); -x_82 = lean_box(0); -x_69 = x_82; -goto block_78; -} -block_78: -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -lean_dec(x_69); -x_70 = lean_ctor_get(x_67, 0); -lean_inc(x_70); -x_71 = lean_ctor_get(x_67, 1); -lean_inc(x_71); -x_72 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_72, 0, x_70); -lean_ctor_set(x_72, 1, x_71); -lean_ctor_set(x_72, 2, x_30); -lean_inc(x_2); -x_73 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_23, x_3, x_9, x_2); -x_74 = l_Lean_Expr_Inhabited; -x_75 = lean_array_get(x_74, x_3, x_23); -lean_dec(x_23); -x_76 = lean_alloc_ctor(5, 3, 0); -lean_ctor_set(x_76, 0, x_73); -lean_ctor_set(x_76, 1, x_75); -lean_ctor_set(x_76, 2, x_72); -if (lean_is_scalar(x_68)) { - x_77 = lean_alloc_ctor(1, 2, 0); -} else { - x_77 = x_68; - lean_ctor_set_tag(x_77, 1); -} -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_67); -x_13 = x_77; -goto block_21; -} -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -lean_dec(x_30); -lean_dec(x_26); -lean_dec(x_23); -x_83 = lean_ctor_get(x_65, 0); -lean_inc(x_83); -x_84 = lean_ctor_get(x_65, 1); -lean_inc(x_84); -if (lean_is_exclusive(x_65)) { - lean_ctor_release(x_65, 0); - lean_ctor_release(x_65, 1); - x_85 = x_65; -} else { - lean_dec_ref(x_65); - x_85 = lean_box(0); -} -if (lean_is_scalar(x_85)) { - x_86 = lean_alloc_ctor(1, 2, 0); -} else { - x_86 = x_85; -} -lean_ctor_set(x_86, 0, x_83); -lean_ctor_set(x_86, 1, x_84); -x_13 = x_86; -goto block_21; -} -} -} -} -else -{ -lean_object* x_92; -lean_dec(x_7); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_92 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_92, 0, x_6); -lean_ctor_set(x_92, 1, x_8); -return x_92; -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__31(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { -_start: -{ -lean_object* x_6; -lean_inc(x_4); -lean_inc(x_2); -lean_inc(x_1); -x_6 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_2, x_4, x_5); -if (lean_obj_tag(x_6) == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -x_8 = lean_ctor_get(x_6, 1); -lean_inc(x_8); -lean_dec(x_6); -x_9 = lean_unsigned_to_nat(0u); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_7); -x_11 = lean_array_get_size(x_3); -lean_inc(x_11); -lean_inc(x_3); -x_12 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__32(x_1, x_2, x_3, x_11, x_11, x_10, x_4, x_8); -if (lean_obj_tag(x_12) == 0) -{ -uint8_t x_13; -x_13 = !lean_is_exclusive(x_12); -if (x_13 == 0) -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_14 = lean_ctor_get(x_12, 0); -x_15 = lean_ctor_get(x_14, 0); -lean_inc(x_15); -x_16 = lean_ctor_get(x_14, 1); -lean_inc(x_16); -lean_dec(x_14); -x_17 = lean_expr_instantiate_rev_range(x_16, x_15, x_11, x_3); -lean_dec(x_11); -lean_dec(x_15); -lean_dec(x_16); -lean_ctor_set(x_12, 0, x_17); -return x_12; -} -else -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_18 = lean_ctor_get(x_12, 0); -x_19 = lean_ctor_get(x_12, 1); -lean_inc(x_19); -lean_inc(x_18); -lean_dec(x_12); -x_20 = lean_ctor_get(x_18, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -lean_dec(x_18); -x_22 = lean_expr_instantiate_rev_range(x_21, x_20, x_11, x_3); -lean_dec(x_11); -lean_dec(x_20); -lean_dec(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_19); -return x_23; -} -} -else -{ -uint8_t x_24; -lean_dec(x_11); -lean_dec(x_3); -x_24 = !lean_is_exclusive(x_12); -if (x_24 == 0) -{ -return x_12; -} -else -{ -lean_object* x_25; lean_object* x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_12, 0); -x_26 = lean_ctor_get(x_12, 1); -lean_inc(x_26); -lean_inc(x_25); -lean_dec(x_12); -x_27 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set(x_27, 1, x_26); -return x_27; -} -} -} -else -{ -uint8_t x_28; -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_28 = !lean_is_exclusive(x_6); -if (x_28 == 0) -{ -return x_6; -} -else -{ -lean_object* x_29; lean_object* x_30; lean_object* x_31; -x_29 = lean_ctor_get(x_6, 0); -x_30 = lean_ctor_get(x_6, 1); -lean_inc(x_30); -lean_inc(x_29); -lean_dec(x_6); -x_31 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_31, 0, x_29); -lean_ctor_set(x_31, 1, x_30); -return x_31; -} -} -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; uint8_t x_11; -x_10 = lean_unsigned_to_nat(0u); -x_11 = lean_nat_dec_eq(x_6, x_10); -if (x_11 == 0) -{ -lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; uint8_t x_19; -x_12 = lean_unsigned_to_nat(1u); -x_13 = lean_nat_sub(x_6, x_12); -lean_dec(x_6); -x_14 = lean_nat_sub(x_5, x_13); -x_15 = lean_nat_sub(x_14, x_12); -lean_dec(x_14); -x_16 = lean_ctor_get(x_8, 0); -lean_inc(x_16); -x_17 = lean_ctor_get(x_8, 1); -lean_inc(x_17); -x_18 = lean_ctor_get(x_8, 2); -lean_inc(x_18); -x_19 = !lean_is_exclusive(x_16); -if (x_19 == 0) -{ -uint8_t x_20; lean_object* x_21; lean_object* x_22; -x_20 = 1; -lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_20); -lean_inc(x_17); -x_21 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_21, 0, x_16); -lean_ctor_set(x_21, 1, x_17); -lean_ctor_set(x_21, 2, x_18); -lean_inc(x_1); -x_22 = lean_apply_3(x_1, x_7, x_21, x_9); -if (lean_obj_tag(x_22) == 0) -{ -lean_object* x_23; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -if (lean_obj_tag(x_23) == 7) -{ -lean_object* x_24; lean_object* x_25; uint8_t x_26; -lean_dec(x_17); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -x_25 = lean_ctor_get(x_23, 2); -lean_inc(x_25); -lean_dec(x_23); -x_26 = l_Lean_Expr_hasLooseBVars(x_25); -if (x_26 == 0) -{ -lean_dec(x_15); -x_6 = x_13; -x_7 = x_25; -x_9 = x_24; -goto _start; -} -else -{ -lean_object* x_28; lean_object* x_29; -lean_inc(x_4); -lean_inc(x_2); -x_28 = l_Lean_mkProj(x_2, x_15, x_4); -x_29 = lean_expr_instantiate1(x_25, x_28); -lean_dec(x_28); -lean_dec(x_25); -x_6 = x_13; -x_7 = x_29; -x_9 = x_24; -goto _start; -} -} -else -{ -uint8_t x_31; -lean_dec(x_23); -lean_dec(x_15); -lean_dec(x_13); -lean_dec(x_8); -lean_dec(x_1); -x_31 = !lean_is_exclusive(x_22); -if (x_31 == 0) -{ -lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_32 = lean_ctor_get(x_22, 1); -x_33 = lean_ctor_get(x_22, 0); -lean_dec(x_33); -x_34 = lean_ctor_get(x_32, 0); -lean_inc(x_34); -x_35 = lean_ctor_get(x_32, 1); -lean_inc(x_35); -x_36 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_36, 0, x_34); -lean_ctor_set(x_36, 1, x_35); -lean_ctor_set(x_36, 2, x_17); -x_37 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_37, 0, x_2); -lean_ctor_set(x_37, 1, x_3); -lean_ctor_set(x_37, 2, x_4); -lean_ctor_set(x_37, 3, x_36); -lean_ctor_set_tag(x_22, 1); -lean_ctor_set(x_22, 0, x_37); -return x_22; -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; -x_38 = lean_ctor_get(x_22, 1); -lean_inc(x_38); -lean_dec(x_22); -x_39 = lean_ctor_get(x_38, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_38, 1); -lean_inc(x_40); -x_41 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_41, 0, x_39); -lean_ctor_set(x_41, 1, x_40); -lean_ctor_set(x_41, 2, x_17); -x_42 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_42, 0, x_2); -lean_ctor_set(x_42, 1, x_3); -lean_ctor_set(x_42, 2, x_4); -lean_ctor_set(x_42, 3, x_41); -x_43 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_43, 0, x_42); -lean_ctor_set(x_43, 1, x_38); -return x_43; -} -} -} -else -{ -uint8_t x_44; -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_13); -lean_dec(x_8); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_44 = !lean_is_exclusive(x_22); -if (x_44 == 0) -{ -return x_22; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_22, 0); -x_46 = lean_ctor_get(x_22, 1); -lean_inc(x_46); -lean_inc(x_45); -lean_dec(x_22); -x_47 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_47, 0, x_45); -lean_ctor_set(x_47, 1, x_46); -return x_47; -} -} -} -else -{ -lean_object* x_48; uint8_t x_49; uint8_t x_50; uint8_t x_51; uint8_t x_52; uint8_t x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; -x_48 = lean_ctor_get(x_16, 0); -x_49 = lean_ctor_get_uint8(x_16, sizeof(void*)*1); -x_50 = lean_ctor_get_uint8(x_16, sizeof(void*)*1 + 1); -x_51 = lean_ctor_get_uint8(x_16, sizeof(void*)*1 + 2); -x_52 = lean_ctor_get_uint8(x_16, sizeof(void*)*1 + 3); -lean_inc(x_48); -lean_dec(x_16); -x_53 = 1; -x_54 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_54, 0, x_48); -lean_ctor_set_uint8(x_54, sizeof(void*)*1, x_49); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 1, x_50); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 2, x_51); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 3, x_52); -lean_ctor_set_uint8(x_54, sizeof(void*)*1 + 4, x_53); -lean_inc(x_17); -x_55 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_55, 0, x_54); -lean_ctor_set(x_55, 1, x_17); -lean_ctor_set(x_55, 2, x_18); -lean_inc(x_1); -x_56 = lean_apply_3(x_1, x_7, x_55, x_9); -if (lean_obj_tag(x_56) == 0) -{ -lean_object* x_57; -x_57 = lean_ctor_get(x_56, 0); -lean_inc(x_57); -if (lean_obj_tag(x_57) == 7) -{ -lean_object* x_58; lean_object* x_59; uint8_t x_60; -lean_dec(x_17); -x_58 = lean_ctor_get(x_56, 1); -lean_inc(x_58); -lean_dec(x_56); -x_59 = lean_ctor_get(x_57, 2); -lean_inc(x_59); -lean_dec(x_57); -x_60 = l_Lean_Expr_hasLooseBVars(x_59); -if (x_60 == 0) -{ -lean_dec(x_15); -x_6 = x_13; -x_7 = x_59; -x_9 = x_58; -goto _start; -} -else -{ -lean_object* x_62; lean_object* x_63; -lean_inc(x_4); -lean_inc(x_2); -x_62 = l_Lean_mkProj(x_2, x_15, x_4); -x_63 = lean_expr_instantiate1(x_59, x_62); -lean_dec(x_62); -lean_dec(x_59); -x_6 = x_13; -x_7 = x_63; -x_9 = x_58; -goto _start; -} -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -lean_dec(x_57); -lean_dec(x_15); -lean_dec(x_13); -lean_dec(x_8); -lean_dec(x_1); -x_65 = lean_ctor_get(x_56, 1); -lean_inc(x_65); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - x_66 = x_56; -} else { - lean_dec_ref(x_56); - x_66 = lean_box(0); -} -x_67 = lean_ctor_get(x_65, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_65, 1); -lean_inc(x_68); -x_69 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_69, 0, x_67); -lean_ctor_set(x_69, 1, x_68); -lean_ctor_set(x_69, 2, x_17); -x_70 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_70, 0, x_2); -lean_ctor_set(x_70, 1, x_3); -lean_ctor_set(x_70, 2, x_4); -lean_ctor_set(x_70, 3, x_69); -if (lean_is_scalar(x_66)) { - x_71 = lean_alloc_ctor(1, 2, 0); -} else { - x_71 = x_66; - lean_ctor_set_tag(x_71, 1); -} -lean_ctor_set(x_71, 0, x_70); -lean_ctor_set(x_71, 1, x_65); -return x_71; -} -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_13); -lean_dec(x_8); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_72 = lean_ctor_get(x_56, 0); -lean_inc(x_72); -x_73 = lean_ctor_get(x_56, 1); -lean_inc(x_73); -if (lean_is_exclusive(x_56)) { - lean_ctor_release(x_56, 0); - lean_ctor_release(x_56, 1); - x_74 = x_56; -} else { - lean_dec_ref(x_56); - x_74 = lean_box(0); -} -if (lean_is_scalar(x_74)) { - x_75 = lean_alloc_ctor(1, 2, 0); -} else { - x_75 = x_74; -} -lean_ctor_set(x_75, 0, x_72); -lean_ctor_set(x_75, 1, x_73); -return x_75; -} -} -} -else -{ -lean_object* x_76; -lean_dec(x_8); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_76 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_76, 0, x_7); -lean_ctor_set(x_76, 1, x_9); -return x_76; -} -} -} -lean_object* l___private_Init_Lean_Meta_InferType_3__inferProjType___at_Lean_Meta_inferTypeAux___spec__30(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_1); -x_7 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_4, x_5, x_6); -if (lean_obj_tag(x_7) == 0) -{ -lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; -x_8 = lean_ctor_get(x_5, 0); -lean_inc(x_8); -x_9 = lean_ctor_get(x_7, 0); -lean_inc(x_9); -x_10 = lean_ctor_get(x_7, 1); -lean_inc(x_10); -lean_dec(x_7); -x_11 = lean_ctor_get(x_5, 1); -lean_inc(x_11); -x_12 = lean_ctor_get(x_5, 2); -lean_inc(x_12); -x_13 = !lean_is_exclusive(x_8); -if (x_13 == 0) -{ -uint8_t x_14; lean_object* x_15; lean_object* x_16; -x_14 = 1; -lean_ctor_set_uint8(x_8, sizeof(void*)*1 + 4, x_14); -lean_inc(x_11); -x_15 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_15, 0, x_8); -lean_ctor_set(x_15, 1, x_11); -lean_ctor_set(x_15, 2, x_12); -lean_inc(x_1); -lean_inc(x_15); -x_16 = lean_apply_3(x_1, x_9, x_15, x_10); -if (lean_obj_tag(x_16) == 0) -{ -uint8_t x_17; -x_17 = !lean_is_exclusive(x_16); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; -x_18 = lean_ctor_get(x_16, 1); -x_19 = lean_ctor_get(x_16, 0); -x_20 = lean_ctor_get(x_18, 0); -lean_inc(x_20); -x_21 = lean_ctor_get(x_18, 1); -lean_inc(x_21); -x_22 = l_Lean_Expr_getAppFn___main(x_19); -if (lean_obj_tag(x_22) == 4) -{ -lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_23 = lean_ctor_get(x_22, 0); -lean_inc(x_23); -x_24 = lean_ctor_get(x_22, 1); -lean_inc(x_24); -lean_dec(x_22); -lean_inc(x_20); -x_25 = lean_environment_find(x_20, x_23); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; lean_object* x_27; -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_26 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_26, 0, x_20); -lean_ctor_set(x_26, 1, x_21); -lean_ctor_set(x_26, 2, x_11); -x_27 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_27, 0, x_2); -lean_ctor_set(x_27, 1, x_3); -lean_ctor_set(x_27, 2, x_4); -lean_ctor_set(x_27, 3, x_26); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_27); -return x_16; -} -else -{ -lean_object* x_28; -x_28 = lean_ctor_get(x_25, 0); -lean_inc(x_28); -lean_dec(x_25); -if (lean_obj_tag(x_28) == 5) -{ -lean_object* x_29; lean_object* x_30; -x_29 = lean_ctor_get(x_28, 0); -lean_inc(x_29); -lean_dec(x_28); -x_30 = lean_ctor_get(x_29, 4); -lean_inc(x_30); -if (lean_obj_tag(x_30) == 0) -{ -lean_object* x_31; lean_object* x_32; -lean_dec(x_29); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_31 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_31, 0, x_20); -lean_ctor_set(x_31, 1, x_21); -lean_ctor_set(x_31, 2, x_11); -x_32 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_32, 0, x_2); -lean_ctor_set(x_32, 1, x_3); -lean_ctor_set(x_32, 2, x_4); -lean_ctor_set(x_32, 3, x_31); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_32); -return x_16; -} -else -{ -lean_object* x_33; -x_33 = lean_ctor_get(x_30, 1); -lean_inc(x_33); -if (lean_obj_tag(x_33) == 0) -{ -lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; -x_34 = lean_ctor_get(x_29, 1); -lean_inc(x_34); -lean_dec(x_29); -x_35 = lean_ctor_get(x_30, 0); -lean_inc(x_35); -lean_dec(x_30); -x_36 = lean_unsigned_to_nat(0u); -x_37 = l_Lean_Expr_getAppNumArgsAux___main(x_19, x_36); -x_38 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_37); -x_39 = lean_mk_array(x_37, x_38); -x_40 = lean_unsigned_to_nat(1u); -x_41 = lean_nat_sub(x_37, x_40); -lean_dec(x_37); -x_42 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_19, x_39, x_41); -x_43 = lean_array_get_size(x_42); -x_44 = lean_nat_dec_eq(x_34, x_43); -lean_dec(x_43); -lean_dec(x_34); -if (x_44 == 0) -{ -lean_object* x_45; lean_object* x_46; -lean_dec(x_42); -lean_dec(x_35); -lean_dec(x_24); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_45 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_45, 0, x_20); -lean_ctor_set(x_45, 1, x_21); -lean_ctor_set(x_45, 2, x_11); -x_46 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_46, 0, x_2); -lean_ctor_set(x_46, 1, x_3); -lean_ctor_set(x_46, 2, x_4); -lean_ctor_set(x_46, 3, x_45); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_46); -return x_16; -} -else -{ -lean_object* x_47; -lean_inc(x_35); -lean_inc(x_20); -x_47 = lean_environment_find(x_20, x_35); -if (lean_obj_tag(x_47) == 0) -{ -lean_object* x_48; lean_object* x_49; -lean_dec(x_42); -lean_dec(x_35); -lean_dec(x_24); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_48 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_48, 0, x_20); -lean_ctor_set(x_48, 1, x_21); -lean_ctor_set(x_48, 2, x_11); -x_49 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_49, 0, x_2); -lean_ctor_set(x_49, 1, x_3); -lean_ctor_set(x_49, 2, x_4); -lean_ctor_set(x_49, 3, x_48); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_49); -return x_16; -} -else -{ -lean_object* x_50; lean_object* x_51; -lean_dec(x_47); -lean_dec(x_21); -lean_dec(x_20); -lean_free_object(x_16); -x_50 = l_Lean_mkConst(x_35, x_24); -lean_inc(x_5); -lean_inc(x_1); -x_51 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__31(x_1, x_50, x_42, x_5, x_18); -if (lean_obj_tag(x_51) == 0) -{ -lean_object* x_52; lean_object* x_53; lean_object* x_54; -x_52 = lean_ctor_get(x_51, 0); -lean_inc(x_52); -x_53 = lean_ctor_get(x_51, 1); -lean_inc(x_53); -lean_dec(x_51); -lean_inc(x_4); -lean_inc_n(x_3, 2); -lean_inc(x_2); -lean_inc(x_1); -x_54 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33(x_1, x_2, x_3, x_4, x_3, x_3, x_52, x_5, x_53); -if (lean_obj_tag(x_54) == 0) -{ -lean_object* x_55; lean_object* x_56; lean_object* x_57; -x_55 = lean_ctor_get(x_54, 0); -lean_inc(x_55); -x_56 = lean_ctor_get(x_54, 1); -lean_inc(x_56); -lean_dec(x_54); -x_57 = lean_apply_3(x_1, x_55, x_15, x_56); -if (lean_obj_tag(x_57) == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_57, 0); -lean_inc(x_58); -if (lean_obj_tag(x_58) == 7) -{ -uint8_t x_59; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_59 = !lean_is_exclusive(x_57); -if (x_59 == 0) -{ -lean_object* x_60; lean_object* x_61; -x_60 = lean_ctor_get(x_57, 0); -lean_dec(x_60); -x_61 = lean_ctor_get(x_58, 1); -lean_inc(x_61); -lean_dec(x_58); -lean_ctor_set(x_57, 0, x_61); -return x_57; -} -else -{ -lean_object* x_62; lean_object* x_63; lean_object* x_64; -x_62 = lean_ctor_get(x_57, 1); -lean_inc(x_62); -lean_dec(x_57); -x_63 = lean_ctor_get(x_58, 1); -lean_inc(x_63); -lean_dec(x_58); -x_64 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_64, 0, x_63); -lean_ctor_set(x_64, 1, x_62); -return x_64; -} -} -else -{ -uint8_t x_65; -lean_dec(x_58); -x_65 = !lean_is_exclusive(x_57); -if (x_65 == 0) -{ -lean_object* x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_66 = lean_ctor_get(x_57, 1); -x_67 = lean_ctor_get(x_57, 0); -lean_dec(x_67); -x_68 = lean_ctor_get(x_66, 0); -lean_inc(x_68); -x_69 = lean_ctor_get(x_66, 1); -lean_inc(x_69); -x_70 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_70, 0, x_68); -lean_ctor_set(x_70, 1, x_69); -lean_ctor_set(x_70, 2, x_11); -x_71 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_71, 0, x_2); -lean_ctor_set(x_71, 1, x_3); -lean_ctor_set(x_71, 2, x_4); -lean_ctor_set(x_71, 3, x_70); -lean_ctor_set_tag(x_57, 1); -lean_ctor_set(x_57, 0, x_71); -return x_57; -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_72 = lean_ctor_get(x_57, 1); -lean_inc(x_72); -lean_dec(x_57); -x_73 = lean_ctor_get(x_72, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_72, 1); -lean_inc(x_74); -x_75 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -lean_ctor_set(x_75, 2, x_11); -x_76 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_76, 0, x_2); -lean_ctor_set(x_76, 1, x_3); -lean_ctor_set(x_76, 2, x_4); -lean_ctor_set(x_76, 3, x_75); -x_77 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_77, 0, x_76); -lean_ctor_set(x_77, 1, x_72); -return x_77; -} -} -} -else -{ -uint8_t x_78; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_78 = !lean_is_exclusive(x_57); -if (x_78 == 0) -{ -return x_57; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_57, 0); -x_80 = lean_ctor_get(x_57, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_57); -x_81 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_81, 0, x_79); -lean_ctor_set(x_81, 1, x_80); -return x_81; -} -} -} -else -{ -uint8_t x_82; -lean_dec(x_15); -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_82 = !lean_is_exclusive(x_54); -if (x_82 == 0) -{ -return x_54; -} -else -{ -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_54, 0); -x_84 = lean_ctor_get(x_54, 1); -lean_inc(x_84); -lean_inc(x_83); -lean_dec(x_54); -x_85 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_85, 0, x_83); -lean_ctor_set(x_85, 1, x_84); -return x_85; -} -} -} -else -{ -uint8_t x_86; -lean_dec(x_15); -lean_dec(x_11); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_86 = !lean_is_exclusive(x_51); -if (x_86 == 0) -{ -return x_51; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_51, 0); -x_88 = lean_ctor_get(x_51, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_51); -x_89 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_89, 0, x_87); -lean_ctor_set(x_89, 1, x_88); -return x_89; -} -} -} -} -} -else -{ -lean_object* x_90; lean_object* x_91; -lean_dec(x_33); -lean_dec(x_30); -lean_dec(x_29); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_90 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_90, 0, x_20); -lean_ctor_set(x_90, 1, x_21); -lean_ctor_set(x_90, 2, x_11); -x_91 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_91, 0, x_2); -lean_ctor_set(x_91, 1, x_3); -lean_ctor_set(x_91, 2, x_4); -lean_ctor_set(x_91, 3, x_90); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_91); -return x_16; -} -} -} -else -{ -lean_object* x_92; lean_object* x_93; -lean_dec(x_28); -lean_dec(x_24); -lean_dec(x_19); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_92 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_92, 0, x_20); -lean_ctor_set(x_92, 1, x_21); -lean_ctor_set(x_92, 2, x_11); -x_93 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_93, 0, x_2); -lean_ctor_set(x_93, 1, x_3); -lean_ctor_set(x_93, 2, x_4); -lean_ctor_set(x_93, 3, x_92); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_93); -return x_16; -} -} -} -else -{ -lean_object* x_94; lean_object* x_95; -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_94 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_94, 0, x_20); -lean_ctor_set(x_94, 1, x_21); -lean_ctor_set(x_94, 2, x_11); -x_95 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_95, 0, x_2); -lean_ctor_set(x_95, 1, x_3); -lean_ctor_set(x_95, 2, x_4); -lean_ctor_set(x_95, 3, x_94); -lean_ctor_set_tag(x_16, 1); -lean_ctor_set(x_16, 0, x_95); -return x_16; -} -} -else -{ -lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; -x_96 = lean_ctor_get(x_16, 1); -x_97 = lean_ctor_get(x_16, 0); -lean_inc(x_96); -lean_inc(x_97); -lean_dec(x_16); -x_98 = lean_ctor_get(x_96, 0); -lean_inc(x_98); -x_99 = lean_ctor_get(x_96, 1); -lean_inc(x_99); -x_100 = l_Lean_Expr_getAppFn___main(x_97); -if (lean_obj_tag(x_100) == 4) -{ -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_100, 0); -lean_inc(x_101); -x_102 = lean_ctor_get(x_100, 1); -lean_inc(x_102); -lean_dec(x_100); -lean_inc(x_98); -x_103 = lean_environment_find(x_98, x_101); -if (lean_obj_tag(x_103) == 0) -{ -lean_object* x_104; lean_object* x_105; lean_object* x_106; -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_104 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_104, 0, x_98); -lean_ctor_set(x_104, 1, x_99); -lean_ctor_set(x_104, 2, x_11); -x_105 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_105, 0, x_2); -lean_ctor_set(x_105, 1, x_3); -lean_ctor_set(x_105, 2, x_4); -lean_ctor_set(x_105, 3, x_104); -x_106 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_106, 0, x_105); -lean_ctor_set(x_106, 1, x_96); -return x_106; -} -else -{ -lean_object* x_107; -x_107 = lean_ctor_get(x_103, 0); -lean_inc(x_107); -lean_dec(x_103); -if (lean_obj_tag(x_107) == 5) -{ -lean_object* x_108; lean_object* x_109; -x_108 = lean_ctor_get(x_107, 0); -lean_inc(x_108); -lean_dec(x_107); -x_109 = lean_ctor_get(x_108, 4); -lean_inc(x_109); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; lean_object* x_111; lean_object* x_112; -lean_dec(x_108); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_110 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_110, 0, x_98); -lean_ctor_set(x_110, 1, x_99); -lean_ctor_set(x_110, 2, x_11); -x_111 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_111, 0, x_2); -lean_ctor_set(x_111, 1, x_3); -lean_ctor_set(x_111, 2, x_4); -lean_ctor_set(x_111, 3, x_110); -x_112 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_112, 0, x_111); -lean_ctor_set(x_112, 1, x_96); -return x_112; -} -else -{ -lean_object* x_113; -x_113 = lean_ctor_get(x_109, 1); -lean_inc(x_113); -if (lean_obj_tag(x_113) == 0) -{ -lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; uint8_t x_124; -x_114 = lean_ctor_get(x_108, 1); -lean_inc(x_114); -lean_dec(x_108); -x_115 = lean_ctor_get(x_109, 0); -lean_inc(x_115); -lean_dec(x_109); -x_116 = lean_unsigned_to_nat(0u); -x_117 = l_Lean_Expr_getAppNumArgsAux___main(x_97, x_116); -x_118 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_117); -x_119 = lean_mk_array(x_117, x_118); -x_120 = lean_unsigned_to_nat(1u); -x_121 = lean_nat_sub(x_117, x_120); -lean_dec(x_117); -x_122 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_97, x_119, x_121); -x_123 = lean_array_get_size(x_122); -x_124 = lean_nat_dec_eq(x_114, x_123); -lean_dec(x_123); -lean_dec(x_114); -if (x_124 == 0) -{ -lean_object* x_125; lean_object* x_126; lean_object* x_127; -lean_dec(x_122); -lean_dec(x_115); -lean_dec(x_102); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_125 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_125, 0, x_98); -lean_ctor_set(x_125, 1, x_99); -lean_ctor_set(x_125, 2, x_11); -x_126 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_126, 0, x_2); -lean_ctor_set(x_126, 1, x_3); -lean_ctor_set(x_126, 2, x_4); -lean_ctor_set(x_126, 3, x_125); -x_127 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_127, 0, x_126); -lean_ctor_set(x_127, 1, x_96); -return x_127; -} -else -{ -lean_object* x_128; -lean_inc(x_115); -lean_inc(x_98); -x_128 = lean_environment_find(x_98, x_115); -if (lean_obj_tag(x_128) == 0) -{ -lean_object* x_129; lean_object* x_130; lean_object* x_131; -lean_dec(x_122); -lean_dec(x_115); -lean_dec(x_102); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_129 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_129, 0, x_98); -lean_ctor_set(x_129, 1, x_99); -lean_ctor_set(x_129, 2, x_11); -x_130 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_130, 0, x_2); -lean_ctor_set(x_130, 1, x_3); -lean_ctor_set(x_130, 2, x_4); -lean_ctor_set(x_130, 3, x_129); -x_131 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_131, 0, x_130); -lean_ctor_set(x_131, 1, x_96); -return x_131; -} -else -{ -lean_object* x_132; lean_object* x_133; -lean_dec(x_128); -lean_dec(x_99); -lean_dec(x_98); -x_132 = l_Lean_mkConst(x_115, x_102); -lean_inc(x_5); -lean_inc(x_1); -x_133 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__31(x_1, x_132, x_122, x_5, x_96); -if (lean_obj_tag(x_133) == 0) -{ -lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_134 = lean_ctor_get(x_133, 0); -lean_inc(x_134); -x_135 = lean_ctor_get(x_133, 1); -lean_inc(x_135); -lean_dec(x_133); -lean_inc(x_4); -lean_inc_n(x_3, 2); -lean_inc(x_2); -lean_inc(x_1); -x_136 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33(x_1, x_2, x_3, x_4, x_3, x_3, x_134, x_5, x_135); -if (lean_obj_tag(x_136) == 0) -{ -lean_object* x_137; lean_object* x_138; lean_object* x_139; -x_137 = lean_ctor_get(x_136, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_136, 1); -lean_inc(x_138); -lean_dec(x_136); -x_139 = lean_apply_3(x_1, x_137, x_15, x_138); -if (lean_obj_tag(x_139) == 0) -{ -lean_object* x_140; -x_140 = lean_ctor_get(x_139, 0); -lean_inc(x_140); -if (lean_obj_tag(x_140) == 7) -{ -lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_141 = lean_ctor_get(x_139, 1); -lean_inc(x_141); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_142 = x_139; -} else { - lean_dec_ref(x_139); - x_142 = lean_box(0); -} -x_143 = lean_ctor_get(x_140, 1); -lean_inc(x_143); -lean_dec(x_140); -if (lean_is_scalar(x_142)) { - x_144 = lean_alloc_ctor(0, 2, 0); -} else { - x_144 = x_142; -} -lean_ctor_set(x_144, 0, x_143); -lean_ctor_set(x_144, 1, x_141); -return x_144; -} -else -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -lean_dec(x_140); -x_145 = lean_ctor_get(x_139, 1); -lean_inc(x_145); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_146 = x_139; -} else { - lean_dec_ref(x_139); - x_146 = lean_box(0); -} -x_147 = lean_ctor_get(x_145, 0); -lean_inc(x_147); -x_148 = lean_ctor_get(x_145, 1); -lean_inc(x_148); -x_149 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_149, 0, x_147); -lean_ctor_set(x_149, 1, x_148); -lean_ctor_set(x_149, 2, x_11); -x_150 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_150, 0, x_2); -lean_ctor_set(x_150, 1, x_3); -lean_ctor_set(x_150, 2, x_4); -lean_ctor_set(x_150, 3, x_149); -if (lean_is_scalar(x_146)) { - x_151 = lean_alloc_ctor(1, 2, 0); -} else { - x_151 = x_146; - lean_ctor_set_tag(x_151, 1); -} -lean_ctor_set(x_151, 0, x_150); -lean_ctor_set(x_151, 1, x_145); -return x_151; -} -} -else -{ -lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_152 = lean_ctor_get(x_139, 0); -lean_inc(x_152); -x_153 = lean_ctor_get(x_139, 1); -lean_inc(x_153); -if (lean_is_exclusive(x_139)) { - lean_ctor_release(x_139, 0); - lean_ctor_release(x_139, 1); - x_154 = x_139; -} else { - lean_dec_ref(x_139); - x_154 = lean_box(0); -} -if (lean_is_scalar(x_154)) { - x_155 = lean_alloc_ctor(1, 2, 0); -} else { - x_155 = x_154; -} -lean_ctor_set(x_155, 0, x_152); -lean_ctor_set(x_155, 1, x_153); -return x_155; -} -} -else -{ -lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; -lean_dec(x_15); -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_156 = lean_ctor_get(x_136, 0); -lean_inc(x_156); -x_157 = lean_ctor_get(x_136, 1); -lean_inc(x_157); -if (lean_is_exclusive(x_136)) { - lean_ctor_release(x_136, 0); - lean_ctor_release(x_136, 1); - x_158 = x_136; -} else { - lean_dec_ref(x_136); - x_158 = lean_box(0); -} -if (lean_is_scalar(x_158)) { - x_159 = lean_alloc_ctor(1, 2, 0); -} else { - x_159 = x_158; -} -lean_ctor_set(x_159, 0, x_156); -lean_ctor_set(x_159, 1, x_157); -return x_159; -} -} -else -{ -lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; -lean_dec(x_15); -lean_dec(x_11); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_160 = lean_ctor_get(x_133, 0); -lean_inc(x_160); -x_161 = lean_ctor_get(x_133, 1); -lean_inc(x_161); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - x_162 = x_133; -} else { - lean_dec_ref(x_133); - x_162 = lean_box(0); -} -if (lean_is_scalar(x_162)) { - x_163 = lean_alloc_ctor(1, 2, 0); -} else { - x_163 = x_162; -} -lean_ctor_set(x_163, 0, x_160); -lean_ctor_set(x_163, 1, x_161); -return x_163; -} -} -} -} -else -{ -lean_object* x_164; lean_object* x_165; lean_object* x_166; -lean_dec(x_113); -lean_dec(x_109); -lean_dec(x_108); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_164 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_164, 0, x_98); -lean_ctor_set(x_164, 1, x_99); -lean_ctor_set(x_164, 2, x_11); -x_165 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_165, 0, x_2); -lean_ctor_set(x_165, 1, x_3); -lean_ctor_set(x_165, 2, x_4); -lean_ctor_set(x_165, 3, x_164); -x_166 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_166, 0, x_165); -lean_ctor_set(x_166, 1, x_96); -return x_166; -} -} -} -else -{ -lean_object* x_167; lean_object* x_168; lean_object* x_169; -lean_dec(x_107); -lean_dec(x_102); -lean_dec(x_97); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_167 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_167, 0, x_98); -lean_ctor_set(x_167, 1, x_99); -lean_ctor_set(x_167, 2, x_11); -x_168 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_168, 0, x_2); -lean_ctor_set(x_168, 1, x_3); -lean_ctor_set(x_168, 2, x_4); -lean_ctor_set(x_168, 3, x_167); -x_169 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_169, 0, x_168); -lean_ctor_set(x_169, 1, x_96); -return x_169; -} -} -} -else -{ -lean_object* x_170; lean_object* x_171; lean_object* x_172; -lean_dec(x_100); -lean_dec(x_97); -lean_dec(x_15); -lean_dec(x_5); -lean_dec(x_1); -x_170 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_170, 0, x_98); -lean_ctor_set(x_170, 1, x_99); -lean_ctor_set(x_170, 2, x_11); -x_171 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_171, 0, x_2); -lean_ctor_set(x_171, 1, x_3); -lean_ctor_set(x_171, 2, x_4); -lean_ctor_set(x_171, 3, x_170); -x_172 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_172, 0, x_171); -lean_ctor_set(x_172, 1, x_96); -return x_172; -} -} -} -else -{ -uint8_t x_173; -lean_dec(x_15); -lean_dec(x_11); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_173 = !lean_is_exclusive(x_16); -if (x_173 == 0) -{ -return x_16; -} -else -{ -lean_object* x_174; lean_object* x_175; lean_object* x_176; -x_174 = lean_ctor_get(x_16, 0); -x_175 = lean_ctor_get(x_16, 1); -lean_inc(x_175); -lean_inc(x_174); -lean_dec(x_16); -x_176 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_176, 0, x_174); -lean_ctor_set(x_176, 1, x_175); -return x_176; -} -} -} -else -{ -lean_object* x_177; uint8_t x_178; uint8_t x_179; uint8_t x_180; uint8_t x_181; uint8_t x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; -x_177 = lean_ctor_get(x_8, 0); -x_178 = lean_ctor_get_uint8(x_8, sizeof(void*)*1); -x_179 = lean_ctor_get_uint8(x_8, sizeof(void*)*1 + 1); -x_180 = lean_ctor_get_uint8(x_8, sizeof(void*)*1 + 2); -x_181 = lean_ctor_get_uint8(x_8, sizeof(void*)*1 + 3); -lean_inc(x_177); -lean_dec(x_8); -x_182 = 1; -x_183 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_183, 0, x_177); -lean_ctor_set_uint8(x_183, sizeof(void*)*1, x_178); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 1, x_179); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 2, x_180); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 3, x_181); -lean_ctor_set_uint8(x_183, sizeof(void*)*1 + 4, x_182); -lean_inc(x_11); -x_184 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_184, 0, x_183); -lean_ctor_set(x_184, 1, x_11); -lean_ctor_set(x_184, 2, x_12); -lean_inc(x_1); -lean_inc(x_184); -x_185 = lean_apply_3(x_1, x_9, x_184, x_10); -if (lean_obj_tag(x_185) == 0) -{ -lean_object* x_186; lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; -x_186 = lean_ctor_get(x_185, 1); -lean_inc(x_186); -x_187 = lean_ctor_get(x_185, 0); -lean_inc(x_187); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - x_188 = x_185; -} else { - lean_dec_ref(x_185); - x_188 = lean_box(0); -} -x_189 = lean_ctor_get(x_186, 0); -lean_inc(x_189); -x_190 = lean_ctor_get(x_186, 1); -lean_inc(x_190); -x_191 = l_Lean_Expr_getAppFn___main(x_187); -if (lean_obj_tag(x_191) == 4) -{ -lean_object* x_192; lean_object* x_193; lean_object* x_194; -x_192 = lean_ctor_get(x_191, 0); -lean_inc(x_192); -x_193 = lean_ctor_get(x_191, 1); -lean_inc(x_193); -lean_dec(x_191); -lean_inc(x_189); -x_194 = lean_environment_find(x_189, x_192); -if (lean_obj_tag(x_194) == 0) -{ -lean_object* x_195; lean_object* x_196; lean_object* x_197; -lean_dec(x_193); -lean_dec(x_187); -lean_dec(x_184); -lean_dec(x_5); -lean_dec(x_1); -x_195 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_195, 0, x_189); -lean_ctor_set(x_195, 1, x_190); -lean_ctor_set(x_195, 2, x_11); -x_196 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_196, 0, x_2); -lean_ctor_set(x_196, 1, x_3); -lean_ctor_set(x_196, 2, x_4); -lean_ctor_set(x_196, 3, x_195); -if (lean_is_scalar(x_188)) { - x_197 = lean_alloc_ctor(1, 2, 0); -} else { - x_197 = x_188; - lean_ctor_set_tag(x_197, 1); -} -lean_ctor_set(x_197, 0, x_196); -lean_ctor_set(x_197, 1, x_186); -return x_197; -} -else -{ -lean_object* x_198; -x_198 = lean_ctor_get(x_194, 0); -lean_inc(x_198); -lean_dec(x_194); -if (lean_obj_tag(x_198) == 5) -{ -lean_object* x_199; lean_object* x_200; -x_199 = lean_ctor_get(x_198, 0); -lean_inc(x_199); -lean_dec(x_198); -x_200 = lean_ctor_get(x_199, 4); -lean_inc(x_200); -if (lean_obj_tag(x_200) == 0) -{ -lean_object* x_201; lean_object* x_202; lean_object* x_203; -lean_dec(x_199); -lean_dec(x_193); -lean_dec(x_187); -lean_dec(x_184); -lean_dec(x_5); -lean_dec(x_1); -x_201 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_201, 0, x_189); -lean_ctor_set(x_201, 1, x_190); -lean_ctor_set(x_201, 2, x_11); -x_202 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_202, 0, x_2); -lean_ctor_set(x_202, 1, x_3); -lean_ctor_set(x_202, 2, x_4); -lean_ctor_set(x_202, 3, x_201); -if (lean_is_scalar(x_188)) { - x_203 = lean_alloc_ctor(1, 2, 0); -} else { - x_203 = x_188; - lean_ctor_set_tag(x_203, 1); -} -lean_ctor_set(x_203, 0, x_202); -lean_ctor_set(x_203, 1, x_186); -return x_203; -} -else -{ -lean_object* x_204; -x_204 = lean_ctor_get(x_200, 1); -lean_inc(x_204); -if (lean_obj_tag(x_204) == 0) -{ -lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; uint8_t x_215; -x_205 = lean_ctor_get(x_199, 1); -lean_inc(x_205); -lean_dec(x_199); -x_206 = lean_ctor_get(x_200, 0); -lean_inc(x_206); -lean_dec(x_200); -x_207 = lean_unsigned_to_nat(0u); -x_208 = l_Lean_Expr_getAppNumArgsAux___main(x_187, x_207); -x_209 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_208); -x_210 = lean_mk_array(x_208, x_209); -x_211 = lean_unsigned_to_nat(1u); -x_212 = lean_nat_sub(x_208, x_211); -lean_dec(x_208); -x_213 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_187, x_210, x_212); -x_214 = lean_array_get_size(x_213); -x_215 = lean_nat_dec_eq(x_205, x_214); -lean_dec(x_214); -lean_dec(x_205); -if (x_215 == 0) -{ -lean_object* x_216; lean_object* x_217; lean_object* x_218; -lean_dec(x_213); -lean_dec(x_206); -lean_dec(x_193); -lean_dec(x_184); -lean_dec(x_5); -lean_dec(x_1); -x_216 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_216, 0, x_189); -lean_ctor_set(x_216, 1, x_190); -lean_ctor_set(x_216, 2, x_11); -x_217 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_217, 0, x_2); -lean_ctor_set(x_217, 1, x_3); -lean_ctor_set(x_217, 2, x_4); -lean_ctor_set(x_217, 3, x_216); -if (lean_is_scalar(x_188)) { - x_218 = lean_alloc_ctor(1, 2, 0); -} else { - x_218 = x_188; - lean_ctor_set_tag(x_218, 1); -} -lean_ctor_set(x_218, 0, x_217); -lean_ctor_set(x_218, 1, x_186); -return x_218; -} -else -{ -lean_object* x_219; -lean_inc(x_206); -lean_inc(x_189); -x_219 = lean_environment_find(x_189, x_206); -if (lean_obj_tag(x_219) == 0) -{ -lean_object* x_220; lean_object* x_221; lean_object* x_222; -lean_dec(x_213); -lean_dec(x_206); -lean_dec(x_193); -lean_dec(x_184); -lean_dec(x_5); -lean_dec(x_1); -x_220 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_220, 0, x_189); -lean_ctor_set(x_220, 1, x_190); -lean_ctor_set(x_220, 2, x_11); -x_221 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_221, 0, x_2); -lean_ctor_set(x_221, 1, x_3); -lean_ctor_set(x_221, 2, x_4); -lean_ctor_set(x_221, 3, x_220); -if (lean_is_scalar(x_188)) { - x_222 = lean_alloc_ctor(1, 2, 0); -} else { - x_222 = x_188; - lean_ctor_set_tag(x_222, 1); -} -lean_ctor_set(x_222, 0, x_221); -lean_ctor_set(x_222, 1, x_186); -return x_222; -} -else -{ -lean_object* x_223; lean_object* x_224; -lean_dec(x_219); -lean_dec(x_190); -lean_dec(x_189); -lean_dec(x_188); -x_223 = l_Lean_mkConst(x_206, x_193); -lean_inc(x_5); -lean_inc(x_1); -x_224 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__31(x_1, x_223, x_213, x_5, x_186); -if (lean_obj_tag(x_224) == 0) -{ -lean_object* x_225; lean_object* x_226; lean_object* x_227; -x_225 = lean_ctor_get(x_224, 0); -lean_inc(x_225); -x_226 = lean_ctor_get(x_224, 1); -lean_inc(x_226); -lean_dec(x_224); -lean_inc(x_4); -lean_inc_n(x_3, 2); -lean_inc(x_2); -lean_inc(x_1); -x_227 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33(x_1, x_2, x_3, x_4, x_3, x_3, x_225, x_5, x_226); -if (lean_obj_tag(x_227) == 0) -{ -lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_228 = lean_ctor_get(x_227, 0); -lean_inc(x_228); -x_229 = lean_ctor_get(x_227, 1); -lean_inc(x_229); -lean_dec(x_227); -x_230 = lean_apply_3(x_1, x_228, x_184, x_229); -if (lean_obj_tag(x_230) == 0) -{ -lean_object* x_231; -x_231 = lean_ctor_get(x_230, 0); -lean_inc(x_231); -if (lean_obj_tag(x_231) == 7) -{ -lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_232 = lean_ctor_get(x_230, 1); -lean_inc(x_232); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_233 = x_230; -} else { - lean_dec_ref(x_230); - x_233 = lean_box(0); -} -x_234 = lean_ctor_get(x_231, 1); -lean_inc(x_234); -lean_dec(x_231); -if (lean_is_scalar(x_233)) { - x_235 = lean_alloc_ctor(0, 2, 0); -} else { - x_235 = x_233; -} -lean_ctor_set(x_235, 0, x_234); -lean_ctor_set(x_235, 1, x_232); -return x_235; -} -else -{ -lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; -lean_dec(x_231); -x_236 = lean_ctor_get(x_230, 1); -lean_inc(x_236); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_237 = x_230; -} else { - lean_dec_ref(x_230); - x_237 = lean_box(0); -} -x_238 = lean_ctor_get(x_236, 0); -lean_inc(x_238); -x_239 = lean_ctor_get(x_236, 1); -lean_inc(x_239); -x_240 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_240, 0, x_238); -lean_ctor_set(x_240, 1, x_239); -lean_ctor_set(x_240, 2, x_11); -x_241 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_241, 0, x_2); -lean_ctor_set(x_241, 1, x_3); -lean_ctor_set(x_241, 2, x_4); -lean_ctor_set(x_241, 3, x_240); -if (lean_is_scalar(x_237)) { - x_242 = lean_alloc_ctor(1, 2, 0); -} else { - x_242 = x_237; - lean_ctor_set_tag(x_242, 1); -} -lean_ctor_set(x_242, 0, x_241); -lean_ctor_set(x_242, 1, x_236); -return x_242; -} -} -else -{ -lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_243 = lean_ctor_get(x_230, 0); -lean_inc(x_243); -x_244 = lean_ctor_get(x_230, 1); -lean_inc(x_244); -if (lean_is_exclusive(x_230)) { - lean_ctor_release(x_230, 0); - lean_ctor_release(x_230, 1); - x_245 = x_230; -} else { - lean_dec_ref(x_230); - x_245 = lean_box(0); -} -if (lean_is_scalar(x_245)) { - x_246 = lean_alloc_ctor(1, 2, 0); -} else { - x_246 = x_245; -} -lean_ctor_set(x_246, 0, x_243); -lean_ctor_set(x_246, 1, x_244); -return x_246; -} -} -else -{ -lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; -lean_dec(x_184); -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_247 = lean_ctor_get(x_227, 0); -lean_inc(x_247); -x_248 = lean_ctor_get(x_227, 1); -lean_inc(x_248); -if (lean_is_exclusive(x_227)) { - lean_ctor_release(x_227, 0); - lean_ctor_release(x_227, 1); - x_249 = x_227; -} else { - lean_dec_ref(x_227); - x_249 = lean_box(0); -} -if (lean_is_scalar(x_249)) { - x_250 = lean_alloc_ctor(1, 2, 0); -} else { - x_250 = x_249; -} -lean_ctor_set(x_250, 0, x_247); -lean_ctor_set(x_250, 1, x_248); -return x_250; -} -} -else -{ -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; -lean_dec(x_184); -lean_dec(x_11); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_251 = lean_ctor_get(x_224, 0); -lean_inc(x_251); -x_252 = lean_ctor_get(x_224, 1); -lean_inc(x_252); -if (lean_is_exclusive(x_224)) { - lean_ctor_release(x_224, 0); - lean_ctor_release(x_224, 1); - x_253 = x_224; -} else { - lean_dec_ref(x_224); - x_253 = lean_box(0); -} -if (lean_is_scalar(x_253)) { - x_254 = lean_alloc_ctor(1, 2, 0); -} else { - x_254 = x_253; -} -lean_ctor_set(x_254, 0, x_251); -lean_ctor_set(x_254, 1, x_252); -return x_254; -} -} -} -} -else -{ -lean_object* x_255; lean_object* x_256; lean_object* x_257; -lean_dec(x_204); -lean_dec(x_200); -lean_dec(x_199); -lean_dec(x_193); -lean_dec(x_187); -lean_dec(x_184); -lean_dec(x_5); -lean_dec(x_1); -x_255 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_255, 0, x_189); -lean_ctor_set(x_255, 1, x_190); -lean_ctor_set(x_255, 2, x_11); -x_256 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_256, 0, x_2); -lean_ctor_set(x_256, 1, x_3); -lean_ctor_set(x_256, 2, x_4); -lean_ctor_set(x_256, 3, x_255); -if (lean_is_scalar(x_188)) { - x_257 = lean_alloc_ctor(1, 2, 0); -} else { - x_257 = x_188; - lean_ctor_set_tag(x_257, 1); -} -lean_ctor_set(x_257, 0, x_256); -lean_ctor_set(x_257, 1, x_186); -return x_257; -} -} -} -else -{ -lean_object* x_258; lean_object* x_259; lean_object* x_260; -lean_dec(x_198); -lean_dec(x_193); -lean_dec(x_187); -lean_dec(x_184); -lean_dec(x_5); -lean_dec(x_1); -x_258 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_258, 0, x_189); -lean_ctor_set(x_258, 1, x_190); -lean_ctor_set(x_258, 2, x_11); -x_259 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_259, 0, x_2); -lean_ctor_set(x_259, 1, x_3); -lean_ctor_set(x_259, 2, x_4); -lean_ctor_set(x_259, 3, x_258); -if (lean_is_scalar(x_188)) { - x_260 = lean_alloc_ctor(1, 2, 0); -} else { - x_260 = x_188; - lean_ctor_set_tag(x_260, 1); -} -lean_ctor_set(x_260, 0, x_259); -lean_ctor_set(x_260, 1, x_186); -return x_260; -} -} -} -else -{ -lean_object* x_261; lean_object* x_262; lean_object* x_263; -lean_dec(x_191); -lean_dec(x_187); -lean_dec(x_184); -lean_dec(x_5); -lean_dec(x_1); -x_261 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_261, 0, x_189); -lean_ctor_set(x_261, 1, x_190); -lean_ctor_set(x_261, 2, x_11); -x_262 = lean_alloc_ctor(8, 4, 0); -lean_ctor_set(x_262, 0, x_2); -lean_ctor_set(x_262, 1, x_3); -lean_ctor_set(x_262, 2, x_4); -lean_ctor_set(x_262, 3, x_261); -if (lean_is_scalar(x_188)) { - x_263 = lean_alloc_ctor(1, 2, 0); -} else { - x_263 = x_188; - lean_ctor_set_tag(x_263, 1); -} -lean_ctor_set(x_263, 0, x_262); -lean_ctor_set(x_263, 1, x_186); -return x_263; -} -} -else -{ -lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; -lean_dec(x_184); -lean_dec(x_11); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_264 = lean_ctor_get(x_185, 0); -lean_inc(x_264); -x_265 = lean_ctor_get(x_185, 1); -lean_inc(x_265); -if (lean_is_exclusive(x_185)) { - lean_ctor_release(x_185, 0); - lean_ctor_release(x_185, 1); - x_266 = x_185; -} else { - lean_dec_ref(x_185); - x_266 = lean_box(0); -} -if (lean_is_scalar(x_266)) { - x_267 = lean_alloc_ctor(1, 2, 0); -} else { - x_267 = x_266; -} -lean_ctor_set(x_267, 0, x_264); -lean_ctor_set(x_267, 1, x_265); -return x_267; -} -} -} -else -{ -uint8_t x_268; -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_268 = !lean_is_exclusive(x_7); -if (x_268 == 0) -{ -return x_7; -} -else -{ -lean_object* x_269; lean_object* x_270; lean_object* x_271; -x_269 = lean_ctor_get(x_7, 0); -x_270 = lean_ctor_get(x_7, 1); -lean_inc(x_270); -lean_inc(x_269); -lean_dec(x_7); -x_271 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_271, 0, x_269); -lean_ctor_set(x_271, 1, x_270); -return x_271; -} -} -} -} -lean_object* l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; -switch (lean_obj_tag(x_2)) { -case 0: -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; -lean_dec(x_3); -lean_dec(x_1); -x_56 = lean_ctor_get(x_2, 0); -lean_inc(x_56); -lean_dec(x_2); -x_57 = lean_alloc_ctor(4, 1, 0); -lean_ctor_set(x_57, 0, x_56); -x_58 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_4); -return x_58; -} -case 1: -{ -lean_object* x_59; lean_object* x_60; -lean_dec(x_1); -x_59 = lean_ctor_get(x_2, 0); -lean_inc(x_59); -lean_dec(x_2); -x_60 = l___private_Init_Lean_Meta_InferType_8__inferFVarType(x_59, x_3, x_4); -return x_60; -} -case 2: -{ -lean_object* x_61; lean_object* x_62; -lean_dec(x_1); -x_61 = lean_ctor_get(x_2, 0); -lean_inc(x_61); -lean_dec(x_2); -x_62 = l___private_Init_Lean_Meta_InferType_7__inferMVarType(x_61, x_3, x_4); -lean_dec(x_3); -return x_62; -} -case 3: -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -lean_dec(x_3); -lean_dec(x_1); -x_63 = lean_ctor_get(x_2, 0); -lean_inc(x_63); -lean_dec(x_2); -x_64 = l_Lean_mkLevelSucc(x_63); -x_65 = l_Lean_mkSort(x_64); -x_66 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_66, 1, x_4); -return x_66; -} -case 4: -{ -lean_object* x_67; lean_object* x_68; lean_object* x_69; -lean_dec(x_1); -x_67 = lean_ctor_get(x_2, 0); -lean_inc(x_67); -x_68 = lean_ctor_get(x_2, 1); -lean_inc(x_68); -lean_dec(x_2); -x_69 = l___private_Init_Lean_Meta_InferType_2__inferConstType(x_67, x_68, x_3, x_4); -lean_dec(x_3); -return x_69; -} -case 5: -{ -lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_70 = lean_ctor_get(x_2, 0); -lean_inc(x_70); -x_71 = l_Lean_Expr_getAppFn___main(x_70); -lean_dec(x_70); -x_72 = lean_unsigned_to_nat(0u); -x_73 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_72); -x_74 = l_Lean_Expr_getAppArgs___closed__1; -lean_inc(x_73); -x_75 = lean_mk_array(x_73, x_74); -x_76 = lean_unsigned_to_nat(1u); -x_77 = lean_nat_sub(x_73, x_76); -lean_dec(x_73); -lean_inc(x_2); -x_78 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_75, x_77); -x_79 = lean_ctor_get(x_4, 2); -lean_inc(x_79); -x_80 = lean_ctor_get(x_79, 0); -lean_inc(x_80); -lean_dec(x_79); -x_81 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_80, x_2); -lean_dec(x_80); -if (lean_obj_tag(x_81) == 0) -{ -lean_object* x_82; -x_82 = l___private_Init_Lean_Meta_InferType_1__inferAppType___at_Lean_Meta_inferTypeAux___spec__13(x_1, x_71, x_78, x_3, x_4); -if (lean_obj_tag(x_82) == 0) -{ -lean_object* x_83; lean_object* x_84; uint8_t x_85; -x_83 = lean_ctor_get(x_82, 1); -lean_inc(x_83); -x_84 = lean_ctor_get(x_83, 2); -lean_inc(x_84); -x_85 = !lean_is_exclusive(x_82); -if (x_85 == 0) -{ -lean_object* x_86; lean_object* x_87; uint8_t x_88; -x_86 = lean_ctor_get(x_82, 0); -x_87 = lean_ctor_get(x_82, 1); -lean_dec(x_87); -x_88 = !lean_is_exclusive(x_83); -if (x_88 == 0) -{ -lean_object* x_89; uint8_t x_90; -x_89 = lean_ctor_get(x_83, 2); -lean_dec(x_89); -x_90 = !lean_is_exclusive(x_84); -if (x_90 == 0) -{ -lean_object* x_91; lean_object* x_92; -x_91 = lean_ctor_get(x_84, 0); -lean_inc(x_86); -x_92 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_91, x_2, x_86); -lean_ctor_set(x_84, 0, x_92); -return x_82; -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_93 = lean_ctor_get(x_84, 0); -x_94 = lean_ctor_get(x_84, 1); -lean_inc(x_94); -lean_inc(x_93); -lean_dec(x_84); -lean_inc(x_86); -x_95 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_93, x_2, x_86); -x_96 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_96, 0, x_95); -lean_ctor_set(x_96, 1, x_94); -lean_ctor_set(x_83, 2, x_96); -return x_82; -} -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_97 = lean_ctor_get(x_83, 0); -x_98 = lean_ctor_get(x_83, 1); -x_99 = lean_ctor_get(x_83, 3); -x_100 = lean_ctor_get(x_83, 4); -x_101 = lean_ctor_get(x_83, 5); -lean_inc(x_101); -lean_inc(x_100); -lean_inc(x_99); -lean_inc(x_98); -lean_inc(x_97); -lean_dec(x_83); -x_102 = lean_ctor_get(x_84, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_84, 1); -lean_inc(x_103); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_104 = x_84; -} else { - lean_dec_ref(x_84); - x_104 = lean_box(0); -} -lean_inc(x_86); -x_105 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_102, x_2, x_86); -if (lean_is_scalar(x_104)) { - x_106 = lean_alloc_ctor(0, 2, 0); -} else { - x_106 = x_104; -} -lean_ctor_set(x_106, 0, x_105); -lean_ctor_set(x_106, 1, x_103); -x_107 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_107, 0, x_97); -lean_ctor_set(x_107, 1, x_98); -lean_ctor_set(x_107, 2, x_106); -lean_ctor_set(x_107, 3, x_99); -lean_ctor_set(x_107, 4, x_100); -lean_ctor_set(x_107, 5, x_101); -lean_ctor_set(x_82, 1, x_107); -return x_82; -} -} -else -{ -lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_108 = lean_ctor_get(x_82, 0); -lean_inc(x_108); -lean_dec(x_82); -x_109 = lean_ctor_get(x_83, 0); -lean_inc(x_109); -x_110 = lean_ctor_get(x_83, 1); -lean_inc(x_110); -x_111 = lean_ctor_get(x_83, 3); -lean_inc(x_111); -x_112 = lean_ctor_get(x_83, 4); -lean_inc(x_112); -x_113 = lean_ctor_get(x_83, 5); -lean_inc(x_113); -if (lean_is_exclusive(x_83)) { - lean_ctor_release(x_83, 0); - lean_ctor_release(x_83, 1); - lean_ctor_release(x_83, 2); - lean_ctor_release(x_83, 3); - lean_ctor_release(x_83, 4); - lean_ctor_release(x_83, 5); - x_114 = x_83; -} else { - lean_dec_ref(x_83); - x_114 = lean_box(0); -} -x_115 = lean_ctor_get(x_84, 0); -lean_inc(x_115); -x_116 = lean_ctor_get(x_84, 1); -lean_inc(x_116); -if (lean_is_exclusive(x_84)) { - lean_ctor_release(x_84, 0); - lean_ctor_release(x_84, 1); - x_117 = x_84; -} else { - lean_dec_ref(x_84); - x_117 = lean_box(0); -} -lean_inc(x_108); -x_118 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_115, x_2, x_108); -if (lean_is_scalar(x_117)) { - x_119 = lean_alloc_ctor(0, 2, 0); -} else { - x_119 = x_117; -} -lean_ctor_set(x_119, 0, x_118); -lean_ctor_set(x_119, 1, x_116); -if (lean_is_scalar(x_114)) { - x_120 = lean_alloc_ctor(0, 6, 0); -} else { - x_120 = x_114; -} -lean_ctor_set(x_120, 0, x_109); -lean_ctor_set(x_120, 1, x_110); -lean_ctor_set(x_120, 2, x_119); -lean_ctor_set(x_120, 3, x_111); -lean_ctor_set(x_120, 4, x_112); -lean_ctor_set(x_120, 5, x_113); -x_121 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_121, 0, x_108); -lean_ctor_set(x_121, 1, x_120); -return x_121; -} -} -else -{ -uint8_t x_122; -lean_dec(x_2); -x_122 = !lean_is_exclusive(x_82); -if (x_122 == 0) -{ -return x_82; -} -else -{ -lean_object* x_123; lean_object* x_124; lean_object* x_125; -x_123 = lean_ctor_get(x_82, 0); -x_124 = lean_ctor_get(x_82, 1); -lean_inc(x_124); -lean_inc(x_123); -lean_dec(x_82); -x_125 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_125, 0, x_123); -lean_ctor_set(x_125, 1, x_124); -return x_125; -} -} -} -else -{ -lean_object* x_126; lean_object* x_127; -lean_dec(x_78); -lean_dec(x_71); -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_126 = lean_ctor_get(x_81, 0); -lean_inc(x_126); -lean_dec(x_81); -x_127 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_127, 0, x_126); -lean_ctor_set(x_127, 1, x_4); -return x_127; -} -} -case 7: -{ -lean_object* x_128; lean_object* x_129; lean_object* x_130; -x_128 = lean_ctor_get(x_4, 2); -lean_inc(x_128); -x_129 = lean_ctor_get(x_128, 0); -lean_inc(x_129); -lean_dec(x_128); -x_130 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_129, x_2); -lean_dec(x_129); -if (lean_obj_tag(x_130) == 0) -{ -lean_object* x_131; -lean_inc(x_2); -x_131 = l___private_Init_Lean_Meta_InferType_4__inferForallType___at_Lean_Meta_inferTypeAux___spec__15(x_1, x_2, x_3, x_4); -if (lean_obj_tag(x_131) == 0) -{ -lean_object* x_132; lean_object* x_133; uint8_t x_134; -x_132 = lean_ctor_get(x_131, 1); -lean_inc(x_132); -x_133 = lean_ctor_get(x_132, 2); -lean_inc(x_133); -x_134 = !lean_is_exclusive(x_131); -if (x_134 == 0) -{ -lean_object* x_135; lean_object* x_136; uint8_t x_137; -x_135 = lean_ctor_get(x_131, 0); -x_136 = lean_ctor_get(x_131, 1); -lean_dec(x_136); -x_137 = !lean_is_exclusive(x_132); -if (x_137 == 0) -{ -lean_object* x_138; uint8_t x_139; -x_138 = lean_ctor_get(x_132, 2); -lean_dec(x_138); -x_139 = !lean_is_exclusive(x_133); -if (x_139 == 0) -{ -lean_object* x_140; lean_object* x_141; -x_140 = lean_ctor_get(x_133, 0); -lean_inc(x_135); -x_141 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_140, x_2, x_135); -lean_ctor_set(x_133, 0, x_141); -return x_131; -} -else -{ -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; -x_142 = lean_ctor_get(x_133, 0); -x_143 = lean_ctor_get(x_133, 1); -lean_inc(x_143); -lean_inc(x_142); -lean_dec(x_133); -lean_inc(x_135); -x_144 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_142, x_2, x_135); -x_145 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_145, 0, x_144); -lean_ctor_set(x_145, 1, x_143); -lean_ctor_set(x_132, 2, x_145); -return x_131; -} -} -else -{ -lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; -x_146 = lean_ctor_get(x_132, 0); -x_147 = lean_ctor_get(x_132, 1); -x_148 = lean_ctor_get(x_132, 3); -x_149 = lean_ctor_get(x_132, 4); -x_150 = lean_ctor_get(x_132, 5); -lean_inc(x_150); -lean_inc(x_149); -lean_inc(x_148); -lean_inc(x_147); -lean_inc(x_146); -lean_dec(x_132); -x_151 = lean_ctor_get(x_133, 0); -lean_inc(x_151); -x_152 = lean_ctor_get(x_133, 1); -lean_inc(x_152); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - x_153 = x_133; -} else { - lean_dec_ref(x_133); - x_153 = lean_box(0); -} -lean_inc(x_135); -x_154 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_151, x_2, x_135); -if (lean_is_scalar(x_153)) { - x_155 = lean_alloc_ctor(0, 2, 0); -} else { - x_155 = x_153; -} -lean_ctor_set(x_155, 0, x_154); -lean_ctor_set(x_155, 1, x_152); -x_156 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_156, 0, x_146); -lean_ctor_set(x_156, 1, x_147); -lean_ctor_set(x_156, 2, x_155); -lean_ctor_set(x_156, 3, x_148); -lean_ctor_set(x_156, 4, x_149); -lean_ctor_set(x_156, 5, x_150); -lean_ctor_set(x_131, 1, x_156); -return x_131; -} -} -else -{ -lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; -x_157 = lean_ctor_get(x_131, 0); -lean_inc(x_157); -lean_dec(x_131); -x_158 = lean_ctor_get(x_132, 0); -lean_inc(x_158); -x_159 = lean_ctor_get(x_132, 1); -lean_inc(x_159); -x_160 = lean_ctor_get(x_132, 3); -lean_inc(x_160); -x_161 = lean_ctor_get(x_132, 4); -lean_inc(x_161); -x_162 = lean_ctor_get(x_132, 5); -lean_inc(x_162); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - lean_ctor_release(x_132, 2); - lean_ctor_release(x_132, 3); - lean_ctor_release(x_132, 4); - lean_ctor_release(x_132, 5); - x_163 = x_132; -} else { - lean_dec_ref(x_132); - x_163 = lean_box(0); -} -x_164 = lean_ctor_get(x_133, 0); -lean_inc(x_164); -x_165 = lean_ctor_get(x_133, 1); -lean_inc(x_165); -if (lean_is_exclusive(x_133)) { - lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - x_166 = x_133; -} else { - lean_dec_ref(x_133); - x_166 = lean_box(0); -} -lean_inc(x_157); -x_167 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_164, x_2, x_157); -if (lean_is_scalar(x_166)) { - x_168 = lean_alloc_ctor(0, 2, 0); -} else { - x_168 = x_166; -} -lean_ctor_set(x_168, 0, x_167); -lean_ctor_set(x_168, 1, x_165); -if (lean_is_scalar(x_163)) { - x_169 = lean_alloc_ctor(0, 6, 0); -} else { - x_169 = x_163; -} -lean_ctor_set(x_169, 0, x_158); -lean_ctor_set(x_169, 1, x_159); -lean_ctor_set(x_169, 2, x_168); -lean_ctor_set(x_169, 3, x_160); -lean_ctor_set(x_169, 4, x_161); -lean_ctor_set(x_169, 5, x_162); -x_170 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_170, 0, x_157); -lean_ctor_set(x_170, 1, x_169); -return x_170; -} -} -else -{ -uint8_t x_171; -lean_dec(x_2); -x_171 = !lean_is_exclusive(x_131); -if (x_171 == 0) -{ -return x_131; -} -else -{ -lean_object* x_172; lean_object* x_173; lean_object* x_174; -x_172 = lean_ctor_get(x_131, 0); -x_173 = lean_ctor_get(x_131, 1); -lean_inc(x_173); -lean_inc(x_172); -lean_dec(x_131); -x_174 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_174, 0, x_172); -lean_ctor_set(x_174, 1, x_173); -return x_174; -} -} -} -else -{ -lean_object* x_175; lean_object* x_176; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_175 = lean_ctor_get(x_130, 0); -lean_inc(x_175); -lean_dec(x_130); -x_176 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_176, 0, x_175); -lean_ctor_set(x_176, 1, x_4); -return x_176; -} -} -case 9: -{ -lean_object* x_177; lean_object* x_178; lean_object* x_179; -lean_dec(x_3); -lean_dec(x_1); -x_177 = lean_ctor_get(x_2, 0); -lean_inc(x_177); -lean_dec(x_2); -x_178 = l_Lean_Literal_type(x_177); -lean_dec(x_177); -x_179 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_179, 0, x_178); -lean_ctor_set(x_179, 1, x_4); -return x_179; -} -case 10: -{ -lean_object* x_180; -x_180 = lean_ctor_get(x_2, 1); -lean_inc(x_180); -lean_dec(x_2); -x_2 = x_180; -goto _start; -} -case 11: -{ -lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; -x_182 = lean_ctor_get(x_2, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_2, 1); -lean_inc(x_183); -x_184 = lean_ctor_get(x_2, 2); -lean_inc(x_184); -x_185 = lean_ctor_get(x_4, 2); +lean_object* x_185; lean_object* x_186; lean_object* x_187; +x_185 = lean_ctor_get(x_3, 2); lean_inc(x_185); x_186 = lean_ctor_get(x_185, 0); lean_inc(x_186); lean_dec(x_185); -x_187 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_186, x_2); +x_187 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_186, x_1); lean_dec(x_186); if (lean_obj_tag(x_187) == 0) { lean_object* x_188; -x_188 = l___private_Init_Lean_Meta_InferType_3__inferProjType___at_Lean_Meta_inferTypeAux___spec__30(x_1, x_182, x_183, x_184, x_3, x_4); +lean_inc(x_1); +x_188 = l_Lean_Meta_lambdaTelescope___at___private_Init_Lean_Meta_InferType_5__inferLambdaType___spec__1(x_1, x_2, x_3); if (lean_obj_tag(x_188) == 0) { lean_object* x_189; lean_object* x_190; uint8_t x_191; @@ -15866,7 +6462,7 @@ if (x_196 == 0) lean_object* x_197; lean_object* x_198; x_197 = lean_ctor_get(x_190, 0); lean_inc(x_192); -x_198 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_197, x_2, x_192); +x_198 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_197, x_1, x_192); lean_ctor_set(x_190, 0, x_198); return x_188; } @@ -15879,7 +6475,7 @@ lean_inc(x_200); lean_inc(x_199); lean_dec(x_190); lean_inc(x_192); -x_201 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_199, x_2, x_192); +x_201 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_199, x_1, x_192); x_202 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_202, 0, x_201); lean_ctor_set(x_202, 1, x_200); @@ -15914,7 +6510,7 @@ if (lean_is_exclusive(x_190)) { x_210 = lean_box(0); } lean_inc(x_192); -x_211 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_208, x_2, x_192); +x_211 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_208, x_1, x_192); if (lean_is_scalar(x_210)) { x_212 = lean_alloc_ctor(0, 2, 0); } else { @@ -15974,7 +6570,7 @@ if (lean_is_exclusive(x_190)) { x_223 = lean_box(0); } lean_inc(x_214); -x_224 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_221, x_2, x_214); +x_224 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_221, x_1, x_214); if (lean_is_scalar(x_223)) { x_225 = lean_alloc_ctor(0, 2, 0); } else { @@ -16002,7 +6598,7 @@ return x_227; else { uint8_t x_228; -lean_dec(x_2); +lean_dec(x_1); x_228 = !lean_is_exclusive(x_188); if (x_228 == 0) { @@ -16026,10 +6622,6 @@ return x_231; else { lean_object* x_232; lean_object* x_233; -lean_dec(x_184); -lean_dec(x_183); -lean_dec(x_182); -lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); x_232 = lean_ctor_get(x_187, 0); @@ -16037,460 +6629,129 @@ lean_inc(x_232); lean_dec(x_187); x_233 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_233, 0, x_232); -lean_ctor_set(x_233, 1, x_4); +lean_ctor_set(x_233, 1, x_3); return x_233; } } -case 12: -{ -lean_object* x_234; lean_object* x_235; lean_object* x_236; -lean_dec(x_2); -lean_dec(x_1); -x_234 = l_Lean_Meta_isClassQuick___main___closed__1; -x_235 = l_unreachable_x21___rarg(x_234); -x_236 = lean_apply_2(x_235, x_3, x_4); -return x_236; -} -default: -{ -lean_object* x_237; -x_237 = lean_box(0); -x_5 = x_237; -goto block_55; -} -} -block_55: -{ -lean_object* x_6; lean_object* x_7; lean_object* x_8; -lean_dec(x_5); -x_6 = lean_ctor_get(x_4, 2); -lean_inc(x_6); -x_7 = lean_ctor_get(x_6, 0); -lean_inc(x_7); -lean_dec(x_6); -x_8 = l_PersistentHashMap_find___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__1(x_7, x_2); -lean_dec(x_7); -if (lean_obj_tag(x_8) == 0) -{ -lean_object* x_9; -lean_inc(x_2); -x_9 = l_Lean_Meta_lambdaTelescope___at_Lean_Meta_inferTypeAux___spec__3(x_1, x_2, x_3, x_4); -if (lean_obj_tag(x_9) == 0) -{ -lean_object* x_10; lean_object* x_11; uint8_t x_12; -x_10 = lean_ctor_get(x_9, 1); -lean_inc(x_10); -x_11 = lean_ctor_get(x_10, 2); -lean_inc(x_11); -x_12 = !lean_is_exclusive(x_9); -if (x_12 == 0) -{ -lean_object* x_13; lean_object* x_14; uint8_t x_15; -x_13 = lean_ctor_get(x_9, 0); -x_14 = lean_ctor_get(x_9, 1); -lean_dec(x_14); -x_15 = !lean_is_exclusive(x_10); -if (x_15 == 0) -{ -lean_object* x_16; uint8_t x_17; -x_16 = lean_ctor_get(x_10, 2); -lean_dec(x_16); -x_17 = !lean_is_exclusive(x_11); -if (x_17 == 0) -{ -lean_object* x_18; lean_object* x_19; -x_18 = lean_ctor_get(x_11, 0); -lean_inc(x_13); -x_19 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_18, x_2, x_13); -lean_ctor_set(x_11, 0, x_19); -return x_9; -} -else -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_11, 0); -x_21 = lean_ctor_get(x_11, 1); -lean_inc(x_21); -lean_inc(x_20); -lean_dec(x_11); -lean_inc(x_13); -x_22 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_20, x_2, x_13); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_21); -lean_ctor_set(x_10, 2, x_23); -return x_9; -} -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; -x_24 = lean_ctor_get(x_10, 0); -x_25 = lean_ctor_get(x_10, 1); -x_26 = lean_ctor_get(x_10, 3); -x_27 = lean_ctor_get(x_10, 4); -x_28 = lean_ctor_get(x_10, 5); -lean_inc(x_28); -lean_inc(x_27); -lean_inc(x_26); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_10); -x_29 = lean_ctor_get(x_11, 0); -lean_inc(x_29); -x_30 = lean_ctor_get(x_11, 1); -lean_inc(x_30); -if (lean_is_exclusive(x_11)) { - lean_ctor_release(x_11, 0); - lean_ctor_release(x_11, 1); - x_31 = x_11; -} else { - lean_dec_ref(x_11); - x_31 = lean_box(0); -} -lean_inc(x_13); -x_32 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_29, x_2, x_13); -if (lean_is_scalar(x_31)) { - x_33 = lean_alloc_ctor(0, 2, 0); -} else { - x_33 = x_31; -} -lean_ctor_set(x_33, 0, x_32); -lean_ctor_set(x_33, 1, x_30); -x_34 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_34, 0, x_24); -lean_ctor_set(x_34, 1, x_25); -lean_ctor_set(x_34, 2, x_33); -lean_ctor_set(x_34, 3, x_26); -lean_ctor_set(x_34, 4, x_27); -lean_ctor_set(x_34, 5, x_28); -lean_ctor_set(x_9, 1, x_34); -return x_9; -} -} -else -{ -lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; -x_35 = lean_ctor_get(x_9, 0); -lean_inc(x_35); -lean_dec(x_9); -x_36 = lean_ctor_get(x_10, 0); -lean_inc(x_36); -x_37 = lean_ctor_get(x_10, 1); -lean_inc(x_37); -x_38 = lean_ctor_get(x_10, 3); -lean_inc(x_38); -x_39 = lean_ctor_get(x_10, 4); -lean_inc(x_39); -x_40 = lean_ctor_get(x_10, 5); -lean_inc(x_40); -if (lean_is_exclusive(x_10)) { - lean_ctor_release(x_10, 0); - lean_ctor_release(x_10, 1); - lean_ctor_release(x_10, 2); - lean_ctor_release(x_10, 3); - lean_ctor_release(x_10, 4); - lean_ctor_release(x_10, 5); - x_41 = x_10; -} else { - lean_dec_ref(x_10); - x_41 = lean_box(0); -} -x_42 = lean_ctor_get(x_11, 0); -lean_inc(x_42); -x_43 = lean_ctor_get(x_11, 1); -lean_inc(x_43); -if (lean_is_exclusive(x_11)) { - lean_ctor_release(x_11, 0); - lean_ctor_release(x_11, 1); - x_44 = x_11; -} else { - lean_dec_ref(x_11); - x_44 = lean_box(0); -} -lean_inc(x_35); -x_45 = l_PersistentHashMap_insert___at___private_Init_Lean_Meta_InferType_9__checkInferTypeCache___spec__4(x_42, x_2, x_35); -if (lean_is_scalar(x_44)) { - x_46 = lean_alloc_ctor(0, 2, 0); -} else { - x_46 = x_44; -} -lean_ctor_set(x_46, 0, x_45); -lean_ctor_set(x_46, 1, x_43); -if (lean_is_scalar(x_41)) { - x_47 = lean_alloc_ctor(0, 6, 0); -} else { - x_47 = x_41; -} -lean_ctor_set(x_47, 0, x_36); -lean_ctor_set(x_47, 1, x_37); -lean_ctor_set(x_47, 2, x_46); -lean_ctor_set(x_47, 3, x_38); -lean_ctor_set(x_47, 4, x_39); -lean_ctor_set(x_47, 5, x_40); -x_48 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_48, 0, x_35); -lean_ctor_set(x_48, 1, x_47); -return x_48; -} -} -else -{ -uint8_t x_49; -lean_dec(x_2); -x_49 = !lean_is_exclusive(x_9); -if (x_49 == 0) -{ -return x_9; -} -else -{ -lean_object* x_50; lean_object* x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_9, 0); -x_51 = lean_ctor_get(x_9, 1); -lean_inc(x_51); -lean_inc(x_50); -lean_dec(x_9); -x_52 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_52, 0, x_50); -lean_ctor_set(x_52, 1, x_51); -return x_52; } } } -else -{ -lean_object* x_53; lean_object* x_54; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_53 = lean_ctor_get(x_8, 0); -lean_inc(x_53); -lean_dec(x_8); -x_54 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_54, 0, x_53); -lean_ctor_set(x_54, 1, x_4); -return x_54; -} -} -} -} -lean_object* l_Lean_Meta_inferTypeAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_10__inferTypeAux(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_5; -x_5 = l_Lean_Meta_inferTypeAuxAux___main___at_Lean_Meta_inferTypeAux___spec__1(x_1, x_2, x_3, x_4); -return x_5; +lean_object* x_4; +x_4 = l___private_Init_Lean_Meta_InferType_10__inferTypeAux___main(x_1, x_2, x_3); +return x_4; } } -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__9___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Lean_Meta_inferTypeImpl(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__9(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -lean_dec(x_2); -return x_7; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: +uint8_t x_4; +x_4 = !lean_is_exclusive(x_2); +if (x_4 == 0) { -uint8_t x_11; lean_object* x_12; -x_11 = lean_unbox(x_3); -lean_dec(x_3); -x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___lambda__1(x_1, x_2, x_11, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -lean_dec(x_1); -return x_12; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { -_start: +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_2, 0); +x_6 = !lean_is_exclusive(x_5); +if (x_6 == 0) { -uint8_t x_14; lean_object* x_15; -x_14 = lean_unbox(x_2); -lean_dec(x_2); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__10(x_1, x_14, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); -lean_dec(x_10); -lean_dec(x_7); -lean_dec(x_6); -return x_15; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__11___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__11(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -lean_dec(x_2); -return x_7; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_2); -lean_dec(x_2); -x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__8(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__12___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7) { -_start: -{ -lean_object* x_8; -x_8 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__12(x_1, x_2, x_3, x_4, x_5, x_6, x_7); -lean_dec(x_4); +uint8_t x_7; lean_object* x_8; +x_7 = 1; +lean_ctor_set_uint8(x_5, sizeof(void*)*1 + 5, x_7); +x_8 = l___private_Init_Lean_Meta_InferType_10__inferTypeAux___main(x_1, x_2, x_3); return x_8; } -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__14___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: +else { -lean_object* x_9; -x_9 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__14(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -return x_9; -} -} -lean_object* l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l___private_Init_Data_Array_Basic_3__iterateRevMAux___main___at_Lean_Meta_inferTypeAux___spec__18(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_3); -lean_dec(x_2); -return x_9; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__23___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__23(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -lean_dec(x_2); -return x_7; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { -_start: -{ -uint8_t x_11; lean_object* x_12; -x_11 = lean_unbox(x_3); -lean_dec(x_3); -x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___lambda__1(x_1, x_2, x_11, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -lean_dec(x_1); -return x_12; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { -_start: -{ -uint8_t x_14; lean_object* x_15; -x_14 = lean_unbox(x_2); -lean_dec(x_2); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__24(x_1, x_14, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); -lean_dec(x_10); -lean_dec(x_7); -lean_dec(x_6); -return x_15; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__25___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { -_start: -{ -lean_object* x_7; -x_7 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__25(x_1, x_2, x_3, x_4, x_5, x_6); -lean_dec(x_3); -lean_dec(x_2); -return x_7; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_2); -lean_dec(x_2); -x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__22(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_11; -} -} -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__27___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__27(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_object* x_9; uint8_t x_10; uint8_t x_11; uint8_t x_12; uint8_t x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; lean_object* x_17; +x_9 = lean_ctor_get(x_5, 0); +x_10 = lean_ctor_get_uint8(x_5, sizeof(void*)*1); +x_11 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 1); +x_12 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 2); +x_13 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 3); +x_14 = lean_ctor_get_uint8(x_5, sizeof(void*)*1 + 4); +lean_inc(x_9); lean_dec(x_5); +x_15 = 1; +x_16 = lean_alloc_ctor(0, 1, 6); +lean_ctor_set(x_16, 0, x_9); +lean_ctor_set_uint8(x_16, sizeof(void*)*1, x_10); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 1, x_11); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 2, x_12); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 3, x_13); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 4, x_14); +lean_ctor_set_uint8(x_16, sizeof(void*)*1 + 5, x_15); +lean_ctor_set(x_2, 0, x_16); +x_17 = l___private_Init_Lean_Meta_InferType_10__inferTypeAux___main(x_1, x_2, x_3); +return x_17; +} +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; uint8_t x_24; uint8_t x_25; uint8_t x_26; lean_object* x_27; uint8_t x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_18 = lean_ctor_get(x_2, 0); +x_19 = lean_ctor_get(x_2, 1); +x_20 = lean_ctor_get(x_2, 2); +lean_inc(x_20); +lean_inc(x_19); +lean_inc(x_18); lean_dec(x_2); -return x_9; +x_21 = lean_ctor_get(x_18, 0); +lean_inc(x_21); +x_22 = lean_ctor_get_uint8(x_18, sizeof(void*)*1); +x_23 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 1); +x_24 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 2); +x_25 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 3); +x_26 = lean_ctor_get_uint8(x_18, sizeof(void*)*1 + 4); +if (lean_is_exclusive(x_18)) { + lean_ctor_release(x_18, 0); + x_27 = x_18; +} else { + lean_dec_ref(x_18); + x_27 = lean_box(0); +} +x_28 = 1; +if (lean_is_scalar(x_27)) { + x_29 = lean_alloc_ctor(0, 1, 6); +} else { + x_29 = x_27; +} +lean_ctor_set(x_29, 0, x_21); +lean_ctor_set_uint8(x_29, sizeof(void*)*1, x_22); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 1, x_23); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 2, x_24); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 3, x_25); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 4, x_26); +lean_ctor_set_uint8(x_29, sizeof(void*)*1 + 5, x_28); +x_30 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_19); +lean_ctor_set(x_30, 2, x_20); +x_31 = l___private_Init_Lean_Meta_InferType_10__inferTypeAux___main(x_1, x_30, x_3); +return x_31; } } -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +} +lean_object* _init_l_Lean_Meta_setInferTypeRef___closed__1() { _start: { -uint8_t x_11; lean_object* x_12; -x_11 = lean_unbox(x_5); -lean_dec(x_5); -x_12 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___lambda__1(x_1, x_2, x_3, x_4, x_11, x_6, x_7, x_8, x_9, x_10); -return x_12; +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_inferTypeImpl), 3, 0); +return x_1; } } -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +lean_object* l_Lean_Meta_setInferTypeRef(lean_object* x_1) { _start: { -uint8_t x_14; lean_object* x_15; -x_14 = lean_unbox(x_2); -lean_dec(x_2); -x_15 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__28(x_1, x_14, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); -lean_dec(x_10); -lean_dec(x_7); -lean_dec(x_6); -return x_15; +lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_2 = l_Lean_Meta_inferTypeRef; +x_3 = l_Lean_Meta_setInferTypeRef___closed__1; +x_4 = lean_io_ref_set(x_2, x_3, x_1); +return x_4; } } -lean_object* l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__29___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Lean_Meta_withNewLocalInstances___main___at_Lean_Meta_inferTypeAux___spec__29(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_5); -lean_dec(x_2); -return x_9; -} -} -lean_object* l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__26___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -uint8_t x_10; lean_object* x_11; -x_10 = lean_unbox(x_2); -lean_dec(x_2); -x_11 = l___private_Init_Lean_Meta_Basic_5__forallTelescopeReducingAuxAux___main___at_Lean_Meta_inferTypeAux___spec__26(x_1, x_10, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -return x_11; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__32___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { -_start: -{ -lean_object* x_9; -x_9 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__32(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); -lean_dec(x_4); -return x_9; -} -} -lean_object* l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { -_start: -{ -lean_object* x_10; -x_10 = l_Nat_foldMAux___main___at_Lean_Meta_inferTypeAux___spec__33(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9); -lean_dec(x_5); -return x_10; -} -} -uint8_t l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(lean_object* x_1) { +uint8_t l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(lean_object* x_1) { _start: { switch (lean_obj_tag(x_1)) { @@ -16505,7 +6766,7 @@ case 2: lean_object* x_3; lean_object* x_4; uint8_t x_5; x_3 = lean_ctor_get(x_1, 0); x_4 = lean_ctor_get(x_1, 1); -x_5 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_3); +x_5 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(x_3); if (x_5 == 0) { uint8_t x_6; @@ -16534,35 +6795,35 @@ return x_10; } } } -lean_object* l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main___boxed(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main___boxed(lean_object* x_1) { _start: { uint8_t x_2; lean_object* x_3; -x_2 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_1); +x_2 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(x_1); lean_dec(x_1); x_3 = lean_box(x_2); return x_3; } } -uint8_t l___private_Init_Lean_Meta_InferType_10__isAlwaysZero(lean_object* x_1) { +uint8_t l___private_Init_Lean_Meta_InferType_11__isAlwaysZero(lean_object* x_1) { _start: { uint8_t x_2; -x_2 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_1); +x_2 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(x_1); return x_2; } } -lean_object* l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___boxed(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___boxed(lean_object* x_1) { _start: { uint8_t x_2; lean_object* x_3; -x_2 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero(x_1); +x_2 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero(x_1); lean_dec(x_1); x_3 = lean_box(x_2); return x_3; } } -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { switch (lean_obj_tag(x_1)) { @@ -16595,7 +6856,7 @@ if (x_12 == 0) { lean_object* x_13; uint8_t x_14; uint8_t x_15; lean_object* x_16; x_13 = lean_ctor_get(x_11, 0); -x_14 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_13); +x_14 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(x_13); lean_dec(x_13); x_15 = l_Bool_toLBool(x_14); x_16 = lean_box(x_15); @@ -16610,7 +6871,7 @@ x_18 = lean_ctor_get(x_11, 1); lean_inc(x_18); lean_inc(x_17); lean_dec(x_11); -x_19 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_17); +x_19 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(x_17); lean_dec(x_17); x_20 = l_Bool_toLBool(x_19); x_21 = lean_box(x_20); @@ -16685,33 +6946,33 @@ return x_38; } } } -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_1, x_2, x_3, x_4); lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_1, x_2, x_3, x_4); return x_5; } } -lean_object* l___private_Init_Lean_Meta_InferType_11__isArrowProp___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_12__isArrowProp___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_InferType_11__isArrowProp(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_InferType_12__isArrowProp(x_1, x_2, x_3, x_4); lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_InferType_12__isPropQuickApp___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuickApp___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { switch (lean_obj_tag(x_1)) { @@ -16731,7 +6992,7 @@ lean_inc(x_7); x_8 = lean_ctor_get(x_6, 1); lean_inc(x_8); lean_dec(x_6); -x_9 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_7, x_2, x_3, x_8); +x_9 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_7, x_2, x_3, x_8); lean_dec(x_3); return x_9; } @@ -16775,7 +7036,7 @@ lean_inc(x_16); x_17 = lean_ctor_get(x_15, 1); lean_inc(x_17); lean_dec(x_15); -x_18 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_16, x_2, x_3, x_17); +x_18 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_16, x_2, x_3, x_17); lean_dec(x_3); return x_18; } @@ -16821,7 +7082,7 @@ lean_inc(x_26); x_27 = lean_ctor_get(x_25, 1); lean_inc(x_27); lean_dec(x_25); -x_28 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_26, x_2, x_3, x_27); +x_28 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_26, x_2, x_3, x_27); lean_dec(x_3); return x_28; } @@ -16929,15 +7190,15 @@ return x_52; } } } -lean_object* l___private_Init_Lean_Meta_InferType_12__isPropQuickApp(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuickApp(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_InferType_12__isPropQuickApp___main(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Meta_InferType_13__isPropQuickApp___main(x_1, x_2, x_3, x_4); return x_5; } } -lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuick___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_InferType_14__isPropQuick___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { switch (lean_obj_tag(x_1)) { @@ -16970,7 +7231,7 @@ x_10 = lean_ctor_get(x_8, 1); lean_inc(x_10); lean_dec(x_8); x_11 = lean_unsigned_to_nat(0u); -x_12 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_9, x_11, x_2, x_10); +x_12 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_9, x_11, x_2, x_10); lean_dec(x_2); return x_12; } @@ -17014,7 +7275,7 @@ x_20 = lean_ctor_get(x_18, 1); lean_inc(x_20); lean_dec(x_18); x_21 = lean_unsigned_to_nat(0u); -x_22 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_19, x_21, x_2, x_20); +x_22 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_19, x_21, x_2, x_20); lean_dec(x_2); return x_22; } @@ -17060,7 +7321,7 @@ x_31 = lean_ctor_get(x_29, 1); lean_inc(x_31); lean_dec(x_29); x_32 = lean_unsigned_to_nat(0u); -x_33 = l___private_Init_Lean_Meta_InferType_11__isArrowProp___main(x_30, x_32, x_2, x_31); +x_33 = l___private_Init_Lean_Meta_InferType_12__isArrowProp___main(x_30, x_32, x_2, x_31); lean_dec(x_2); return x_33; } @@ -17095,7 +7356,7 @@ x_38 = lean_ctor_get(x_1, 0); lean_inc(x_38); lean_dec(x_1); x_39 = lean_unsigned_to_nat(1u); -x_40 = l___private_Init_Lean_Meta_InferType_12__isPropQuickApp___main(x_38, x_39, x_2, x_3); +x_40 = l___private_Init_Lean_Meta_InferType_13__isPropQuickApp___main(x_38, x_39, x_2, x_3); return x_40; } case 7: @@ -17161,164 +7422,174 @@ return x_55; } } } -lean_object* l___private_Init_Lean_Meta_InferType_13__isPropQuick(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_InferType_14__isPropQuick(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l___private_Init_Lean_Meta_InferType_13__isPropQuick___main(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Meta_InferType_14__isPropQuick___main(x_1, x_2, x_3); return x_4; } } -lean_object* l_Lean_Meta_isPropAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isProp(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { -lean_object* x_5; -lean_inc(x_3); +lean_object* x_4; lean_inc(x_2); -x_5 = l___private_Init_Lean_Meta_InferType_13__isPropQuick___main(x_2, x_3, x_4); -if (lean_obj_tag(x_5) == 0) +lean_inc(x_1); +x_4 = l___private_Init_Lean_Meta_InferType_14__isPropQuick___main(x_1, x_2, x_3); +if (lean_obj_tag(x_4) == 0) { -lean_object* x_6; uint8_t x_7; -x_6 = lean_ctor_get(x_5, 0); -lean_inc(x_6); -x_7 = lean_unbox(x_6); -lean_dec(x_6); -switch (x_7) { +lean_object* x_5; uint8_t x_6; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = lean_unbox(x_5); +lean_dec(x_5); +switch (x_6) { case 0: { -uint8_t x_8; -lean_dec(x_3); +uint8_t x_7; lean_dec(x_2); lean_dec(x_1); -x_8 = !lean_is_exclusive(x_5); -if (x_8 == 0) +x_7 = !lean_is_exclusive(x_4); +if (x_7 == 0) { -lean_object* x_9; uint8_t x_10; lean_object* x_11; -x_9 = lean_ctor_get(x_5, 0); -lean_dec(x_9); -x_10 = 0; -x_11 = lean_box(x_10); -lean_ctor_set(x_5, 0, x_11); -return x_5; +lean_object* x_8; uint8_t x_9; lean_object* x_10; +x_8 = lean_ctor_get(x_4, 0); +lean_dec(x_8); +x_9 = 0; +x_10 = lean_box(x_9); +lean_ctor_set(x_4, 0, x_10); +return x_4; } else { -lean_object* x_12; uint8_t x_13; lean_object* x_14; lean_object* x_15; -x_12 = lean_ctor_get(x_5, 1); -lean_inc(x_12); -lean_dec(x_5); -x_13 = 0; -x_14 = lean_box(x_13); -x_15 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_15, 0, x_14); -lean_ctor_set(x_15, 1, x_12); -return x_15; +lean_object* x_11; uint8_t x_12; lean_object* x_13; lean_object* x_14; +x_11 = lean_ctor_get(x_4, 1); +lean_inc(x_11); +lean_dec(x_4); +x_12 = 0; +x_13 = lean_box(x_12); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_11); +return x_14; } } case 1: { -uint8_t x_16; -lean_dec(x_3); +uint8_t x_15; lean_dec(x_2); lean_dec(x_1); -x_16 = !lean_is_exclusive(x_5); -if (x_16 == 0) +x_15 = !lean_is_exclusive(x_4); +if (x_15 == 0) { -lean_object* x_17; uint8_t x_18; lean_object* x_19; -x_17 = lean_ctor_get(x_5, 0); -lean_dec(x_17); -x_18 = 1; -x_19 = lean_box(x_18); -lean_ctor_set(x_5, 0, x_19); -return x_5; +lean_object* x_16; uint8_t x_17; lean_object* x_18; +x_16 = lean_ctor_get(x_4, 0); +lean_dec(x_16); +x_17 = 1; +x_18 = lean_box(x_17); +lean_ctor_set(x_4, 0, x_18); +return x_4; } else { -lean_object* x_20; uint8_t x_21; lean_object* x_22; lean_object* x_23; -x_20 = lean_ctor_get(x_5, 1); -lean_inc(x_20); -lean_dec(x_5); -x_21 = 1; -x_22 = lean_box(x_21); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_22); -lean_ctor_set(x_23, 1, x_20); -return x_23; +lean_object* x_19; uint8_t x_20; lean_object* x_21; lean_object* x_22; +x_19 = lean_ctor_get(x_4, 1); +lean_inc(x_19); +lean_dec(x_4); +x_20 = 1; +x_21 = lean_box(x_20); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_19); +return x_22; } } default: { -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_5, 1); -lean_inc(x_24); -lean_dec(x_5); -lean_inc(x_1); -x_25 = lean_alloc_closure((void*)(l_Lean_Meta_usingDefault), 4, 1); -lean_closure_set(x_25, 0, x_1); -lean_inc(x_3); -x_26 = l_Lean_Meta_inferTypeAuxAux___main(x_25, x_2, x_3, x_24); -if (lean_obj_tag(x_26) == 0) +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_4, 1); +lean_inc(x_23); +lean_dec(x_4); +lean_inc(x_2); +x_24 = l_Lean_Meta_inferType(x_1, x_2, x_23); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; -x_27 = lean_ctor_get(x_3, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_26, 0); +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_24, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_24, 1); +lean_inc(x_26); +lean_dec(x_24); +lean_inc(x_2); +x_27 = l_Lean_Meta_whnfUsingDefault(x_25, x_2, x_26); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; +x_28 = lean_ctor_get(x_27, 0); lean_inc(x_28); -x_29 = lean_ctor_get(x_26, 1); +if (lean_obj_tag(x_28) == 3) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; uint8_t x_32; +x_29 = lean_ctor_get(x_27, 1); lean_inc(x_29); -lean_dec(x_26); -x_30 = lean_ctor_get(x_3, 1); +lean_dec(x_27); +x_30 = lean_ctor_get(x_28, 0); lean_inc(x_30); -x_31 = lean_ctor_get(x_3, 2); -lean_inc(x_31); -x_32 = !lean_is_exclusive(x_27); +lean_dec(x_28); +x_31 = l_Lean_Meta_instantiateLevelMVars(x_30, x_2, x_29); +lean_dec(x_2); +x_32 = !lean_is_exclusive(x_31); if (x_32 == 0) { -uint8_t x_33; lean_object* x_34; lean_object* x_35; -x_33 = 1; -lean_ctor_set_uint8(x_27, sizeof(void*)*1 + 4, x_33); -x_34 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_34, 0, x_27); -lean_ctor_set(x_34, 1, x_30); -lean_ctor_set(x_34, 2, x_31); -x_35 = lean_apply_3(x_1, x_28, x_34, x_29); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; -x_36 = lean_ctor_get(x_35, 0); -lean_inc(x_36); -if (lean_obj_tag(x_36) == 3) -{ -lean_object* x_37; lean_object* x_38; lean_object* x_39; uint8_t x_40; -x_37 = lean_ctor_get(x_35, 1); -lean_inc(x_37); -lean_dec(x_35); -x_38 = lean_ctor_get(x_36, 0); -lean_inc(x_38); -lean_dec(x_36); -x_39 = l_Lean_Meta_instantiateLevelMVars(x_38, x_3, x_37); -lean_dec(x_3); -x_40 = !lean_is_exclusive(x_39); -if (x_40 == 0) -{ -lean_object* x_41; uint8_t x_42; lean_object* x_43; -x_41 = lean_ctor_get(x_39, 0); -x_42 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_41); -lean_dec(x_41); -x_43 = lean_box(x_42); -lean_ctor_set(x_39, 0, x_43); -return x_39; +lean_object* x_33; uint8_t x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_31, 0); +x_34 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(x_33); +lean_dec(x_33); +x_35 = lean_box(x_34); +lean_ctor_set(x_31, 0, x_35); +return x_31; } else { -lean_object* x_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; -x_44 = lean_ctor_get(x_39, 0); -x_45 = lean_ctor_get(x_39, 1); +lean_object* x_36; lean_object* x_37; uint8_t x_38; lean_object* x_39; lean_object* x_40; +x_36 = lean_ctor_get(x_31, 0); +x_37 = lean_ctor_get(x_31, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_31); +x_38 = l___private_Init_Lean_Meta_InferType_11__isAlwaysZero___main(x_36); +lean_dec(x_36); +x_39 = lean_box(x_38); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_39); +lean_ctor_set(x_40, 1, x_37); +return x_40; +} +} +else +{ +uint8_t x_41; +lean_dec(x_28); +lean_dec(x_2); +x_41 = !lean_is_exclusive(x_27); +if (x_41 == 0) +{ +lean_object* x_42; uint8_t x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_27, 0); +lean_dec(x_42); +x_43 = 0; +x_44 = lean_box(x_43); +lean_ctor_set(x_27, 0, x_44); +return x_27; +} +else +{ +lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; +x_45 = lean_ctor_get(x_27, 1); lean_inc(x_45); -lean_inc(x_44); -lean_dec(x_39); -x_46 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_44); -lean_dec(x_44); +lean_dec(x_27); +x_46 = 0; x_47 = lean_box(x_46); x_48 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_48, 0, x_47); @@ -17326,54 +7597,75 @@ lean_ctor_set(x_48, 1, x_45); return x_48; } } -else -{ -uint8_t x_49; -lean_dec(x_36); -lean_dec(x_3); -x_49 = !lean_is_exclusive(x_35); -if (x_49 == 0) -{ -lean_object* x_50; uint8_t x_51; lean_object* x_52; -x_50 = lean_ctor_get(x_35, 0); -lean_dec(x_50); -x_51 = 0; -x_52 = lean_box(x_51); -lean_ctor_set(x_35, 0, x_52); -return x_35; } else { -lean_object* x_53; uint8_t x_54; lean_object* x_55; lean_object* x_56; -x_53 = lean_ctor_get(x_35, 1); -lean_inc(x_53); -lean_dec(x_35); -x_54 = 0; -x_55 = lean_box(x_54); -x_56 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_56, 0, x_55); -lean_ctor_set(x_56, 1, x_53); +uint8_t x_49; +lean_dec(x_2); +x_49 = !lean_is_exclusive(x_27); +if (x_49 == 0) +{ +return x_27; +} +else +{ +lean_object* x_50; lean_object* x_51; lean_object* x_52; +x_50 = lean_ctor_get(x_27, 0); +x_51 = lean_ctor_get(x_27, 1); +lean_inc(x_51); +lean_inc(x_50); +lean_dec(x_27); +x_52 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_52, 0, x_50); +lean_ctor_set(x_52, 1, x_51); +return x_52; +} +} +} +else +{ +uint8_t x_53; +lean_dec(x_2); +x_53 = !lean_is_exclusive(x_24); +if (x_53 == 0) +{ +return x_24; +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_54 = lean_ctor_get(x_24, 0); +x_55 = lean_ctor_get(x_24, 1); +lean_inc(x_55); +lean_inc(x_54); +lean_dec(x_24); +x_56 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_56, 0, x_54); +lean_ctor_set(x_56, 1, x_55); return x_56; } } } +} +} else { uint8_t x_57; -lean_dec(x_3); -x_57 = !lean_is_exclusive(x_35); +lean_dec(x_2); +lean_dec(x_1); +x_57 = !lean_is_exclusive(x_4); if (x_57 == 0) { -return x_35; +return x_4; } else { lean_object* x_58; lean_object* x_59; lean_object* x_60; -x_58 = lean_ctor_get(x_35, 0); -x_59 = lean_ctor_get(x_35, 1); +x_58 = lean_ctor_get(x_4, 0); +x_59 = lean_ctor_get(x_4, 1); lean_inc(x_59); lean_inc(x_58); -lean_dec(x_35); +lean_dec(x_4); x_60 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_60, 0, x_58); lean_ctor_set(x_60, 1, x_59); @@ -17381,176 +7673,6 @@ return x_60; } } } -else -{ -lean_object* x_61; uint8_t x_62; uint8_t x_63; uint8_t x_64; uint8_t x_65; uint8_t x_66; lean_object* x_67; lean_object* x_68; lean_object* x_69; -x_61 = lean_ctor_get(x_27, 0); -x_62 = lean_ctor_get_uint8(x_27, sizeof(void*)*1); -x_63 = lean_ctor_get_uint8(x_27, sizeof(void*)*1 + 1); -x_64 = lean_ctor_get_uint8(x_27, sizeof(void*)*1 + 2); -x_65 = lean_ctor_get_uint8(x_27, sizeof(void*)*1 + 3); -lean_inc(x_61); -lean_dec(x_27); -x_66 = 1; -x_67 = lean_alloc_ctor(0, 1, 5); -lean_ctor_set(x_67, 0, x_61); -lean_ctor_set_uint8(x_67, sizeof(void*)*1, x_62); -lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 1, x_63); -lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 2, x_64); -lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 3, x_65); -lean_ctor_set_uint8(x_67, sizeof(void*)*1 + 4, x_66); -x_68 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_68, 0, x_67); -lean_ctor_set(x_68, 1, x_30); -lean_ctor_set(x_68, 2, x_31); -x_69 = lean_apply_3(x_1, x_28, x_68, x_29); -if (lean_obj_tag(x_69) == 0) -{ -lean_object* x_70; -x_70 = lean_ctor_get(x_69, 0); -lean_inc(x_70); -if (lean_obj_tag(x_70) == 3) -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; uint8_t x_77; lean_object* x_78; lean_object* x_79; -x_71 = lean_ctor_get(x_69, 1); -lean_inc(x_71); -lean_dec(x_69); -x_72 = lean_ctor_get(x_70, 0); -lean_inc(x_72); -lean_dec(x_70); -x_73 = l_Lean_Meta_instantiateLevelMVars(x_72, x_3, x_71); -lean_dec(x_3); -x_74 = lean_ctor_get(x_73, 0); -lean_inc(x_74); -x_75 = lean_ctor_get(x_73, 1); -lean_inc(x_75); -if (lean_is_exclusive(x_73)) { - lean_ctor_release(x_73, 0); - lean_ctor_release(x_73, 1); - x_76 = x_73; -} else { - lean_dec_ref(x_73); - x_76 = lean_box(0); -} -x_77 = l___private_Init_Lean_Meta_InferType_10__isAlwaysZero___main(x_74); -lean_dec(x_74); -x_78 = lean_box(x_77); -if (lean_is_scalar(x_76)) { - x_79 = lean_alloc_ctor(0, 2, 0); -} else { - x_79 = x_76; -} -lean_ctor_set(x_79, 0, x_78); -lean_ctor_set(x_79, 1, x_75); -return x_79; -} -else -{ -lean_object* x_80; lean_object* x_81; uint8_t x_82; lean_object* x_83; lean_object* x_84; -lean_dec(x_70); -lean_dec(x_3); -x_80 = lean_ctor_get(x_69, 1); -lean_inc(x_80); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - x_81 = x_69; -} else { - lean_dec_ref(x_69); - x_81 = lean_box(0); -} -x_82 = 0; -x_83 = lean_box(x_82); -if (lean_is_scalar(x_81)) { - x_84 = lean_alloc_ctor(0, 2, 0); -} else { - x_84 = x_81; -} -lean_ctor_set(x_84, 0, x_83); -lean_ctor_set(x_84, 1, x_80); -return x_84; -} -} -else -{ -lean_object* x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; -lean_dec(x_3); -x_85 = lean_ctor_get(x_69, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_69, 1); -lean_inc(x_86); -if (lean_is_exclusive(x_69)) { - lean_ctor_release(x_69, 0); - lean_ctor_release(x_69, 1); - x_87 = x_69; -} else { - lean_dec_ref(x_69); - x_87 = lean_box(0); -} -if (lean_is_scalar(x_87)) { - x_88 = lean_alloc_ctor(1, 2, 0); -} else { - x_88 = x_87; -} -lean_ctor_set(x_88, 0, x_85); -lean_ctor_set(x_88, 1, x_86); -return x_88; -} -} -} -else -{ -uint8_t x_89; -lean_dec(x_3); -lean_dec(x_1); -x_89 = !lean_is_exclusive(x_26); -if (x_89 == 0) -{ -return x_26; -} -else -{ -lean_object* x_90; lean_object* x_91; lean_object* x_92; -x_90 = lean_ctor_get(x_26, 0); -x_91 = lean_ctor_get(x_26, 1); -lean_inc(x_91); -lean_inc(x_90); -lean_dec(x_26); -x_92 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_92, 0, x_90); -lean_ctor_set(x_92, 1, x_91); -return x_92; -} -} -} -} -} -else -{ -uint8_t x_93; -lean_dec(x_3); -lean_dec(x_2); -lean_dec(x_1); -x_93 = !lean_is_exclusive(x_5); -if (x_93 == 0) -{ -return x_5; -} -else -{ -lean_object* x_94; lean_object* x_95; lean_object* x_96; -x_94 = lean_ctor_get(x_5, 0); -x_95 = lean_ctor_get(x_5, 1); -lean_inc(x_95); -lean_inc(x_94); -lean_dec(x_5); -x_96 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_96, 0, x_94); -lean_ctor_set(x_96, 1, x_95); -return x_96; -} -} -} } lean_object* initialize_Init_Lean_LBool(lean_object*); lean_object* initialize_Init_Lean_Meta_Basic(lean_object*); @@ -17565,8 +7687,11 @@ lean_dec_ref(res); res = initialize_Init_Lean_Meta_Basic(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1 = _init_l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_InferType_1__inferAppType___closed__1); +l_Lean_Meta_setInferTypeRef___closed__1 = _init_l_Lean_Meta_setInferTypeRef___closed__1(); +lean_mark_persistent(l_Lean_Meta_setInferTypeRef___closed__1); +res = l_Lean_Meta_setInferTypeRef(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/library/Init/Lean/Meta/LevelDefEq.c b/stage0/library/Init/Lean/Meta/LevelDefEq.c index 2160dbb0e3..d931b857c0 100644 --- a/stage0/library/Init/Lean/Meta/LevelDefEq.c +++ b/stage0/library/Init/Lean/Meta/LevelDefEq.c @@ -13,123 +13,130 @@ #ifdef __cplusplus extern "C" { #endif -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__6; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___rarg___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__6; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__3; lean_object* l_Lean_Level_normalize___main(lean_object*); -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__4(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); -lean_object* l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__5(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); lean_object* l_Lean_Meta_mkFreshLevelMVarId___rarg(lean_object*); uint8_t l___private_Init_Lean_Meta_LevelDefEq_1__strictOccursMaxAux(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main(lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_4__solveSelfMax(lean_object*); -lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1(lean_object*, uint8_t, lean_object*, lean_object*); uint8_t l___private_Init_Lean_Meta_LevelDefEq_1__strictOccursMaxAux___main(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___boxed(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__1; extern lean_object* l_Array_empty___closed__1; +lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_3__mkMaxArgsDiff___main___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__4(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); uint8_t lean_name_eq(lean_object*, lean_object*); lean_object* l_Lean_Level_dec___main(lean_object*); -lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__2; lean_object* l_Lean_Meta_instantiateLevelMVars(lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_4__solveSelfMax___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__4; lean_object* lean_array_push(lean_object*, lean_object*); lean_object* lean_array_get_size(lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__8; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__9; lean_object* l_PersistentArray_push___rarg(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__1; -lean_object* l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__4; -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__5(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__5; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__8; +lean_object* l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Level_mvarId_x21(lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_4__solveSelfMax___boxed(lean_object*); -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__5___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___rarg(lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__7; +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__3; lean_object* lean_nat_add(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__8; +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__1; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__7; +lean_object* l_Lean_Meta_isLevelDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2; +lean_object* l_Lean_Meta_isLevelDefEqAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_MetavarContext_hasAssignableLevelMVar___main(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6(lean_object*); +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__2; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__5; +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__7; lean_object* lean_array_fget(lean_object*, lean_object*); uint8_t lean_nat_dec_eq(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2; +lean_object* l_Lean_Meta_isListLevelDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__4; lean_object* l___private_Init_Lean_Meta_LevelDefEq_6__getLevelConstraintKind___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___rarg(lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_3__mkMaxArgsDiff___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_isListLevelDefEq___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___rarg(lean_object*); extern lean_object* l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__3(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3; lean_object* l_Lean_Name_append___main(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___boxed(lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed(lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__5; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5; +lean_object* l_Lean_Meta_isLevelDefEqAux___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed(lean_object*); +lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkLevelMax(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__3; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__2; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_13__restore___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__3(lean_object*, lean_object*, lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__restore___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Nat_repr(lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___boxed(lean_object*); +lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(lean_object*, lean_object*, lean_object*); lean_object* lean_name_mk_string(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_2__strictOccursMax___boxed(lean_object*, lean_object*); extern lean_object* l_PersistentArray_empty___closed__3; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__3; lean_object* l___private_Init_Lean_Meta_LevelDefEq_4__solveSelfMax___rarg___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_13__restore(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_3__mkMaxArgsDiff___main(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__3; +lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__restore(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isListLevelDefEqAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_try(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_assignLevelMVar(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Meta_isLevelDefEqAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l___private_Init_Lean_Trace_4__checkTraceOptionAux___main(lean_object*, lean_object*); +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isLevelDefEqAux___main___closed__6; lean_object* l_Lean_mkLevelMVar(lean_object*); -lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___lambda__1___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__7; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__2; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__1; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__3; +lean_object* l_Lean_Meta_isListLevelDefEqAux___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__1; +lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Level_occurs___main(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__8; -lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___lambda__1(uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6(lean_object*); +lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__2(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___boxed(lean_object*); lean_object* l_Lean_Meta_isLevelDefEq(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__1; uint8_t l___private_Init_Lean_Meta_LevelDefEq_2__strictOccursMax(lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_1__strictOccursMaxAux___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__6; -lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___closed__1; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___boxed(lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__1; lean_object* l___private_Init_Lean_Meta_LevelDefEq_5__postponeIsLevelDefEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___boxed(lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep(lean_object*, lean_object*); uint8_t l_Lean_Level_isMVar(lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_1__strictOccursMaxAux___main___boxed(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed(lean_object*); +lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_6__getLevelConstraintKind(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_5__postponeIsLevelDefEq(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__1; -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__9; -lean_object* l_Lean_Meta_isListLevelDefEq(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1(lean_object*, uint8_t, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux(uint8_t, lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isListLevelDefEqAux___main___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed(lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___rarg(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___boxed(lean_object*, lean_object*); +lean_object* l_Lean_Meta_isExprDefEq(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux(lean_object*); +lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___rarg(lean_object*); lean_object* l___private_Init_Lean_Meta_LevelDefEq_3__mkMaxArgsDiff(lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___rarg(lean_object*); +lean_object* l_Lean_Meta_isLevelDefEq___boxed(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Level_isSucc(lean_object*); uint8_t l_List_isEmpty___rarg(lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___boxed(lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___boxed(lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___rarg(lean_object*); uint8_t lean_level_eq(lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2; lean_object* l_Lean_Meta_isReadOnlyLevelMVar(lean_object*, lean_object*, lean_object*); -lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2(lean_object*, uint8_t, lean_object*, lean_object*); -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___boxed(lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l___private_Init_Lean_Meta_LevelDefEq_1__strictOccursMaxAux___main(lean_object* x_1, lean_object* x_2) { @@ -611,7 +618,7 @@ lean_dec(x_2); return x_5; } } -lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; lean_object* x_5; uint8_t x_6; @@ -640,7 +647,7 @@ return x_12; } } } -lean_object* l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { uint8_t x_5; @@ -739,7 +746,7 @@ return x_34; } } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__1() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__1() { _start: { lean_object* x_1; @@ -747,17 +754,17 @@ x_1 = lean_mk_string("type_context"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__2() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__1; +x_2 = l_Lean_Meta_isLevelDefEqAux___main___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__3() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__3() { _start: { lean_object* x_1; @@ -765,27 +772,27 @@ x_1 = lean_mk_string("level_is_def_eq"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__4() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__2; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__3; +x_1 = l_Lean_Meta_isLevelDefEqAux___main___closed__2; +x_2 = l_Lean_Meta_isLevelDefEqAux___main___closed__3; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__5() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; +x_2 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__6() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__6() { _start: { lean_object* x_1; @@ -793,27 +800,27 @@ x_1 = lean_mk_string(" =?= "); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__7() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__7() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__6; +x_1 = l_Lean_Meta_isLevelDefEqAux___main___closed__6; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__8() { +lean_object* _init_l_Lean_Meta_isLevelDefEqAux___main___closed__8() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__7; +x_1 = l_Lean_Meta_isLevelDefEqAux___main___closed__7; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isLevelDefEqAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; lean_object* x_317; @@ -2176,8 +2183,8 @@ goto block_316; else { lean_object* x_321; lean_object* x_322; lean_object* x_323; uint8_t x_324; -x_321 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5; -x_322 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_321, x_3, x_4); +x_321 = l_Lean_Meta_isLevelDefEqAux___main___closed__5; +x_322 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_321, x_3, x_4); x_323 = lean_ctor_get(x_322, 0); lean_inc(x_323); x_324 = lean_unbox(x_323); @@ -2200,7 +2207,7 @@ lean_dec(x_322); lean_inc(x_1); x_327 = lean_alloc_ctor(3, 1, 0); lean_ctor_set(x_327, 0, x_1); -x_328 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__8; +x_328 = l_Lean_Meta_isLevelDefEqAux___main___closed__8; x_329 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_329, 0, x_327); lean_ctor_set(x_329, 1, x_328); @@ -2210,8 +2217,8 @@ lean_ctor_set(x_330, 0, x_2); x_331 = lean_alloc_ctor(8, 2, 0); lean_ctor_set(x_331, 0, x_329); lean_ctor_set(x_331, 1, x_330); -x_332 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_333 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_332, x_331, x_3, x_326); +x_332 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_333 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_332, x_331, x_3, x_326); x_334 = lean_ctor_get(x_333, 1); lean_inc(x_334); lean_dec(x_333); @@ -2235,52 +2242,204 @@ return x_337; } } } -lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_1, x_2, x_3); +x_4 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_1, x_2, x_3); lean_dec(x_2); lean_dec(x_1); return x_4; } } -lean_object* l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_1, x_2, x_3, x_4); lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isLevelDefEqAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main(x_1, x_2, x_3, x_4); +x_5 = l_Lean_Meta_isLevelDefEqAux___main(x_1, x_2, x_3, x_4); lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isLevelDefEqAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main(x_1, x_2, x_3, x_4); +x_5 = l_Lean_Meta_isLevelDefEqAux___main(x_1, x_2, x_3, x_4); return x_5; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isLevelDefEqAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux(x_1, x_2, x_3, x_4); +x_5 = l_Lean_Meta_isLevelDefEqAux(x_1, x_2, x_3, x_4); lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___rarg(lean_object* x_1) { +lean_object* l_Lean_Meta_isListLevelDefEqAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +if (lean_obj_tag(x_1) == 0) +{ +if (lean_obj_tag(x_2) == 0) +{ +uint8_t x_5; lean_object* x_6; lean_object* x_7; +x_5 = 1; +x_6 = lean_box(x_5); +x_7 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_7, 0, x_6); +lean_ctor_set(x_7, 1, x_4); +return x_7; +} +else +{ +uint8_t x_8; lean_object* x_9; lean_object* x_10; +lean_dec(x_2); +x_8 = 0; +x_9 = lean_box(x_8); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_4); +return x_10; +} +} +else +{ +if (lean_obj_tag(x_2) == 0) +{ +uint8_t x_11; lean_object* x_12; lean_object* x_13; +lean_dec(x_1); +x_11 = 0; +x_12 = lean_box(x_11); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_12); +lean_ctor_set(x_13, 1, x_4); +return x_13; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_14 = lean_ctor_get(x_1, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_1, 1); +lean_inc(x_15); +lean_dec(x_1); +x_16 = lean_ctor_get(x_2, 0); +lean_inc(x_16); +x_17 = lean_ctor_get(x_2, 1); +lean_inc(x_17); +lean_dec(x_2); +x_18 = l_Lean_Meta_isLevelDefEqAux___main(x_14, x_16, x_3, x_4); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; uint8_t x_20; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_unbox(x_19); +if (x_20 == 0) +{ +uint8_t x_21; +lean_dec(x_17); +lean_dec(x_15); +x_21 = !lean_is_exclusive(x_18); +if (x_21 == 0) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_18, 0); +lean_dec(x_22); +return x_18; +} +else +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_dec(x_18); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_19); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +else +{ +lean_object* x_25; +lean_dec(x_19); +x_25 = lean_ctor_get(x_18, 1); +lean_inc(x_25); +lean_dec(x_18); +x_1 = x_15; +x_2 = x_17; +x_4 = x_25; +goto _start; +} +} +else +{ +uint8_t x_27; +lean_dec(x_17); +lean_dec(x_15); +x_27 = !lean_is_exclusive(x_18); +if (x_27 == 0) +{ +return x_18; +} +else +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_28 = lean_ctor_get(x_18, 0); +x_29 = lean_ctor_get(x_18, 1); +lean_inc(x_29); +lean_inc(x_28); +lean_dec(x_18); +x_30 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_30, 0, x_28); +lean_ctor_set(x_30, 1, x_29); +return x_30; +} +} +} +} +} +} +lean_object* l_Lean_Meta_isListLevelDefEqAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Meta_isListLevelDefEqAux___main(x_1, x_2, x_3, x_4); +lean_dec(x_3); +return x_5; +} +} +lean_object* l_Lean_Meta_isListLevelDefEqAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Meta_isListLevelDefEqAux___main(x_1, x_2, x_3, x_4); +return x_5; +} +} +lean_object* l_Lean_Meta_isListLevelDefEqAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = l_Lean_Meta_isListLevelDefEqAux(x_1, x_2, x_3, x_4); +lean_dec(x_3); +return x_5; +} +} +lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___rarg(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; lean_object* x_4; @@ -2295,24 +2454,24 @@ lean_ctor_set(x_4, 1, x_1); return x_4; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___rarg), 1, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___rarg), 1, 0); return x_2; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___boxed(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___boxed(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed(x_1); +x_2 = l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed(x_1); lean_dec(x_1); return x_2; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___rarg(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___rarg(lean_object* x_1) { _start: { uint8_t x_2; @@ -2359,24 +2518,24 @@ return x_14; } } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___rarg), 1, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___rarg), 1, 0); return x_2; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___boxed(lean_object* x_1) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___boxed(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed(x_1); +x_2 = l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed(x_1); lean_dec(x_1); return x_2; } } -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; uint8_t x_8; @@ -2400,7 +2559,7 @@ x_11 = lean_array_fget(x_2, x_3); x_12 = lean_unsigned_to_nat(1u); x_13 = lean_nat_add(x_3, x_12); lean_dec(x_3); -x_14 = l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2(x_11, x_4, x_5, x_6); +x_14 = l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__2(x_11, x_4, x_5, x_6); lean_dec(x_11); if (lean_obj_tag(x_14) == 0) { @@ -2443,7 +2602,7 @@ return x_22; } } } -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; uint8_t x_8; @@ -2484,7 +2643,7 @@ lean_inc(x_16); x_17 = lean_ctor_get(x_11, 1); lean_inc(x_17); lean_dec(x_11); -x_18 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main(x_16, x_17, x_5, x_6); +x_18 = l_Lean_Meta_isLevelDefEqAux___main(x_16, x_17, x_5, x_6); if (lean_obj_tag(x_18) == 0) { lean_object* x_19; lean_object* x_20; uint8_t x_21; @@ -2527,7 +2686,7 @@ return x_26; } } } -lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__2(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4) { _start: { if (lean_obj_tag(x_1) == 0) @@ -2535,7 +2694,7 @@ if (lean_obj_tag(x_1) == 0) lean_object* x_5; lean_object* x_6; lean_object* x_7; x_5 = lean_ctor_get(x_1, 0); x_6 = lean_unsigned_to_nat(0u); -x_7 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__3(x_5, x_5, x_6, x_2, x_3, x_4); +x_7 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__3(x_5, x_5, x_6, x_2, x_3, x_4); return x_7; } else @@ -2543,12 +2702,12 @@ else lean_object* x_8; lean_object* x_9; lean_object* x_10; x_8 = lean_ctor_get(x_1, 0); x_9 = lean_unsigned_to_nat(0u); -x_10 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__4(x_8, x_8, x_9, x_2, x_3, x_4); +x_10 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__4(x_8, x_8, x_9, x_2, x_3, x_4); return x_10; } } } -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, uint8_t x_4, lean_object* x_5, lean_object* x_6) { _start: { lean_object* x_7; uint8_t x_8; @@ -2589,7 +2748,7 @@ lean_inc(x_16); x_17 = lean_ctor_get(x_11, 1); lean_inc(x_17); lean_dec(x_11); -x_18 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main(x_16, x_17, x_5, x_6); +x_18 = l_Lean_Meta_isLevelDefEqAux___main(x_16, x_17, x_5, x_6); if (lean_obj_tag(x_18) == 0) { lean_object* x_19; lean_object* x_20; uint8_t x_21; @@ -2632,12 +2791,12 @@ return x_26; } } } -lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1(lean_object* x_1, uint8_t x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; lean_object* x_6; x_5 = lean_ctor_get(x_1, 0); -x_6 = l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2(x_5, x_2, x_3, x_4); +x_6 = l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__2(x_5, x_2, x_3, x_4); if (lean_obj_tag(x_6) == 0) { lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; lean_object* x_12; @@ -2650,7 +2809,7 @@ x_9 = lean_ctor_get(x_1, 1); x_10 = lean_unsigned_to_nat(0u); x_11 = lean_unbox(x_7); lean_dec(x_7); -x_12 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__5(x_1, x_9, x_10, x_11, x_3, x_8); +x_12 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__5(x_1, x_9, x_10, x_11, x_3, x_8); return x_12; } else @@ -2677,7 +2836,7 @@ return x_16; } } } -lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___rarg(lean_object* x_1) { +lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___rarg(lean_object* x_1) { _start: { uint8_t x_2; @@ -2764,15 +2923,15 @@ return x_25; } } } -lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6(lean_object* x_1) { +lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___rarg), 1, 0); +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___rarg), 1, 0); return x_2; } } -lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { uint8_t x_5; @@ -2877,7 +3036,7 @@ return x_37; } } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__1() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__1() { _start: { lean_object* x_1; @@ -2885,27 +3044,27 @@ x_1 = lean_mk_string("postponed_step"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__1; +x_1 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_2 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__3() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__3() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2; +x_2 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep(lean_object* x_1, lean_object* x_2) { _start: { uint8_t x_3; lean_object* x_4; lean_object* x_192; uint8_t x_193; @@ -2924,8 +3083,8 @@ goto block_191; else { lean_object* x_195; lean_object* x_196; lean_object* x_197; lean_object* x_198; uint8_t x_199; -x_195 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__3; -x_196 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_195, x_1, x_2); +x_195 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__3; +x_196 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_195, x_1, x_2); x_197 = lean_ctor_get(x_196, 0); lean_inc(x_197); x_198 = lean_ctor_get(x_196, 1); @@ -2953,13 +3112,13 @@ if (x_7 == 0) uint8_t x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; x_8 = 1; lean_ctor_set_uint8(x_6, sizeof(void*)*1, x_8); -x_9 = l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___rarg(x_4); +x_9 = l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___rarg(x_4); x_10 = lean_ctor_get(x_9, 0); lean_inc(x_10); x_11 = lean_ctor_get(x_9, 1); lean_inc(x_11); lean_dec(x_9); -x_12 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1(x_10, x_8, x_1, x_11); +x_12 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1(x_10, x_8, x_1, x_11); lean_dec(x_10); if (lean_obj_tag(x_12) == 0) { @@ -3263,13 +3422,13 @@ x_83 = lean_alloc_ctor(0, 1, 1); lean_ctor_set(x_83, 0, x_81); lean_ctor_set_uint8(x_83, sizeof(void*)*1, x_82); lean_ctor_set(x_4, 4, x_83); -x_84 = l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___rarg(x_4); +x_84 = l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___rarg(x_4); x_85 = lean_ctor_get(x_84, 0); lean_inc(x_85); x_86 = lean_ctor_get(x_84, 1); lean_inc(x_86); lean_dec(x_84); -x_87 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1(x_85, x_82, x_1, x_86); +x_87 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1(x_85, x_82, x_1, x_86); lean_dec(x_85); if (lean_obj_tag(x_87) == 0) { @@ -3465,13 +3624,13 @@ lean_ctor_set(x_130, 2, x_123); lean_ctor_set(x_130, 3, x_124); lean_ctor_set(x_130, 4, x_129); lean_ctor_set(x_130, 5, x_125); -x_131 = l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___rarg(x_130); +x_131 = l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___rarg(x_130); x_132 = lean_ctor_get(x_131, 0); lean_inc(x_132); x_133 = lean_ctor_get(x_131, 1); lean_inc(x_133); lean_dec(x_131); -x_134 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1(x_132, x_128, x_1, x_133); +x_134 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1(x_132, x_128, x_1, x_133); lean_dec(x_132); if (lean_obj_tag(x_134) == 0) { @@ -3630,20 +3789,20 @@ return x_166; else { lean_object* x_167; lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; uint8_t x_173; lean_object* x_174; -x_167 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___rarg(x_4); +x_167 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___rarg(x_4); x_168 = lean_ctor_get(x_167, 0); lean_inc(x_168); x_169 = lean_ctor_get(x_167, 1); lean_inc(x_169); lean_dec(x_167); -x_170 = l___private_Init_Lean_Meta_LevelDefEq_9__getResetPostponed___rarg(x_169); +x_170 = l___private_Init_Lean_Meta_LevelDefEq_8__getResetPostponed___rarg(x_169); x_171 = lean_ctor_get(x_170, 0); lean_inc(x_171); x_172 = lean_ctor_get(x_170, 1); lean_inc(x_172); lean_dec(x_170); x_173 = 1; -x_174 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1(x_171, x_173, x_1, x_172); +x_174 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1(x_171, x_173, x_1, x_172); lean_dec(x_171); if (lean_obj_tag(x_174) == 0) { @@ -3653,8 +3812,8 @@ lean_inc(x_175); x_176 = lean_ctor_get(x_174, 1); lean_inc(x_176); lean_dec(x_174); -x_177 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2; -x_178 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(x_168, x_177, x_1, x_176); +x_177 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2; +x_178 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(x_168, x_177, x_1, x_176); x_179 = !lean_is_exclusive(x_178); if (x_179 == 0) { @@ -3684,8 +3843,8 @@ lean_inc(x_183); x_184 = lean_ctor_get(x_174, 1); lean_inc(x_184); lean_dec(x_174); -x_185 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2; -x_186 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(x_168, x_185, x_1, x_184); +x_185 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2; +x_186 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(x_168, x_185, x_1, x_184); x_187 = !lean_is_exclusive(x_186); if (x_187 == 0) { @@ -3712,97 +3871,97 @@ return x_190; } } } -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { uint8_t x_7; lean_object* x_8; x_7 = lean_unbox(x_4); lean_dec(x_4); -x_8 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__3(x_1, x_2, x_3, x_7, x_5, x_6); +x_8 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__3(x_1, x_2, x_3, x_7, x_5, x_6); lean_dec(x_5); lean_dec(x_2); lean_dec(x_1); return x_8; } } -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { uint8_t x_7; lean_object* x_8; x_7 = lean_unbox(x_4); lean_dec(x_4); -x_8 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__4(x_1, x_2, x_3, x_7, x_5, x_6); +x_8 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__4(x_1, x_2, x_3, x_7, x_5, x_6); lean_dec(x_5); lean_dec(x_2); lean_dec(x_1); return x_8; } } -lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { uint8_t x_5; lean_object* x_6; x_5 = lean_unbox(x_2); lean_dec(x_2); -x_6 = l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__2(x_1, x_5, x_3, x_4); +x_6 = l_PersistentArray_foldlMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__2(x_1, x_5, x_3, x_4); lean_dec(x_3); lean_dec(x_1); return x_6; } } -lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +lean_object* l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__5___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { uint8_t x_7; lean_object* x_8; x_7 = lean_unbox(x_4); lean_dec(x_4); -x_8 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__5(x_1, x_2, x_3, x_7, x_5, x_6); +x_8 = l_Array_iterateMAux___main___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__5(x_1, x_2, x_3, x_7, x_5, x_6); lean_dec(x_5); lean_dec(x_2); lean_dec(x_1); return x_8; } } -lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { uint8_t x_5; lean_object* x_6; x_5 = lean_unbox(x_2); lean_dec(x_2); -x_6 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__1(x_1, x_5, x_3, x_4); +x_6 = l_PersistentArray_foldlM___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__1(x_1, x_5, x_3, x_4); lean_dec(x_3); lean_dec(x_1); return x_6; } } -lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___boxed(lean_object* x_1) { +lean_object* l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___boxed(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6(x_1); +x_2 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6(x_1); lean_dec(x_1); return x_2; } } -lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(x_1, x_2, x_3, x_4); +x_5 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(x_1, x_2, x_3, x_4); lean_dec(x_3); return x_5; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___boxed(lean_object* x_1, lean_object* x_2) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___boxed(lean_object* x_1, lean_object* x_2) { _start: { lean_object* x_3; -x_3 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep(x_1, x_2); +x_3 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep(x_1, x_2); lean_dec(x_1); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__1() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__1() { _start: { lean_object* x_1; @@ -3810,27 +3969,27 @@ x_1 = lean_mk_string("no progress solving pending is-def-eq level constraints"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__2() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__2() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__1; +x_1 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__1; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__2; +x_1 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__2; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__4() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__4() { _start: { lean_object* x_1; @@ -3838,27 +3997,27 @@ x_1 = lean_mk_string("processing #"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__5() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__5() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__4; +x_1 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__4; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__6() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__6() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__5; +x_1 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__5; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__7() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__7() { _start: { lean_object* x_1; @@ -3866,174 +4025,175 @@ x_1 = lean_mk_string(" postponed is-def-eq level constraints"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__8() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__8() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__7; +x_1 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__7; x_2 = lean_alloc_ctor(2, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__9() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__9() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__8; +x_1 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__8; x_2 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_2, 0, x_1); return x_2; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(uint8_t x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(lean_object* x_1, lean_object* x_2) { _start: { -lean_object* x_4; uint8_t x_5; -x_4 = l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___rarg(x_3); -x_5 = !lean_is_exclusive(x_4); -if (x_5 == 0) +lean_object* x_3; uint8_t x_4; +x_3 = l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___rarg(x_2); +x_4 = !lean_is_exclusive(x_3); +if (x_4 == 0) { -lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_9; -x_6 = lean_ctor_get(x_4, 0); -x_7 = lean_ctor_get(x_4, 1); -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_nat_dec_eq(x_6, x_8); -if (x_9 == 0) +lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_5 = lean_ctor_get(x_3, 0); +x_6 = lean_ctor_get(x_3, 1); +x_7 = lean_unsigned_to_nat(0u); +x_8 = lean_nat_dec_eq(x_5, x_7); +if (x_8 == 0) { -lean_object* x_10; lean_object* x_84; uint8_t x_85; -lean_free_object(x_4); -x_84 = lean_ctor_get(x_7, 4); -lean_inc(x_84); -x_85 = lean_ctor_get_uint8(x_84, sizeof(void*)*1); -lean_dec(x_84); -if (x_85 == 0) -{ -x_10 = x_7; -goto block_83; -} -else -{ -lean_object* x_86; lean_object* x_87; lean_object* x_88; uint8_t x_89; -x_86 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5; -x_87 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_86, x_2, x_7); -x_88 = lean_ctor_get(x_87, 0); -lean_inc(x_88); -x_89 = lean_unbox(x_88); -lean_dec(x_88); -if (x_89 == 0) -{ -lean_object* x_90; -x_90 = lean_ctor_get(x_87, 1); -lean_inc(x_90); -lean_dec(x_87); -x_10 = x_90; -goto block_83; -} -else -{ -lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_91 = lean_ctor_get(x_87, 1); +lean_object* x_9; lean_object* x_91; uint8_t x_92; +lean_free_object(x_3); +x_91 = lean_ctor_get(x_6, 4); lean_inc(x_91); -lean_dec(x_87); -lean_inc(x_6); -x_92 = l_Nat_repr(x_6); -x_93 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_93, 0, x_92); -x_94 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_94, 0, x_93); -x_95 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__6; -x_96 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_96, 0, x_95); -lean_ctor_set(x_96, 1, x_94); -x_97 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__9; -x_98 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_98, 0, x_96); -lean_ctor_set(x_98, 1, x_97); -x_99 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_100 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_99, x_98, x_2, x_91); -x_101 = lean_ctor_get(x_100, 1); -lean_inc(x_101); -lean_dec(x_100); -x_10 = x_101; -goto block_83; +x_92 = lean_ctor_get_uint8(x_91, sizeof(void*)*1); +lean_dec(x_91); +if (x_92 == 0) +{ +x_9 = x_6; +goto block_90; +} +else +{ +lean_object* x_93; lean_object* x_94; lean_object* x_95; uint8_t x_96; +x_93 = l_Lean_Meta_isLevelDefEqAux___main___closed__5; +x_94 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_93, x_1, x_6); +x_95 = lean_ctor_get(x_94, 0); +lean_inc(x_95); +x_96 = lean_unbox(x_95); +lean_dec(x_95); +if (x_96 == 0) +{ +lean_object* x_97; +x_97 = lean_ctor_get(x_94, 1); +lean_inc(x_97); +lean_dec(x_94); +x_9 = x_97; +goto block_90; +} +else +{ +lean_object* x_98; lean_object* x_99; lean_object* x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_98 = lean_ctor_get(x_94, 1); +lean_inc(x_98); +lean_dec(x_94); +lean_inc(x_5); +x_99 = l_Nat_repr(x_5); +x_100 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_100, 0, x_99); +x_101 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_101, 0, x_100); +x_102 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__6; +x_103 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_103, 0, x_102); +lean_ctor_set(x_103, 1, x_101); +x_104 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__9; +x_105 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_105, 0, x_103); +lean_ctor_set(x_105, 1, x_104); +x_106 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_107 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_106, x_105, x_1, x_98); +x_108 = lean_ctor_get(x_107, 1); +lean_inc(x_108); +lean_dec(x_107); +x_9 = x_108; +goto block_90; } } -block_83: +block_90: { -lean_object* x_11; -x_11 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep(x_2, x_10); -if (lean_obj_tag(x_11) == 0) +lean_object* x_10; +x_10 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep(x_1, x_9); +if (lean_obj_tag(x_10) == 0) { -lean_object* x_12; uint8_t x_13; -x_12 = lean_ctor_get(x_11, 0); -lean_inc(x_12); -x_13 = lean_unbox(x_12); +lean_object* x_11; uint8_t x_12; +x_11 = lean_ctor_get(x_10, 0); +lean_inc(x_11); +x_12 = lean_unbox(x_11); +if (x_12 == 0) +{ +uint8_t x_13; +lean_dec(x_5); +x_13 = !lean_is_exclusive(x_10); if (x_13 == 0) { -uint8_t x_14; -lean_dec(x_6); -x_14 = !lean_is_exclusive(x_11); -if (x_14 == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_11, 0); -lean_dec(x_15); -return x_11; +lean_object* x_14; +x_14 = lean_ctor_get(x_10, 0); +lean_dec(x_14); +return x_10; } else { -lean_object* x_16; lean_object* x_17; -x_16 = lean_ctor_get(x_11, 1); -lean_inc(x_16); -lean_dec(x_11); -x_17 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_17, 0, x_12); -lean_ctor_set(x_17, 1, x_16); -return x_17; +lean_object* x_15; lean_object* x_16; +x_15 = lean_ctor_get(x_10, 1); +lean_inc(x_15); +lean_dec(x_10); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_11); +lean_ctor_set(x_16, 1, x_15); +return x_16; } } else { -lean_object* x_18; lean_object* x_19; uint8_t x_20; -lean_dec(x_12); -x_18 = lean_ctor_get(x_11, 1); -lean_inc(x_18); +lean_object* x_17; lean_object* x_18; uint8_t x_19; lean_dec(x_11); -x_19 = l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___rarg(x_18); -x_20 = !lean_is_exclusive(x_19); -if (x_20 == 0) +x_17 = lean_ctor_get(x_10, 1); +lean_inc(x_17); +lean_dec(x_10); +x_18 = l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___rarg(x_17); +x_19 = !lean_is_exclusive(x_18); +if (x_19 == 0) { -lean_object* x_21; lean_object* x_22; uint8_t x_23; -x_21 = lean_ctor_get(x_19, 0); -x_22 = lean_ctor_get(x_19, 1); -x_23 = lean_nat_dec_eq(x_21, x_8); +lean_object* x_20; lean_object* x_21; uint8_t x_22; +x_20 = lean_ctor_get(x_18, 0); +x_21 = lean_ctor_get(x_18, 1); +x_22 = lean_nat_dec_eq(x_20, x_7); +if (x_22 == 0) +{ +uint8_t x_23; +x_23 = lean_nat_dec_lt(x_20, x_5); +lean_dec(x_5); +lean_dec(x_20); if (x_23 == 0) { -uint8_t x_24; -x_24 = lean_nat_dec_lt(x_21, x_6); -lean_dec(x_6); -lean_dec(x_21); -if (x_24 == 0) +lean_object* x_24; uint8_t x_25; +x_24 = lean_ctor_get(x_21, 4); +lean_inc(x_24); +x_25 = lean_ctor_get_uint8(x_24, sizeof(void*)*1); +lean_dec(x_24); +if (x_25 == 0) { -lean_object* x_25; uint8_t x_26; -x_25 = lean_ctor_get(x_22, 4); -lean_inc(x_25); -x_26 = lean_ctor_get_uint8(x_25, sizeof(void*)*1); -lean_dec(x_25); -if (x_26 == 0) -{ -lean_object* x_27; -x_27 = lean_box(x_1); -lean_ctor_set(x_19, 0, x_27); -return x_19; +uint8_t x_26; lean_object* x_27; +x_26 = 0; +x_27 = lean_box(x_26); +lean_ctor_set(x_18, 0, x_27); +return x_18; } else { lean_object* x_28; lean_object* x_29; lean_object* x_30; uint8_t x_31; -lean_free_object(x_19); -x_28 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5; -x_29 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_28, x_2, x_22); +lean_free_object(x_18); +x_28 = l_Lean_Meta_isLevelDefEqAux___main___closed__5; +x_29 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_28, x_1, x_21); x_30 = lean_ctor_get(x_29, 0); lean_inc(x_30); x_31 = lean_unbox(x_30); @@ -4044,538 +4204,578 @@ uint8_t x_32; x_32 = !lean_is_exclusive(x_29); if (x_32 == 0) { -lean_object* x_33; lean_object* x_34; +lean_object* x_33; uint8_t x_34; lean_object* x_35; x_33 = lean_ctor_get(x_29, 0); lean_dec(x_33); -x_34 = lean_box(x_1); -lean_ctor_set(x_29, 0, x_34); +x_34 = 0; +x_35 = lean_box(x_34); +lean_ctor_set(x_29, 0, x_35); return x_29; } else { -lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_29, 1); -lean_inc(x_35); +lean_object* x_36; uint8_t x_37; lean_object* x_38; lean_object* x_39; +x_36 = lean_ctor_get(x_29, 1); +lean_inc(x_36); lean_dec(x_29); -x_36 = lean_box(x_1); -x_37 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_37, 0, x_36); -lean_ctor_set(x_37, 1, x_35); -return x_37; +x_37 = 0; +x_38 = lean_box(x_37); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_36); +return x_39; } } else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; uint8_t x_42; -x_38 = lean_ctor_get(x_29, 1); -lean_inc(x_38); +lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_40 = lean_ctor_get(x_29, 1); +lean_inc(x_40); lean_dec(x_29); -x_39 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_40 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3; -x_41 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_39, x_40, x_2, x_38); -x_42 = !lean_is_exclusive(x_41); -if (x_42 == 0) +x_41 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_42 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3; +x_43 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_41, x_42, x_1, x_40); +x_44 = !lean_is_exclusive(x_43); +if (x_44 == 0) { -lean_object* x_43; lean_object* x_44; -x_43 = lean_ctor_get(x_41, 0); +lean_object* x_45; uint8_t x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_43, 0); +lean_dec(x_45); +x_46 = 0; +x_47 = lean_box(x_46); +lean_ctor_set(x_43, 0, x_47); +return x_43; +} +else +{ +lean_object* x_48; uint8_t x_49; lean_object* x_50; lean_object* x_51; +x_48 = lean_ctor_get(x_43, 1); +lean_inc(x_48); lean_dec(x_43); -x_44 = lean_box(x_1); -lean_ctor_set(x_41, 0, x_44); -return x_41; -} -else -{ -lean_object* x_45; lean_object* x_46; lean_object* x_47; -x_45 = lean_ctor_get(x_41, 1); -lean_inc(x_45); -lean_dec(x_41); -x_46 = lean_box(x_1); -x_47 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_45); -return x_47; -} -} -} -} -else -{ -lean_free_object(x_19); -x_3 = x_22; -goto _start; -} -} -else -{ -uint8_t x_49; lean_object* x_50; -lean_dec(x_21); -lean_dec(x_6); -x_49 = 1; +x_49 = 0; x_50 = lean_box(x_49); -lean_ctor_set(x_19, 0, x_50); -return x_19; +x_51 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_51, 0, x_50); +lean_ctor_set(x_51, 1, x_48); +return x_51; } } -else -{ -lean_object* x_51; lean_object* x_52; uint8_t x_53; -x_51 = lean_ctor_get(x_19, 0); -x_52 = lean_ctor_get(x_19, 1); -lean_inc(x_52); -lean_inc(x_51); -lean_dec(x_19); -x_53 = lean_nat_dec_eq(x_51, x_8); -if (x_53 == 0) -{ -uint8_t x_54; -x_54 = lean_nat_dec_lt(x_51, x_6); -lean_dec(x_6); -lean_dec(x_51); -if (x_54 == 0) -{ -lean_object* x_55; uint8_t x_56; -x_55 = lean_ctor_get(x_52, 4); -lean_inc(x_55); -x_56 = lean_ctor_get_uint8(x_55, sizeof(void*)*1); -lean_dec(x_55); -if (x_56 == 0) -{ -lean_object* x_57; lean_object* x_58; -x_57 = lean_box(x_1); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_52); -return x_58; -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; uint8_t x_62; -x_59 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5; -x_60 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_59, x_2, x_52); -x_61 = lean_ctor_get(x_60, 0); -lean_inc(x_61); -x_62 = lean_unbox(x_61); -lean_dec(x_61); -if (x_62 == 0) -{ -lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; -x_63 = lean_ctor_get(x_60, 1); -lean_inc(x_63); -if (lean_is_exclusive(x_60)) { - lean_ctor_release(x_60, 0); - lean_ctor_release(x_60, 1); - x_64 = x_60; -} else { - lean_dec_ref(x_60); - x_64 = lean_box(0); -} -x_65 = lean_box(x_1); -if (lean_is_scalar(x_64)) { - x_66 = lean_alloc_ctor(0, 2, 0); -} else { - x_66 = x_64; -} -lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_66, 1, x_63); -return x_66; -} -else -{ -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; -x_67 = lean_ctor_get(x_60, 1); -lean_inc(x_67); -lean_dec(x_60); -x_68 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_69 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3; -x_70 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_68, x_69, x_2, x_67); -x_71 = lean_ctor_get(x_70, 1); -lean_inc(x_71); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - x_72 = x_70; -} else { - lean_dec_ref(x_70); - x_72 = lean_box(0); -} -x_73 = lean_box(x_1); -if (lean_is_scalar(x_72)) { - x_74 = lean_alloc_ctor(0, 2, 0); -} else { - x_74 = x_72; -} -lean_ctor_set(x_74, 0, x_73); -lean_ctor_set(x_74, 1, x_71); -return x_74; -} } } else { -x_3 = x_52; +lean_free_object(x_18); +x_2 = x_21; goto _start; } } else { -uint8_t x_76; lean_object* x_77; lean_object* x_78; -lean_dec(x_51); -lean_dec(x_6); -x_76 = 1; -x_77 = lean_box(x_76); -x_78 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_78, 0, x_77); -lean_ctor_set(x_78, 1, x_52); -return x_78; +uint8_t x_53; lean_object* x_54; +lean_dec(x_20); +lean_dec(x_5); +x_53 = 1; +x_54 = lean_box(x_53); +lean_ctor_set(x_18, 0, x_54); +return x_18; +} +} +else +{ +lean_object* x_55; lean_object* x_56; uint8_t x_57; +x_55 = lean_ctor_get(x_18, 0); +x_56 = lean_ctor_get(x_18, 1); +lean_inc(x_56); +lean_inc(x_55); +lean_dec(x_18); +x_57 = lean_nat_dec_eq(x_55, x_7); +if (x_57 == 0) +{ +uint8_t x_58; +x_58 = lean_nat_dec_lt(x_55, x_5); +lean_dec(x_5); +lean_dec(x_55); +if (x_58 == 0) +{ +lean_object* x_59; uint8_t x_60; +x_59 = lean_ctor_get(x_56, 4); +lean_inc(x_59); +x_60 = lean_ctor_get_uint8(x_59, sizeof(void*)*1); +lean_dec(x_59); +if (x_60 == 0) +{ +uint8_t x_61; lean_object* x_62; lean_object* x_63; +x_61 = 0; +x_62 = lean_box(x_61); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_56); +return x_63; +} +else +{ +lean_object* x_64; lean_object* x_65; lean_object* x_66; uint8_t x_67; +x_64 = l_Lean_Meta_isLevelDefEqAux___main___closed__5; +x_65 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_64, x_1, x_56); +x_66 = lean_ctor_get(x_65, 0); +lean_inc(x_66); +x_67 = lean_unbox(x_66); +lean_dec(x_66); +if (x_67 == 0) +{ +lean_object* x_68; lean_object* x_69; uint8_t x_70; lean_object* x_71; lean_object* x_72; +x_68 = lean_ctor_get(x_65, 1); +lean_inc(x_68); +if (lean_is_exclusive(x_65)) { + lean_ctor_release(x_65, 0); + lean_ctor_release(x_65, 1); + x_69 = x_65; +} else { + lean_dec_ref(x_65); + x_69 = lean_box(0); +} +x_70 = 0; +x_71 = lean_box(x_70); +if (lean_is_scalar(x_69)) { + x_72 = lean_alloc_ctor(0, 2, 0); +} else { + x_72 = x_69; +} +lean_ctor_set(x_72, 0, x_71); +lean_ctor_set(x_72, 1, x_68); +return x_72; +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; uint8_t x_79; lean_object* x_80; lean_object* x_81; +x_73 = lean_ctor_get(x_65, 1); +lean_inc(x_73); +lean_dec(x_65); +x_74 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_75 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3; +x_76 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_74, x_75, x_1, x_73); +x_77 = lean_ctor_get(x_76, 1); +lean_inc(x_77); +if (lean_is_exclusive(x_76)) { + lean_ctor_release(x_76, 0); + lean_ctor_release(x_76, 1); + x_78 = x_76; +} else { + lean_dec_ref(x_76); + x_78 = lean_box(0); +} +x_79 = 0; +x_80 = lean_box(x_79); +if (lean_is_scalar(x_78)) { + x_81 = lean_alloc_ctor(0, 2, 0); +} else { + x_81 = x_78; +} +lean_ctor_set(x_81, 0, x_80); +lean_ctor_set(x_81, 1, x_77); +return x_81; +} +} +} +else +{ +x_2 = x_56; +goto _start; +} +} +else +{ +uint8_t x_83; lean_object* x_84; lean_object* x_85; +lean_dec(x_55); +lean_dec(x_5); +x_83 = 1; +x_84 = lean_box(x_83); +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_84); +lean_ctor_set(x_85, 1, x_56); +return x_85; } } } } else { -uint8_t x_79; -lean_dec(x_6); -x_79 = !lean_is_exclusive(x_11); -if (x_79 == 0) +uint8_t x_86; +lean_dec(x_5); +x_86 = !lean_is_exclusive(x_10); +if (x_86 == 0) { -return x_11; +return x_10; } else { -lean_object* x_80; lean_object* x_81; lean_object* x_82; -x_80 = lean_ctor_get(x_11, 0); -x_81 = lean_ctor_get(x_11, 1); -lean_inc(x_81); -lean_inc(x_80); -lean_dec(x_11); -x_82 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_82, 0, x_80); -lean_ctor_set(x_82, 1, x_81); -return x_82; +lean_object* x_87; lean_object* x_88; lean_object* x_89; +x_87 = lean_ctor_get(x_10, 0); +x_88 = lean_ctor_get(x_10, 1); +lean_inc(x_88); +lean_inc(x_87); +lean_dec(x_10); +x_89 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_89, 0, x_87); +lean_ctor_set(x_89, 1, x_88); +return x_89; } } } } else { -uint8_t x_102; lean_object* x_103; -lean_dec(x_6); -x_102 = 1; -x_103 = lean_box(x_102); -lean_ctor_set(x_4, 0, x_103); -return x_4; +uint8_t x_109; lean_object* x_110; +lean_dec(x_5); +x_109 = 1; +x_110 = lean_box(x_109); +lean_ctor_set(x_3, 0, x_110); +return x_3; } } else { -lean_object* x_104; lean_object* x_105; lean_object* x_106; uint8_t x_107; -x_104 = lean_ctor_get(x_4, 0); -x_105 = lean_ctor_get(x_4, 1); -lean_inc(x_105); -lean_inc(x_104); -lean_dec(x_4); -x_106 = lean_unsigned_to_nat(0u); -x_107 = lean_nat_dec_eq(x_104, x_106); -if (x_107 == 0) -{ -lean_object* x_108; lean_object* x_151; uint8_t x_152; -x_151 = lean_ctor_get(x_105, 4); -lean_inc(x_151); -x_152 = lean_ctor_get_uint8(x_151, sizeof(void*)*1); -lean_dec(x_151); -if (x_152 == 0) -{ -x_108 = x_105; -goto block_150; -} -else -{ -lean_object* x_153; lean_object* x_154; lean_object* x_155; uint8_t x_156; -x_153 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5; -x_154 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_153, x_2, x_105); -x_155 = lean_ctor_get(x_154, 0); -lean_inc(x_155); -x_156 = lean_unbox(x_155); -lean_dec(x_155); -if (x_156 == 0) -{ -lean_object* x_157; -x_157 = lean_ctor_get(x_154, 1); -lean_inc(x_157); -lean_dec(x_154); -x_108 = x_157; -goto block_150; -} -else -{ -lean_object* x_158; lean_object* x_159; lean_object* x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_158 = lean_ctor_get(x_154, 1); -lean_inc(x_158); -lean_dec(x_154); -lean_inc(x_104); -x_159 = l_Nat_repr(x_104); -x_160 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_160, 0, x_159); -x_161 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_161, 0, x_160); -x_162 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__6; -x_163 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_163, 0, x_162); -lean_ctor_set(x_163, 1, x_161); -x_164 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__9; -x_165 = lean_alloc_ctor(8, 2, 0); -lean_ctor_set(x_165, 0, x_163); -lean_ctor_set(x_165, 1, x_164); -x_166 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_167 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_166, x_165, x_2, x_158); -x_168 = lean_ctor_get(x_167, 1); -lean_inc(x_168); -lean_dec(x_167); -x_108 = x_168; -goto block_150; -} -} -block_150: -{ -lean_object* x_109; -x_109 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep(x_2, x_108); -if (lean_obj_tag(x_109) == 0) -{ -lean_object* x_110; uint8_t x_111; -x_110 = lean_ctor_get(x_109, 0); -lean_inc(x_110); -x_111 = lean_unbox(x_110); -if (x_111 == 0) -{ -lean_object* x_112; lean_object* x_113; lean_object* x_114; -lean_dec(x_104); -x_112 = lean_ctor_get(x_109, 1); +lean_object* x_111; lean_object* x_112; lean_object* x_113; uint8_t x_114; +x_111 = lean_ctor_get(x_3, 0); +x_112 = lean_ctor_get(x_3, 1); lean_inc(x_112); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_113 = x_109; -} else { - lean_dec_ref(x_109); - x_113 = lean_box(0); -} -if (lean_is_scalar(x_113)) { - x_114 = lean_alloc_ctor(0, 2, 0); -} else { - x_114 = x_113; -} -lean_ctor_set(x_114, 0, x_110); -lean_ctor_set(x_114, 1, x_112); -return x_114; +lean_inc(x_111); +lean_dec(x_3); +x_113 = lean_unsigned_to_nat(0u); +x_114 = lean_nat_dec_eq(x_111, x_113); +if (x_114 == 0) +{ +lean_object* x_115; lean_object* x_161; uint8_t x_162; +x_161 = lean_ctor_get(x_112, 4); +lean_inc(x_161); +x_162 = lean_ctor_get_uint8(x_161, sizeof(void*)*1); +lean_dec(x_161); +if (x_162 == 0) +{ +x_115 = x_112; +goto block_160; } else { -lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; uint8_t x_120; -lean_dec(x_110); -x_115 = lean_ctor_get(x_109, 1); -lean_inc(x_115); -lean_dec(x_109); -x_116 = l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___rarg(x_115); +lean_object* x_163; lean_object* x_164; lean_object* x_165; uint8_t x_166; +x_163 = l_Lean_Meta_isLevelDefEqAux___main___closed__5; +x_164 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_163, x_1, x_112); +x_165 = lean_ctor_get(x_164, 0); +lean_inc(x_165); +x_166 = lean_unbox(x_165); +lean_dec(x_165); +if (x_166 == 0) +{ +lean_object* x_167; +x_167 = lean_ctor_get(x_164, 1); +lean_inc(x_167); +lean_dec(x_164); +x_115 = x_167; +goto block_160; +} +else +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; +x_168 = lean_ctor_get(x_164, 1); +lean_inc(x_168); +lean_dec(x_164); +lean_inc(x_111); +x_169 = l_Nat_repr(x_111); +x_170 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_170, 0, x_169); +x_171 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_171, 0, x_170); +x_172 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__6; +x_173 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_173, 0, x_172); +lean_ctor_set(x_173, 1, x_171); +x_174 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__9; +x_175 = lean_alloc_ctor(8, 2, 0); +lean_ctor_set(x_175, 0, x_173); +lean_ctor_set(x_175, 1, x_174); +x_176 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_177 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_176, x_175, x_1, x_168); +x_178 = lean_ctor_get(x_177, 1); +lean_inc(x_178); +lean_dec(x_177); +x_115 = x_178; +goto block_160; +} +} +block_160: +{ +lean_object* x_116; +x_116 = l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep(x_1, x_115); +if (lean_obj_tag(x_116) == 0) +{ +lean_object* x_117; uint8_t x_118; x_117 = lean_ctor_get(x_116, 0); lean_inc(x_117); -x_118 = lean_ctor_get(x_116, 1); -lean_inc(x_118); +x_118 = lean_unbox(x_117); +if (x_118 == 0) +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +lean_dec(x_111); +x_119 = lean_ctor_get(x_116, 1); +lean_inc(x_119); if (lean_is_exclusive(x_116)) { lean_ctor_release(x_116, 0); lean_ctor_release(x_116, 1); - x_119 = x_116; + x_120 = x_116; } else { lean_dec_ref(x_116); - x_119 = lean_box(0); + x_120 = lean_box(0); } -x_120 = lean_nat_dec_eq(x_117, x_106); -if (x_120 == 0) -{ -uint8_t x_121; -x_121 = lean_nat_dec_lt(x_117, x_104); -lean_dec(x_104); -lean_dec(x_117); -if (x_121 == 0) -{ -lean_object* x_122; uint8_t x_123; -x_122 = lean_ctor_get(x_118, 4); -lean_inc(x_122); -x_123 = lean_ctor_get_uint8(x_122, sizeof(void*)*1); -lean_dec(x_122); -if (x_123 == 0) -{ -lean_object* x_124; lean_object* x_125; -x_124 = lean_box(x_1); -if (lean_is_scalar(x_119)) { - x_125 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_120)) { + x_121 = lean_alloc_ctor(0, 2, 0); } else { - x_125 = x_119; + x_121 = x_120; } -lean_ctor_set(x_125, 0, x_124); -lean_ctor_set(x_125, 1, x_118); -return x_125; +lean_ctor_set(x_121, 0, x_117); +lean_ctor_set(x_121, 1, x_119); +return x_121; } else { -lean_object* x_126; lean_object* x_127; lean_object* x_128; uint8_t x_129; -lean_dec(x_119); -x_126 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5; -x_127 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_126, x_2, x_118); -x_128 = lean_ctor_get(x_127, 0); -lean_inc(x_128); -x_129 = lean_unbox(x_128); -lean_dec(x_128); -if (x_129 == 0) -{ -lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; -x_130 = lean_ctor_get(x_127, 1); -lean_inc(x_130); -if (lean_is_exclusive(x_127)) { - lean_ctor_release(x_127, 0); - lean_ctor_release(x_127, 1); - x_131 = x_127; +lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; uint8_t x_127; +lean_dec(x_117); +x_122 = lean_ctor_get(x_116, 1); +lean_inc(x_122); +lean_dec(x_116); +x_123 = l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___rarg(x_122); +x_124 = lean_ctor_get(x_123, 0); +lean_inc(x_124); +x_125 = lean_ctor_get(x_123, 1); +lean_inc(x_125); +if (lean_is_exclusive(x_123)) { + lean_ctor_release(x_123, 0); + lean_ctor_release(x_123, 1); + x_126 = x_123; } else { - lean_dec_ref(x_127); - x_131 = lean_box(0); + lean_dec_ref(x_123); + x_126 = lean_box(0); } -x_132 = lean_box(x_1); -if (lean_is_scalar(x_131)) { +x_127 = lean_nat_dec_eq(x_124, x_113); +if (x_127 == 0) +{ +uint8_t x_128; +x_128 = lean_nat_dec_lt(x_124, x_111); +lean_dec(x_111); +lean_dec(x_124); +if (x_128 == 0) +{ +lean_object* x_129; uint8_t x_130; +x_129 = lean_ctor_get(x_125, 4); +lean_inc(x_129); +x_130 = lean_ctor_get_uint8(x_129, sizeof(void*)*1); +lean_dec(x_129); +if (x_130 == 0) +{ +uint8_t x_131; lean_object* x_132; lean_object* x_133; +x_131 = 0; +x_132 = lean_box(x_131); +if (lean_is_scalar(x_126)) { x_133 = lean_alloc_ctor(0, 2, 0); } else { - x_133 = x_131; + x_133 = x_126; } lean_ctor_set(x_133, 0, x_132); -lean_ctor_set(x_133, 1, x_130); +lean_ctor_set(x_133, 1, x_125); return x_133; } else { -lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; -x_134 = lean_ctor_get(x_127, 1); -lean_inc(x_134); -lean_dec(x_127); -x_135 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_136 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3; -x_137 = l___private_Init_Lean_Trace_3__addTrace___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__2(x_135, x_136, x_2, x_134); -x_138 = lean_ctor_get(x_137, 1); +lean_object* x_134; lean_object* x_135; lean_object* x_136; uint8_t x_137; +lean_dec(x_126); +x_134 = l_Lean_Meta_isLevelDefEqAux___main___closed__5; +x_135 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_134, x_1, x_125); +x_136 = lean_ctor_get(x_135, 0); +lean_inc(x_136); +x_137 = lean_unbox(x_136); +lean_dec(x_136); +if (x_137 == 0) +{ +lean_object* x_138; lean_object* x_139; uint8_t x_140; lean_object* x_141; lean_object* x_142; +x_138 = lean_ctor_get(x_135, 1); lean_inc(x_138); -if (lean_is_exclusive(x_137)) { - lean_ctor_release(x_137, 0); - lean_ctor_release(x_137, 1); - x_139 = x_137; +if (lean_is_exclusive(x_135)) { + lean_ctor_release(x_135, 0); + lean_ctor_release(x_135, 1); + x_139 = x_135; } else { - lean_dec_ref(x_137); + lean_dec_ref(x_135); x_139 = lean_box(0); } -x_140 = lean_box(x_1); +x_140 = 0; +x_141 = lean_box(x_140); if (lean_is_scalar(x_139)) { - x_141 = lean_alloc_ctor(0, 2, 0); + x_142 = lean_alloc_ctor(0, 2, 0); } else { - x_141 = x_139; + x_142 = x_139; } -lean_ctor_set(x_141, 0, x_140); -lean_ctor_set(x_141, 1, x_138); -return x_141; +lean_ctor_set(x_142, 0, x_141); +lean_ctor_set(x_142, 1, x_138); +return x_142; +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; uint8_t x_149; lean_object* x_150; lean_object* x_151; +x_143 = lean_ctor_get(x_135, 1); +lean_inc(x_143); +lean_dec(x_135); +x_144 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_145 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3; +x_146 = l___private_Init_Lean_Trace_3__addTrace___at_Lean_Meta_isLevelDefEqAux___main___spec__2(x_144, x_145, x_1, x_143); +x_147 = lean_ctor_get(x_146, 1); +lean_inc(x_147); +if (lean_is_exclusive(x_146)) { + lean_ctor_release(x_146, 0); + lean_ctor_release(x_146, 1); + x_148 = x_146; +} else { + lean_dec_ref(x_146); + x_148 = lean_box(0); +} +x_149 = 0; +x_150 = lean_box(x_149); +if (lean_is_scalar(x_148)) { + x_151 = lean_alloc_ctor(0, 2, 0); +} else { + x_151 = x_148; +} +lean_ctor_set(x_151, 0, x_150); +lean_ctor_set(x_151, 1, x_147); +return x_151; } } } else { -lean_dec(x_119); -x_3 = x_118; +lean_dec(x_126); +x_2 = x_125; goto _start; } } else { -uint8_t x_143; lean_object* x_144; lean_object* x_145; -lean_dec(x_117); -lean_dec(x_104); -x_143 = 1; -x_144 = lean_box(x_143); -if (lean_is_scalar(x_119)) { - x_145 = lean_alloc_ctor(0, 2, 0); +uint8_t x_153; lean_object* x_154; lean_object* x_155; +lean_dec(x_124); +lean_dec(x_111); +x_153 = 1; +x_154 = lean_box(x_153); +if (lean_is_scalar(x_126)) { + x_155 = lean_alloc_ctor(0, 2, 0); } else { - x_145 = x_119; + x_155 = x_126; } -lean_ctor_set(x_145, 0, x_144); -lean_ctor_set(x_145, 1, x_118); -return x_145; +lean_ctor_set(x_155, 0, x_154); +lean_ctor_set(x_155, 1, x_125); +return x_155; } } } else { -lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; -lean_dec(x_104); -x_146 = lean_ctor_get(x_109, 0); -lean_inc(x_146); -x_147 = lean_ctor_get(x_109, 1); -lean_inc(x_147); -if (lean_is_exclusive(x_109)) { - lean_ctor_release(x_109, 0); - lean_ctor_release(x_109, 1); - x_148 = x_109; +lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; +lean_dec(x_111); +x_156 = lean_ctor_get(x_116, 0); +lean_inc(x_156); +x_157 = lean_ctor_get(x_116, 1); +lean_inc(x_157); +if (lean_is_exclusive(x_116)) { + lean_ctor_release(x_116, 0); + lean_ctor_release(x_116, 1); + x_158 = x_116; } else { - lean_dec_ref(x_109); - x_148 = lean_box(0); + lean_dec_ref(x_116); + x_158 = lean_box(0); } -if (lean_is_scalar(x_148)) { - x_149 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_158)) { + x_159 = lean_alloc_ctor(1, 2, 0); } else { - x_149 = x_148; + x_159 = x_158; } -lean_ctor_set(x_149, 0, x_146); -lean_ctor_set(x_149, 1, x_147); -return x_149; +lean_ctor_set(x_159, 0, x_156); +lean_ctor_set(x_159, 1, x_157); +return x_159; } } } else { -uint8_t x_169; lean_object* x_170; lean_object* x_171; -lean_dec(x_104); -x_169 = 1; -x_170 = lean_box(x_169); -x_171 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_171, 0, x_170); -lean_ctor_set(x_171, 1, x_105); -return x_171; +uint8_t x_179; lean_object* x_180; lean_object* x_181; +lean_dec(x_111); +x_179 = 1; +x_180 = lean_box(x_179); +x_181 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_181, 0, x_180); +lean_ctor_set(x_181, 1, x_112); +return x_181; } } } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main(lean_object* x_1) { _start: { -uint8_t x_4; lean_object* x_5; -x_4 = lean_unbox(x_1); +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___boxed), 2, 0); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_2); lean_dec(x_1); -x_5 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_4, x_2, x_3); -lean_dec(x_2); -return x_5; +return x_3; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux(uint8_t x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___boxed(lean_object* x_1) { _start: { -lean_object* x_4; -x_4 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_1, x_2, x_3); -return x_4; -} -} -lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -uint8_t x_4; lean_object* x_5; -x_4 = lean_unbox(x_1); +lean_object* x_2; +x_2 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main(x_1); lean_dec(x_1); -x_5 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux(x_4, x_2, x_3); -lean_dec(x_2); -return x_5; +return x_2; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__1() { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___rarg(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_2); +return x_3; +} +} +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___rarg___boxed), 2, 0); +return x_2; +} +} +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___rarg___boxed(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; +x_3 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___rarg(x_1, x_2); +lean_dec(x_1); +return x_3; +} +} +lean_object* l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___boxed(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux(x_1); +lean_dec(x_1); +return x_2; +} +} +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__1() { _start: { lean_object* x_1; @@ -4583,812 +4783,812 @@ x_1 = lean_mk_string("postponed"); return x_1; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__1; +x_1 = l_Lean_Meta_isLevelDefEqAux___main___closed__4; +x_2 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__3() { +lean_object* _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__3() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = l_Lean_SimpleMonadTracerAdapter_isTracingEnabledFor___rarg___lambda__1___closed__2; -x_2 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2; +x_2 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2; x_3 = l_Lean_Name_append___main(x_1, x_2); return x_3; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(uint8_t x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(lean_object* x_1, lean_object* x_2) { _start: { -lean_object* x_4; uint8_t x_5; -x_4 = l___private_Init_Lean_Meta_LevelDefEq_8__getNumPostponed___rarg(x_3); -x_5 = !lean_is_exclusive(x_4); -if (x_5 == 0) +lean_object* x_3; uint8_t x_4; +x_3 = l___private_Init_Lean_Meta_LevelDefEq_7__getNumPostponed___rarg(x_2); +x_4 = !lean_is_exclusive(x_3); +if (x_4 == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; uint8_t x_8; +x_5 = lean_ctor_get(x_3, 0); +x_6 = lean_ctor_get(x_3, 1); +x_7 = lean_unsigned_to_nat(0u); +x_8 = lean_nat_dec_eq(x_5, x_7); +lean_dec(x_5); +if (x_8 == 0) +{ +uint8_t x_9; lean_object* x_10; lean_object* x_185; uint8_t x_186; +lean_free_object(x_3); +x_185 = lean_ctor_get(x_6, 4); +lean_inc(x_185); +x_186 = lean_ctor_get_uint8(x_185, sizeof(void*)*1); +lean_dec(x_185); +if (x_186 == 0) +{ +uint8_t x_187; +x_187 = 0; +x_9 = x_187; +x_10 = x_6; +goto block_184; +} +else +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; uint8_t x_192; +x_188 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__3; +x_189 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_188, x_1, x_6); +x_190 = lean_ctor_get(x_189, 0); +lean_inc(x_190); +x_191 = lean_ctor_get(x_189, 1); +lean_inc(x_191); +lean_dec(x_189); +x_192 = lean_unbox(x_190); +lean_dec(x_190); +x_9 = x_192; +x_10 = x_191; +goto block_184; +} +block_184: { -lean_object* x_6; lean_object* x_7; lean_object* x_8; uint8_t x_9; -x_6 = lean_ctor_get(x_4, 0); -x_7 = lean_ctor_get(x_4, 1); -x_8 = lean_unsigned_to_nat(0u); -x_9 = lean_nat_dec_eq(x_6, x_8); -lean_dec(x_6); if (x_9 == 0) { -uint8_t x_10; lean_object* x_11; lean_object* x_186; uint8_t x_187; -lean_free_object(x_4); -x_186 = lean_ctor_get(x_7, 4); -lean_inc(x_186); -x_187 = lean_ctor_get_uint8(x_186, sizeof(void*)*1); -lean_dec(x_186); -if (x_187 == 0) +uint8_t x_11; +x_11 = !lean_is_exclusive(x_10); +if (x_11 == 0) { -uint8_t x_188; -x_188 = 0; -x_10 = x_188; -x_11 = x_7; -goto block_185; -} -else +lean_object* x_12; uint8_t x_13; +x_12 = lean_ctor_get(x_10, 4); +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) { -lean_object* x_189; lean_object* x_190; lean_object* x_191; lean_object* x_192; uint8_t x_193; -x_189 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__3; -x_190 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_189, x_2, x_7); -x_191 = lean_ctor_get(x_190, 0); -lean_inc(x_191); -x_192 = lean_ctor_get(x_190, 1); -lean_inc(x_192); -lean_dec(x_190); -x_193 = lean_unbox(x_191); -lean_dec(x_191); -x_10 = x_193; -x_11 = x_192; -goto block_185; -} -block_185: +uint8_t x_14; lean_object* x_15; +x_14 = 1; +lean_ctor_set_uint8(x_12, sizeof(void*)*1, x_14); +x_15 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_10); +if (lean_obj_tag(x_15) == 0) { -if (x_10 == 0) -{ -uint8_t x_12; -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) -{ -lean_object* x_13; uint8_t x_14; -x_13 = lean_ctor_get(x_11, 4); -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -uint8_t x_15; lean_object* x_16; -x_15 = 1; -lean_ctor_set_uint8(x_13, sizeof(void*)*1, x_15); -x_16 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_1, x_2, x_11); -if (lean_obj_tag(x_16) == 0) -{ -lean_object* x_17; lean_object* x_18; uint8_t x_19; -x_17 = lean_ctor_get(x_16, 1); +lean_object* x_16; lean_object* x_17; uint8_t x_18; +x_16 = lean_ctor_get(x_15, 1); +lean_inc(x_16); +x_17 = lean_ctor_get(x_16, 4); lean_inc(x_17); -x_18 = lean_ctor_get(x_17, 4); -lean_inc(x_18); -x_19 = !lean_is_exclusive(x_16); -if (x_19 == 0) +x_18 = !lean_is_exclusive(x_15); +if (x_18 == 0) { -lean_object* x_20; uint8_t x_21; -x_20 = lean_ctor_get(x_16, 1); -lean_dec(x_20); -x_21 = !lean_is_exclusive(x_17); -if (x_21 == 0) +lean_object* x_19; uint8_t x_20; +x_19 = lean_ctor_get(x_15, 1); +lean_dec(x_19); +x_20 = !lean_is_exclusive(x_16); +if (x_20 == 0) { -lean_object* x_22; uint8_t x_23; -x_22 = lean_ctor_get(x_17, 4); -lean_dec(x_22); -x_23 = !lean_is_exclusive(x_18); -if (x_23 == 0) +lean_object* x_21; uint8_t x_22; +x_21 = lean_ctor_get(x_16, 4); +lean_dec(x_21); +x_22 = !lean_is_exclusive(x_17); +if (x_22 == 0) { -uint8_t x_24; -x_24 = 0; -lean_ctor_set_uint8(x_18, sizeof(void*)*1, x_24); -return x_16; +uint8_t x_23; +x_23 = 0; +lean_ctor_set_uint8(x_17, sizeof(void*)*1, x_23); +return x_15; } else { -lean_object* x_25; uint8_t x_26; lean_object* x_27; -x_25 = lean_ctor_get(x_18, 0); -lean_inc(x_25); -lean_dec(x_18); -x_26 = 0; -x_27 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_27, 0, x_25); -lean_ctor_set_uint8(x_27, sizeof(void*)*1, x_26); -lean_ctor_set(x_17, 4, x_27); -return x_16; +lean_object* x_24; uint8_t x_25; lean_object* x_26; +x_24 = lean_ctor_get(x_17, 0); +lean_inc(x_24); +lean_dec(x_17); +x_25 = 0; +x_26 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_26, 0, x_24); +lean_ctor_set_uint8(x_26, sizeof(void*)*1, x_25); +lean_ctor_set(x_16, 4, x_26); +return x_15; } } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; uint8_t x_35; lean_object* x_36; lean_object* x_37; -x_28 = lean_ctor_get(x_17, 0); -x_29 = lean_ctor_get(x_17, 1); -x_30 = lean_ctor_get(x_17, 2); -x_31 = lean_ctor_get(x_17, 3); -x_32 = lean_ctor_get(x_17, 5); -lean_inc(x_32); +lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; lean_object* x_36; +x_27 = lean_ctor_get(x_16, 0); +x_28 = lean_ctor_get(x_16, 1); +x_29 = lean_ctor_get(x_16, 2); +x_30 = lean_ctor_get(x_16, 3); +x_31 = lean_ctor_get(x_16, 5); lean_inc(x_31); lean_inc(x_30); lean_inc(x_29); lean_inc(x_28); -lean_dec(x_17); -x_33 = lean_ctor_get(x_18, 0); -lean_inc(x_33); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - x_34 = x_18; -} else { - lean_dec_ref(x_18); - x_34 = lean_box(0); -} -x_35 = 0; -if (lean_is_scalar(x_34)) { - x_36 = lean_alloc_ctor(0, 1, 1); -} else { - x_36 = x_34; -} -lean_ctor_set(x_36, 0, x_33); -lean_ctor_set_uint8(x_36, sizeof(void*)*1, x_35); -x_37 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_37, 0, x_28); -lean_ctor_set(x_37, 1, x_29); -lean_ctor_set(x_37, 2, x_30); -lean_ctor_set(x_37, 3, x_31); -lean_ctor_set(x_37, 4, x_36); -lean_ctor_set(x_37, 5, x_32); -lean_ctor_set(x_16, 1, x_37); -return x_16; -} -} -else -{ -lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; uint8_t x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; -x_38 = lean_ctor_get(x_16, 0); -lean_inc(x_38); +lean_inc(x_27); lean_dec(x_16); -x_39 = lean_ctor_get(x_17, 0); -lean_inc(x_39); -x_40 = lean_ctor_get(x_17, 1); -lean_inc(x_40); -x_41 = lean_ctor_get(x_17, 2); -lean_inc(x_41); -x_42 = lean_ctor_get(x_17, 3); -lean_inc(x_42); -x_43 = lean_ctor_get(x_17, 5); -lean_inc(x_43); +x_32 = lean_ctor_get(x_17, 0); +lean_inc(x_32); if (lean_is_exclusive(x_17)) { lean_ctor_release(x_17, 0); - lean_ctor_release(x_17, 1); - lean_ctor_release(x_17, 2); - lean_ctor_release(x_17, 3); - lean_ctor_release(x_17, 4); - lean_ctor_release(x_17, 5); - x_44 = x_17; + x_33 = x_17; } else { lean_dec_ref(x_17); - x_44 = lean_box(0); + x_33 = lean_box(0); } -x_45 = lean_ctor_get(x_18, 0); -lean_inc(x_45); -if (lean_is_exclusive(x_18)) { - lean_ctor_release(x_18, 0); - x_46 = x_18; +x_34 = 0; +if (lean_is_scalar(x_33)) { + x_35 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_18); - x_46 = lean_box(0); + x_35 = x_33; } -x_47 = 0; -if (lean_is_scalar(x_46)) { - x_48 = lean_alloc_ctor(0, 1, 1); -} else { - x_48 = x_46; -} -lean_ctor_set(x_48, 0, x_45); -lean_ctor_set_uint8(x_48, sizeof(void*)*1, x_47); -if (lean_is_scalar(x_44)) { - x_49 = lean_alloc_ctor(0, 6, 0); -} else { - x_49 = x_44; -} -lean_ctor_set(x_49, 0, x_39); -lean_ctor_set(x_49, 1, x_40); -lean_ctor_set(x_49, 2, x_41); -lean_ctor_set(x_49, 3, x_42); -lean_ctor_set(x_49, 4, x_48); -lean_ctor_set(x_49, 5, x_43); -x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_38); -lean_ctor_set(x_50, 1, x_49); -return x_50; +lean_ctor_set(x_35, 0, x_32); +lean_ctor_set_uint8(x_35, sizeof(void*)*1, x_34); +x_36 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_36, 0, x_27); +lean_ctor_set(x_36, 1, x_28); +lean_ctor_set(x_36, 2, x_29); +lean_ctor_set(x_36, 3, x_30); +lean_ctor_set(x_36, 4, x_35); +lean_ctor_set(x_36, 5, x_31); +lean_ctor_set(x_15, 1, x_36); +return x_15; } } else { -lean_object* x_51; lean_object* x_52; uint8_t x_53; -x_51 = lean_ctor_get(x_16, 1); +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; uint8_t x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +x_37 = lean_ctor_get(x_15, 0); +lean_inc(x_37); +lean_dec(x_15); +x_38 = lean_ctor_get(x_16, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_16, 1); +lean_inc(x_39); +x_40 = lean_ctor_get(x_16, 2); +lean_inc(x_40); +x_41 = lean_ctor_get(x_16, 3); +lean_inc(x_41); +x_42 = lean_ctor_get(x_16, 5); +lean_inc(x_42); +if (lean_is_exclusive(x_16)) { + lean_ctor_release(x_16, 0); + lean_ctor_release(x_16, 1); + lean_ctor_release(x_16, 2); + lean_ctor_release(x_16, 3); + lean_ctor_release(x_16, 4); + lean_ctor_release(x_16, 5); + x_43 = x_16; +} else { + lean_dec_ref(x_16); + x_43 = lean_box(0); +} +x_44 = lean_ctor_get(x_17, 0); +lean_inc(x_44); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + x_45 = x_17; +} else { + lean_dec_ref(x_17); + x_45 = lean_box(0); +} +x_46 = 0; +if (lean_is_scalar(x_45)) { + x_47 = lean_alloc_ctor(0, 1, 1); +} else { + x_47 = x_45; +} +lean_ctor_set(x_47, 0, x_44); +lean_ctor_set_uint8(x_47, sizeof(void*)*1, x_46); +if (lean_is_scalar(x_43)) { + x_48 = lean_alloc_ctor(0, 6, 0); +} else { + x_48 = x_43; +} +lean_ctor_set(x_48, 0, x_38); +lean_ctor_set(x_48, 1, x_39); +lean_ctor_set(x_48, 2, x_40); +lean_ctor_set(x_48, 3, x_41); +lean_ctor_set(x_48, 4, x_47); +lean_ctor_set(x_48, 5, x_42); +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_37); +lean_ctor_set(x_49, 1, x_48); +return x_49; +} +} +else +{ +lean_object* x_50; lean_object* x_51; uint8_t x_52; +x_50 = lean_ctor_get(x_15, 1); +lean_inc(x_50); +x_51 = lean_ctor_get(x_50, 4); lean_inc(x_51); -x_52 = lean_ctor_get(x_51, 4); -lean_inc(x_52); -x_53 = !lean_is_exclusive(x_16); -if (x_53 == 0) +x_52 = !lean_is_exclusive(x_15); +if (x_52 == 0) { -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_16, 1); -lean_dec(x_54); -x_55 = !lean_is_exclusive(x_51); -if (x_55 == 0) +lean_object* x_53; uint8_t x_54; +x_53 = lean_ctor_get(x_15, 1); +lean_dec(x_53); +x_54 = !lean_is_exclusive(x_50); +if (x_54 == 0) { -lean_object* x_56; uint8_t x_57; -x_56 = lean_ctor_get(x_51, 4); -lean_dec(x_56); -x_57 = !lean_is_exclusive(x_52); -if (x_57 == 0) +lean_object* x_55; uint8_t x_56; +x_55 = lean_ctor_get(x_50, 4); +lean_dec(x_55); +x_56 = !lean_is_exclusive(x_51); +if (x_56 == 0) { -uint8_t x_58; -x_58 = 0; -lean_ctor_set_uint8(x_52, sizeof(void*)*1, x_58); -return x_16; +uint8_t x_57; +x_57 = 0; +lean_ctor_set_uint8(x_51, sizeof(void*)*1, x_57); +return x_15; } else { -lean_object* x_59; uint8_t x_60; lean_object* x_61; -x_59 = lean_ctor_get(x_52, 0); -lean_inc(x_59); -lean_dec(x_52); -x_60 = 0; -x_61 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_61, 0, x_59); -lean_ctor_set_uint8(x_61, sizeof(void*)*1, x_60); -lean_ctor_set(x_51, 4, x_61); -return x_16; +lean_object* x_58; uint8_t x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_51, 0); +lean_inc(x_58); +lean_dec(x_51); +x_59 = 0; +x_60 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_60, 0, x_58); +lean_ctor_set_uint8(x_60, sizeof(void*)*1, x_59); +lean_ctor_set(x_50, 4, x_60); +return x_15; } } else { -lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; lean_object* x_68; uint8_t x_69; lean_object* x_70; lean_object* x_71; -x_62 = lean_ctor_get(x_51, 0); -x_63 = lean_ctor_get(x_51, 1); -x_64 = lean_ctor_get(x_51, 2); -x_65 = lean_ctor_get(x_51, 3); -x_66 = lean_ctor_get(x_51, 5); -lean_inc(x_66); +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; uint8_t x_68; lean_object* x_69; lean_object* x_70; +x_61 = lean_ctor_get(x_50, 0); +x_62 = lean_ctor_get(x_50, 1); +x_63 = lean_ctor_get(x_50, 2); +x_64 = lean_ctor_get(x_50, 3); +x_65 = lean_ctor_get(x_50, 5); lean_inc(x_65); lean_inc(x_64); lean_inc(x_63); lean_inc(x_62); -lean_dec(x_51); -x_67 = lean_ctor_get(x_52, 0); -lean_inc(x_67); -if (lean_is_exclusive(x_52)) { - lean_ctor_release(x_52, 0); - x_68 = x_52; -} else { - lean_dec_ref(x_52); - x_68 = lean_box(0); -} -x_69 = 0; -if (lean_is_scalar(x_68)) { - x_70 = lean_alloc_ctor(0, 1, 1); -} else { - x_70 = x_68; -} -lean_ctor_set(x_70, 0, x_67); -lean_ctor_set_uint8(x_70, sizeof(void*)*1, x_69); -x_71 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_71, 0, x_62); -lean_ctor_set(x_71, 1, x_63); -lean_ctor_set(x_71, 2, x_64); -lean_ctor_set(x_71, 3, x_65); -lean_ctor_set(x_71, 4, x_70); -lean_ctor_set(x_71, 5, x_66); -lean_ctor_set(x_16, 1, x_71); -return x_16; -} -} -else -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; uint8_t x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; -x_72 = lean_ctor_get(x_16, 0); -lean_inc(x_72); -lean_dec(x_16); -x_73 = lean_ctor_get(x_51, 0); -lean_inc(x_73); -x_74 = lean_ctor_get(x_51, 1); -lean_inc(x_74); -x_75 = lean_ctor_get(x_51, 2); -lean_inc(x_75); -x_76 = lean_ctor_get(x_51, 3); -lean_inc(x_76); -x_77 = lean_ctor_get(x_51, 5); -lean_inc(x_77); +lean_inc(x_61); +lean_dec(x_50); +x_66 = lean_ctor_get(x_51, 0); +lean_inc(x_66); if (lean_is_exclusive(x_51)) { lean_ctor_release(x_51, 0); - lean_ctor_release(x_51, 1); - lean_ctor_release(x_51, 2); - lean_ctor_release(x_51, 3); - lean_ctor_release(x_51, 4); - lean_ctor_release(x_51, 5); - x_78 = x_51; + x_67 = x_51; } else { lean_dec_ref(x_51); - x_78 = lean_box(0); + x_67 = lean_box(0); } -x_79 = lean_ctor_get(x_52, 0); -lean_inc(x_79); -if (lean_is_exclusive(x_52)) { - lean_ctor_release(x_52, 0); - x_80 = x_52; +x_68 = 0; +if (lean_is_scalar(x_67)) { + x_69 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_52); - x_80 = lean_box(0); + x_69 = x_67; } -x_81 = 0; -if (lean_is_scalar(x_80)) { - x_82 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_69, 0, x_66); +lean_ctor_set_uint8(x_69, sizeof(void*)*1, x_68); +x_70 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_70, 0, x_61); +lean_ctor_set(x_70, 1, x_62); +lean_ctor_set(x_70, 2, x_63); +lean_ctor_set(x_70, 3, x_64); +lean_ctor_set(x_70, 4, x_69); +lean_ctor_set(x_70, 5, x_65); +lean_ctor_set(x_15, 1, x_70); +return x_15; +} +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; uint8_t x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; +x_71 = lean_ctor_get(x_15, 0); +lean_inc(x_71); +lean_dec(x_15); +x_72 = lean_ctor_get(x_50, 0); +lean_inc(x_72); +x_73 = lean_ctor_get(x_50, 1); +lean_inc(x_73); +x_74 = lean_ctor_get(x_50, 2); +lean_inc(x_74); +x_75 = lean_ctor_get(x_50, 3); +lean_inc(x_75); +x_76 = lean_ctor_get(x_50, 5); +lean_inc(x_76); +if (lean_is_exclusive(x_50)) { + lean_ctor_release(x_50, 0); + lean_ctor_release(x_50, 1); + lean_ctor_release(x_50, 2); + lean_ctor_release(x_50, 3); + lean_ctor_release(x_50, 4); + lean_ctor_release(x_50, 5); + x_77 = x_50; } else { - x_82 = x_80; + lean_dec_ref(x_50); + x_77 = lean_box(0); } -lean_ctor_set(x_82, 0, x_79); -lean_ctor_set_uint8(x_82, sizeof(void*)*1, x_81); -if (lean_is_scalar(x_78)) { - x_83 = lean_alloc_ctor(0, 6, 0); +x_78 = lean_ctor_get(x_51, 0); +lean_inc(x_78); +if (lean_is_exclusive(x_51)) { + lean_ctor_release(x_51, 0); + x_79 = x_51; } else { - x_83 = x_78; + lean_dec_ref(x_51); + x_79 = lean_box(0); } -lean_ctor_set(x_83, 0, x_73); -lean_ctor_set(x_83, 1, x_74); -lean_ctor_set(x_83, 2, x_75); -lean_ctor_set(x_83, 3, x_76); -lean_ctor_set(x_83, 4, x_82); -lean_ctor_set(x_83, 5, x_77); -x_84 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_84, 0, x_72); -lean_ctor_set(x_84, 1, x_83); -return x_84; +x_80 = 0; +if (lean_is_scalar(x_79)) { + x_81 = lean_alloc_ctor(0, 1, 1); +} else { + x_81 = x_79; +} +lean_ctor_set(x_81, 0, x_78); +lean_ctor_set_uint8(x_81, sizeof(void*)*1, x_80); +if (lean_is_scalar(x_77)) { + x_82 = lean_alloc_ctor(0, 6, 0); +} else { + x_82 = x_77; +} +lean_ctor_set(x_82, 0, x_72); +lean_ctor_set(x_82, 1, x_73); +lean_ctor_set(x_82, 2, x_74); +lean_ctor_set(x_82, 3, x_75); +lean_ctor_set(x_82, 4, x_81); +lean_ctor_set(x_82, 5, x_76); +x_83 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_83, 0, x_71); +lean_ctor_set(x_83, 1, x_82); +return x_83; } } } else { -lean_object* x_85; uint8_t x_86; lean_object* x_87; lean_object* x_88; -x_85 = lean_ctor_get(x_13, 0); -lean_inc(x_85); -lean_dec(x_13); -x_86 = 1; -x_87 = lean_alloc_ctor(0, 1, 1); -lean_ctor_set(x_87, 0, x_85); -lean_ctor_set_uint8(x_87, sizeof(void*)*1, x_86); -lean_ctor_set(x_11, 4, x_87); -x_88 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_1, x_2, x_11); -if (lean_obj_tag(x_88) == 0) +lean_object* x_84; uint8_t x_85; lean_object* x_86; lean_object* x_87; +x_84 = lean_ctor_get(x_12, 0); +lean_inc(x_84); +lean_dec(x_12); +x_85 = 1; +x_86 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_86, 0, x_84); +lean_ctor_set_uint8(x_86, sizeof(void*)*1, x_85); +lean_ctor_set(x_10, 4, x_86); +x_87 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_10); +if (lean_obj_tag(x_87) == 0) { -lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; uint8_t x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_89 = lean_ctor_get(x_88, 1); +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; uint8_t x_100; lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_88 = lean_ctor_get(x_87, 1); +lean_inc(x_88); +x_89 = lean_ctor_get(x_88, 4); lean_inc(x_89); -x_90 = lean_ctor_get(x_89, 4); +x_90 = lean_ctor_get(x_87, 0); lean_inc(x_90); -x_91 = lean_ctor_get(x_88, 0); -lean_inc(x_91); +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + x_91 = x_87; +} else { + lean_dec_ref(x_87); + x_91 = lean_box(0); +} +x_92 = lean_ctor_get(x_88, 0); +lean_inc(x_92); +x_93 = lean_ctor_get(x_88, 1); +lean_inc(x_93); +x_94 = lean_ctor_get(x_88, 2); +lean_inc(x_94); +x_95 = lean_ctor_get(x_88, 3); +lean_inc(x_95); +x_96 = lean_ctor_get(x_88, 5); +lean_inc(x_96); if (lean_is_exclusive(x_88)) { lean_ctor_release(x_88, 0); lean_ctor_release(x_88, 1); - x_92 = x_88; + lean_ctor_release(x_88, 2); + lean_ctor_release(x_88, 3); + lean_ctor_release(x_88, 4); + lean_ctor_release(x_88, 5); + x_97 = x_88; } else { lean_dec_ref(x_88); - x_92 = lean_box(0); + x_97 = lean_box(0); } -x_93 = lean_ctor_get(x_89, 0); -lean_inc(x_93); -x_94 = lean_ctor_get(x_89, 1); -lean_inc(x_94); -x_95 = lean_ctor_get(x_89, 2); -lean_inc(x_95); -x_96 = lean_ctor_get(x_89, 3); -lean_inc(x_96); -x_97 = lean_ctor_get(x_89, 5); -lean_inc(x_97); +x_98 = lean_ctor_get(x_89, 0); +lean_inc(x_98); if (lean_is_exclusive(x_89)) { lean_ctor_release(x_89, 0); - lean_ctor_release(x_89, 1); - lean_ctor_release(x_89, 2); - lean_ctor_release(x_89, 3); - lean_ctor_release(x_89, 4); - lean_ctor_release(x_89, 5); - x_98 = x_89; + x_99 = x_89; } else { lean_dec_ref(x_89); - x_98 = lean_box(0); + x_99 = lean_box(0); } -x_99 = lean_ctor_get(x_90, 0); -lean_inc(x_99); -if (lean_is_exclusive(x_90)) { - lean_ctor_release(x_90, 0); - x_100 = x_90; +x_100 = 0; +if (lean_is_scalar(x_99)) { + x_101 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_90); - x_100 = lean_box(0); + x_101 = x_99; } -x_101 = 0; -if (lean_is_scalar(x_100)) { - x_102 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_101, 0, x_98); +lean_ctor_set_uint8(x_101, sizeof(void*)*1, x_100); +if (lean_is_scalar(x_97)) { + x_102 = lean_alloc_ctor(0, 6, 0); } else { - x_102 = x_100; + x_102 = x_97; } -lean_ctor_set(x_102, 0, x_99); -lean_ctor_set_uint8(x_102, sizeof(void*)*1, x_101); -if (lean_is_scalar(x_98)) { - x_103 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_102, 0, x_92); +lean_ctor_set(x_102, 1, x_93); +lean_ctor_set(x_102, 2, x_94); +lean_ctor_set(x_102, 3, x_95); +lean_ctor_set(x_102, 4, x_101); +lean_ctor_set(x_102, 5, x_96); +if (lean_is_scalar(x_91)) { + x_103 = lean_alloc_ctor(0, 2, 0); } else { - x_103 = x_98; + x_103 = x_91; } -lean_ctor_set(x_103, 0, x_93); -lean_ctor_set(x_103, 1, x_94); -lean_ctor_set(x_103, 2, x_95); -lean_ctor_set(x_103, 3, x_96); -lean_ctor_set(x_103, 4, x_102); -lean_ctor_set(x_103, 5, x_97); -if (lean_is_scalar(x_92)) { - x_104 = lean_alloc_ctor(0, 2, 0); -} else { - x_104 = x_92; -} -lean_ctor_set(x_104, 0, x_91); -lean_ctor_set(x_104, 1, x_103); -return x_104; +lean_ctor_set(x_103, 0, x_90); +lean_ctor_set(x_103, 1, x_102); +return x_103; } else { -lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; uint8_t x_117; lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_105 = lean_ctor_get(x_88, 1); +lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; lean_object* x_109; lean_object* x_110; lean_object* x_111; lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; uint8_t x_116; lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_104 = lean_ctor_get(x_87, 1); +lean_inc(x_104); +x_105 = lean_ctor_get(x_104, 4); lean_inc(x_105); -x_106 = lean_ctor_get(x_105, 4); +x_106 = lean_ctor_get(x_87, 0); lean_inc(x_106); -x_107 = lean_ctor_get(x_88, 0); -lean_inc(x_107); -if (lean_is_exclusive(x_88)) { - lean_ctor_release(x_88, 0); - lean_ctor_release(x_88, 1); - x_108 = x_88; +if (lean_is_exclusive(x_87)) { + lean_ctor_release(x_87, 0); + lean_ctor_release(x_87, 1); + x_107 = x_87; } else { - lean_dec_ref(x_88); - x_108 = lean_box(0); + lean_dec_ref(x_87); + x_107 = lean_box(0); } -x_109 = lean_ctor_get(x_105, 0); +x_108 = lean_ctor_get(x_104, 0); +lean_inc(x_108); +x_109 = lean_ctor_get(x_104, 1); lean_inc(x_109); -x_110 = lean_ctor_get(x_105, 1); +x_110 = lean_ctor_get(x_104, 2); lean_inc(x_110); -x_111 = lean_ctor_get(x_105, 2); +x_111 = lean_ctor_get(x_104, 3); lean_inc(x_111); -x_112 = lean_ctor_get(x_105, 3); +x_112 = lean_ctor_get(x_104, 5); lean_inc(x_112); -x_113 = lean_ctor_get(x_105, 5); -lean_inc(x_113); +if (lean_is_exclusive(x_104)) { + lean_ctor_release(x_104, 0); + lean_ctor_release(x_104, 1); + lean_ctor_release(x_104, 2); + lean_ctor_release(x_104, 3); + lean_ctor_release(x_104, 4); + lean_ctor_release(x_104, 5); + x_113 = x_104; +} else { + lean_dec_ref(x_104); + x_113 = lean_box(0); +} +x_114 = lean_ctor_get(x_105, 0); +lean_inc(x_114); if (lean_is_exclusive(x_105)) { lean_ctor_release(x_105, 0); - lean_ctor_release(x_105, 1); - lean_ctor_release(x_105, 2); - lean_ctor_release(x_105, 3); - lean_ctor_release(x_105, 4); - lean_ctor_release(x_105, 5); - x_114 = x_105; + x_115 = x_105; } else { lean_dec_ref(x_105); - x_114 = lean_box(0); + x_115 = lean_box(0); } -x_115 = lean_ctor_get(x_106, 0); -lean_inc(x_115); -if (lean_is_exclusive(x_106)) { - lean_ctor_release(x_106, 0); - x_116 = x_106; +x_116 = 0; +if (lean_is_scalar(x_115)) { + x_117 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_106); - x_116 = lean_box(0); + x_117 = x_115; } -x_117 = 0; -if (lean_is_scalar(x_116)) { - x_118 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_117, 0, x_114); +lean_ctor_set_uint8(x_117, sizeof(void*)*1, x_116); +if (lean_is_scalar(x_113)) { + x_118 = lean_alloc_ctor(0, 6, 0); } else { - x_118 = x_116; + x_118 = x_113; } -lean_ctor_set(x_118, 0, x_115); -lean_ctor_set_uint8(x_118, sizeof(void*)*1, x_117); -if (lean_is_scalar(x_114)) { - x_119 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_118, 0, x_108); +lean_ctor_set(x_118, 1, x_109); +lean_ctor_set(x_118, 2, x_110); +lean_ctor_set(x_118, 3, x_111); +lean_ctor_set(x_118, 4, x_117); +lean_ctor_set(x_118, 5, x_112); +if (lean_is_scalar(x_107)) { + x_119 = lean_alloc_ctor(1, 2, 0); } else { - x_119 = x_114; + x_119 = x_107; } -lean_ctor_set(x_119, 0, x_109); -lean_ctor_set(x_119, 1, x_110); -lean_ctor_set(x_119, 2, x_111); -lean_ctor_set(x_119, 3, x_112); -lean_ctor_set(x_119, 4, x_118); -lean_ctor_set(x_119, 5, x_113); -if (lean_is_scalar(x_108)) { - x_120 = lean_alloc_ctor(1, 2, 0); -} else { - x_120 = x_108; -} -lean_ctor_set(x_120, 0, x_107); -lean_ctor_set(x_120, 1, x_119); -return x_120; +lean_ctor_set(x_119, 0, x_106); +lean_ctor_set(x_119, 1, x_118); +return x_119; } } } else { -lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; uint8_t x_129; lean_object* x_130; lean_object* x_131; lean_object* x_132; -x_121 = lean_ctor_get(x_11, 4); -x_122 = lean_ctor_get(x_11, 0); -x_123 = lean_ctor_get(x_11, 1); -x_124 = lean_ctor_get(x_11, 2); -x_125 = lean_ctor_get(x_11, 3); -x_126 = lean_ctor_get(x_11, 5); -lean_inc(x_126); -lean_inc(x_121); +lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; uint8_t x_128; lean_object* x_129; lean_object* x_130; lean_object* x_131; +x_120 = lean_ctor_get(x_10, 4); +x_121 = lean_ctor_get(x_10, 0); +x_122 = lean_ctor_get(x_10, 1); +x_123 = lean_ctor_get(x_10, 2); +x_124 = lean_ctor_get(x_10, 3); +x_125 = lean_ctor_get(x_10, 5); lean_inc(x_125); +lean_inc(x_120); lean_inc(x_124); lean_inc(x_123); lean_inc(x_122); -lean_dec(x_11); -x_127 = lean_ctor_get(x_121, 0); -lean_inc(x_127); -if (lean_is_exclusive(x_121)) { - lean_ctor_release(x_121, 0); - x_128 = x_121; +lean_inc(x_121); +lean_dec(x_10); +x_126 = lean_ctor_get(x_120, 0); +lean_inc(x_126); +if (lean_is_exclusive(x_120)) { + lean_ctor_release(x_120, 0); + x_127 = x_120; } else { - lean_dec_ref(x_121); - x_128 = lean_box(0); + lean_dec_ref(x_120); + x_127 = lean_box(0); } -x_129 = 1; -if (lean_is_scalar(x_128)) { - x_130 = lean_alloc_ctor(0, 1, 1); +x_128 = 1; +if (lean_is_scalar(x_127)) { + x_129 = lean_alloc_ctor(0, 1, 1); } else { - x_130 = x_128; + x_129 = x_127; } -lean_ctor_set(x_130, 0, x_127); -lean_ctor_set_uint8(x_130, sizeof(void*)*1, x_129); -x_131 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_131, 0, x_122); -lean_ctor_set(x_131, 1, x_123); -lean_ctor_set(x_131, 2, x_124); -lean_ctor_set(x_131, 3, x_125); -lean_ctor_set(x_131, 4, x_130); -lean_ctor_set(x_131, 5, x_126); -x_132 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_1, x_2, x_131); -if (lean_obj_tag(x_132) == 0) +lean_ctor_set(x_129, 0, x_126); +lean_ctor_set_uint8(x_129, sizeof(void*)*1, x_128); +x_130 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_130, 0, x_121); +lean_ctor_set(x_130, 1, x_122); +lean_ctor_set(x_130, 2, x_123); +lean_ctor_set(x_130, 3, x_124); +lean_ctor_set(x_130, 4, x_129); +lean_ctor_set(x_130, 5, x_125); +x_131 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_130); +if (lean_obj_tag(x_131) == 0) { -lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; uint8_t x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; -x_133 = lean_ctor_get(x_132, 1); +lean_object* x_132; lean_object* x_133; lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; uint8_t x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; +x_132 = lean_ctor_get(x_131, 1); +lean_inc(x_132); +x_133 = lean_ctor_get(x_132, 4); lean_inc(x_133); -x_134 = lean_ctor_get(x_133, 4); +x_134 = lean_ctor_get(x_131, 0); lean_inc(x_134); -x_135 = lean_ctor_get(x_132, 0); -lean_inc(x_135); +if (lean_is_exclusive(x_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_135 = x_131; +} else { + lean_dec_ref(x_131); + x_135 = lean_box(0); +} +x_136 = lean_ctor_get(x_132, 0); +lean_inc(x_136); +x_137 = lean_ctor_get(x_132, 1); +lean_inc(x_137); +x_138 = lean_ctor_get(x_132, 2); +lean_inc(x_138); +x_139 = lean_ctor_get(x_132, 3); +lean_inc(x_139); +x_140 = lean_ctor_get(x_132, 5); +lean_inc(x_140); if (lean_is_exclusive(x_132)) { lean_ctor_release(x_132, 0); lean_ctor_release(x_132, 1); - x_136 = x_132; + lean_ctor_release(x_132, 2); + lean_ctor_release(x_132, 3); + lean_ctor_release(x_132, 4); + lean_ctor_release(x_132, 5); + x_141 = x_132; } else { lean_dec_ref(x_132); - x_136 = lean_box(0); + x_141 = lean_box(0); } -x_137 = lean_ctor_get(x_133, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_133, 1); -lean_inc(x_138); -x_139 = lean_ctor_get(x_133, 2); -lean_inc(x_139); -x_140 = lean_ctor_get(x_133, 3); -lean_inc(x_140); -x_141 = lean_ctor_get(x_133, 5); -lean_inc(x_141); +x_142 = lean_ctor_get(x_133, 0); +lean_inc(x_142); if (lean_is_exclusive(x_133)) { lean_ctor_release(x_133, 0); - lean_ctor_release(x_133, 1); - lean_ctor_release(x_133, 2); - lean_ctor_release(x_133, 3); - lean_ctor_release(x_133, 4); - lean_ctor_release(x_133, 5); - x_142 = x_133; + x_143 = x_133; } else { lean_dec_ref(x_133); - x_142 = lean_box(0); + x_143 = lean_box(0); } -x_143 = lean_ctor_get(x_134, 0); -lean_inc(x_143); -if (lean_is_exclusive(x_134)) { - lean_ctor_release(x_134, 0); - x_144 = x_134; +x_144 = 0; +if (lean_is_scalar(x_143)) { + x_145 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_134); - x_144 = lean_box(0); + x_145 = x_143; } -x_145 = 0; -if (lean_is_scalar(x_144)) { - x_146 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_145, 0, x_142); +lean_ctor_set_uint8(x_145, sizeof(void*)*1, x_144); +if (lean_is_scalar(x_141)) { + x_146 = lean_alloc_ctor(0, 6, 0); } else { - x_146 = x_144; + x_146 = x_141; } -lean_ctor_set(x_146, 0, x_143); -lean_ctor_set_uint8(x_146, sizeof(void*)*1, x_145); -if (lean_is_scalar(x_142)) { - x_147 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_146, 0, x_136); +lean_ctor_set(x_146, 1, x_137); +lean_ctor_set(x_146, 2, x_138); +lean_ctor_set(x_146, 3, x_139); +lean_ctor_set(x_146, 4, x_145); +lean_ctor_set(x_146, 5, x_140); +if (lean_is_scalar(x_135)) { + x_147 = lean_alloc_ctor(0, 2, 0); } else { - x_147 = x_142; + x_147 = x_135; } -lean_ctor_set(x_147, 0, x_137); -lean_ctor_set(x_147, 1, x_138); -lean_ctor_set(x_147, 2, x_139); -lean_ctor_set(x_147, 3, x_140); -lean_ctor_set(x_147, 4, x_146); -lean_ctor_set(x_147, 5, x_141); -if (lean_is_scalar(x_136)) { - x_148 = lean_alloc_ctor(0, 2, 0); -} else { - x_148 = x_136; -} -lean_ctor_set(x_148, 0, x_135); -lean_ctor_set(x_148, 1, x_147); -return x_148; +lean_ctor_set(x_147, 0, x_134); +lean_ctor_set(x_147, 1, x_146); +return x_147; } else { -lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; uint8_t x_161; lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_149 = lean_ctor_get(x_132, 1); +lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; uint8_t x_160; lean_object* x_161; lean_object* x_162; lean_object* x_163; +x_148 = lean_ctor_get(x_131, 1); +lean_inc(x_148); +x_149 = lean_ctor_get(x_148, 4); lean_inc(x_149); -x_150 = lean_ctor_get(x_149, 4); +x_150 = lean_ctor_get(x_131, 0); lean_inc(x_150); -x_151 = lean_ctor_get(x_132, 0); -lean_inc(x_151); -if (lean_is_exclusive(x_132)) { - lean_ctor_release(x_132, 0); - lean_ctor_release(x_132, 1); - x_152 = x_132; +if (lean_is_exclusive(x_131)) { + lean_ctor_release(x_131, 0); + lean_ctor_release(x_131, 1); + x_151 = x_131; } else { - lean_dec_ref(x_132); - x_152 = lean_box(0); + lean_dec_ref(x_131); + x_151 = lean_box(0); } -x_153 = lean_ctor_get(x_149, 0); +x_152 = lean_ctor_get(x_148, 0); +lean_inc(x_152); +x_153 = lean_ctor_get(x_148, 1); lean_inc(x_153); -x_154 = lean_ctor_get(x_149, 1); +x_154 = lean_ctor_get(x_148, 2); lean_inc(x_154); -x_155 = lean_ctor_get(x_149, 2); +x_155 = lean_ctor_get(x_148, 3); lean_inc(x_155); -x_156 = lean_ctor_get(x_149, 3); +x_156 = lean_ctor_get(x_148, 5); lean_inc(x_156); -x_157 = lean_ctor_get(x_149, 5); -lean_inc(x_157); +if (lean_is_exclusive(x_148)) { + lean_ctor_release(x_148, 0); + lean_ctor_release(x_148, 1); + lean_ctor_release(x_148, 2); + lean_ctor_release(x_148, 3); + lean_ctor_release(x_148, 4); + lean_ctor_release(x_148, 5); + x_157 = x_148; +} else { + lean_dec_ref(x_148); + x_157 = lean_box(0); +} +x_158 = lean_ctor_get(x_149, 0); +lean_inc(x_158); if (lean_is_exclusive(x_149)) { lean_ctor_release(x_149, 0); - lean_ctor_release(x_149, 1); - lean_ctor_release(x_149, 2); - lean_ctor_release(x_149, 3); - lean_ctor_release(x_149, 4); - lean_ctor_release(x_149, 5); - x_158 = x_149; + x_159 = x_149; } else { lean_dec_ref(x_149); - x_158 = lean_box(0); + x_159 = lean_box(0); } -x_159 = lean_ctor_get(x_150, 0); -lean_inc(x_159); -if (lean_is_exclusive(x_150)) { - lean_ctor_release(x_150, 0); - x_160 = x_150; +x_160 = 0; +if (lean_is_scalar(x_159)) { + x_161 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_150); - x_160 = lean_box(0); + x_161 = x_159; } -x_161 = 0; -if (lean_is_scalar(x_160)) { - x_162 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_161, 0, x_158); +lean_ctor_set_uint8(x_161, sizeof(void*)*1, x_160); +if (lean_is_scalar(x_157)) { + x_162 = lean_alloc_ctor(0, 6, 0); } else { - x_162 = x_160; + x_162 = x_157; } -lean_ctor_set(x_162, 0, x_159); -lean_ctor_set_uint8(x_162, sizeof(void*)*1, x_161); -if (lean_is_scalar(x_158)) { - x_163 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_162, 0, x_152); +lean_ctor_set(x_162, 1, x_153); +lean_ctor_set(x_162, 2, x_154); +lean_ctor_set(x_162, 3, x_155); +lean_ctor_set(x_162, 4, x_161); +lean_ctor_set(x_162, 5, x_156); +if (lean_is_scalar(x_151)) { + x_163 = lean_alloc_ctor(1, 2, 0); } else { - x_163 = x_158; + x_163 = x_151; } -lean_ctor_set(x_163, 0, x_153); -lean_ctor_set(x_163, 1, x_154); -lean_ctor_set(x_163, 2, x_155); -lean_ctor_set(x_163, 3, x_156); -lean_ctor_set(x_163, 4, x_162); -lean_ctor_set(x_163, 5, x_157); -if (lean_is_scalar(x_152)) { - x_164 = lean_alloc_ctor(1, 2, 0); -} else { - x_164 = x_152; -} -lean_ctor_set(x_164, 0, x_151); -lean_ctor_set(x_164, 1, x_163); -return x_164; +lean_ctor_set(x_163, 0, x_150); +lean_ctor_set(x_163, 1, x_162); +return x_163; } } } else { -lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_165 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___rarg(x_11); -x_166 = lean_ctor_get(x_165, 0); +lean_object* x_164; lean_object* x_165; lean_object* x_166; lean_object* x_167; +x_164 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___rarg(x_10); +x_165 = lean_ctor_get(x_164, 0); +lean_inc(x_165); +x_166 = lean_ctor_get(x_164, 1); lean_inc(x_166); -x_167 = lean_ctor_get(x_165, 1); -lean_inc(x_167); -lean_dec(x_165); -x_168 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_1, x_2, x_167); -if (lean_obj_tag(x_168) == 0) +lean_dec(x_164); +x_167 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_166); +if (lean_obj_tag(x_167) == 0) { -lean_object* x_169; lean_object* x_170; lean_object* x_171; lean_object* x_172; uint8_t x_173; -x_169 = lean_ctor_get(x_168, 0); +lean_object* x_168; lean_object* x_169; lean_object* x_170; lean_object* x_171; uint8_t x_172; +x_168 = lean_ctor_get(x_167, 0); +lean_inc(x_168); +x_169 = lean_ctor_get(x_167, 1); lean_inc(x_169); -x_170 = lean_ctor_get(x_168, 1); -lean_inc(x_170); -lean_dec(x_168); -x_171 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2; -x_172 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(x_166, x_171, x_2, x_170); -x_173 = !lean_is_exclusive(x_172); -if (x_173 == 0) +lean_dec(x_167); +x_170 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2; +x_171 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(x_165, x_170, x_1, x_169); +x_172 = !lean_is_exclusive(x_171); +if (x_172 == 0) { -lean_object* x_174; -x_174 = lean_ctor_get(x_172, 0); -lean_dec(x_174); -lean_ctor_set(x_172, 0, x_169); -return x_172; +lean_object* x_173; +x_173 = lean_ctor_get(x_171, 0); +lean_dec(x_173); +lean_ctor_set(x_171, 0, x_168); +return x_171; } else { -lean_object* x_175; lean_object* x_176; -x_175 = lean_ctor_get(x_172, 1); -lean_inc(x_175); -lean_dec(x_172); -x_176 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_176, 0, x_169); -lean_ctor_set(x_176, 1, x_175); -return x_176; +lean_object* x_174; lean_object* x_175; +x_174 = lean_ctor_get(x_171, 1); +lean_inc(x_174); +lean_dec(x_171); +x_175 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_175, 0, x_168); +lean_ctor_set(x_175, 1, x_174); +return x_175; } } else { -lean_object* x_177; lean_object* x_178; lean_object* x_179; lean_object* x_180; uint8_t x_181; -x_177 = lean_ctor_get(x_168, 0); +lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; uint8_t x_180; +x_176 = lean_ctor_get(x_167, 0); +lean_inc(x_176); +x_177 = lean_ctor_get(x_167, 1); lean_inc(x_177); -x_178 = lean_ctor_get(x_168, 1); -lean_inc(x_178); -lean_dec(x_168); -x_179 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2; -x_180 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(x_166, x_179, x_2, x_178); -x_181 = !lean_is_exclusive(x_180); -if (x_181 == 0) +lean_dec(x_167); +x_178 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2; +x_179 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(x_165, x_178, x_1, x_177); +x_180 = !lean_is_exclusive(x_179); +if (x_180 == 0) { -lean_object* x_182; -x_182 = lean_ctor_get(x_180, 0); -lean_dec(x_182); -lean_ctor_set_tag(x_180, 1); -lean_ctor_set(x_180, 0, x_177); -return x_180; +lean_object* x_181; +x_181 = lean_ctor_get(x_179, 0); +lean_dec(x_181); +lean_ctor_set_tag(x_179, 1); +lean_ctor_set(x_179, 0, x_176); +return x_179; } else { -lean_object* x_183; lean_object* x_184; -x_183 = lean_ctor_get(x_180, 1); -lean_inc(x_183); -lean_dec(x_180); -x_184 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_184, 0, x_177); -lean_ctor_set(x_184, 1, x_183); -return x_184; +lean_object* x_182; lean_object* x_183; +x_182 = lean_ctor_get(x_179, 1); +lean_inc(x_182); +lean_dec(x_179); +x_183 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_183, 0, x_176); +lean_ctor_set(x_183, 1, x_182); +return x_183; } } } @@ -5396,363 +5596,361 @@ return x_184; } else { -uint8_t x_194; lean_object* x_195; -x_194 = 1; -x_195 = lean_box(x_194); -lean_ctor_set(x_4, 0, x_195); -return x_4; +uint8_t x_193; lean_object* x_194; +x_193 = 1; +x_194 = lean_box(x_193); +lean_ctor_set(x_3, 0, x_194); +return x_3; } } else { -lean_object* x_196; lean_object* x_197; lean_object* x_198; uint8_t x_199; -x_196 = lean_ctor_get(x_4, 0); -x_197 = lean_ctor_get(x_4, 1); -lean_inc(x_197); +lean_object* x_195; lean_object* x_196; lean_object* x_197; uint8_t x_198; +x_195 = lean_ctor_get(x_3, 0); +x_196 = lean_ctor_get(x_3, 1); lean_inc(x_196); -lean_dec(x_4); -x_198 = lean_unsigned_to_nat(0u); -x_199 = lean_nat_dec_eq(x_196, x_198); -lean_dec(x_196); +lean_inc(x_195); +lean_dec(x_3); +x_197 = lean_unsigned_to_nat(0u); +x_198 = lean_nat_dec_eq(x_195, x_197); +lean_dec(x_195); +if (x_198 == 0) +{ +uint8_t x_199; lean_object* x_200; lean_object* x_265; uint8_t x_266; +x_265 = lean_ctor_get(x_196, 4); +lean_inc(x_265); +x_266 = lean_ctor_get_uint8(x_265, sizeof(void*)*1); +lean_dec(x_265); +if (x_266 == 0) +{ +uint8_t x_267; +x_267 = 0; +x_199 = x_267; +x_200 = x_196; +goto block_264; +} +else +{ +lean_object* x_268; lean_object* x_269; lean_object* x_270; lean_object* x_271; uint8_t x_272; +x_268 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__3; +x_269 = l___private_Init_Lean_Trace_5__checkTraceOption___at_Lean_Meta_isLevelDefEqAux___main___spec__1(x_268, x_1, x_196); +x_270 = lean_ctor_get(x_269, 0); +lean_inc(x_270); +x_271 = lean_ctor_get(x_269, 1); +lean_inc(x_271); +lean_dec(x_269); +x_272 = lean_unbox(x_270); +lean_dec(x_270); +x_199 = x_272; +x_200 = x_271; +goto block_264; +} +block_264: +{ if (x_199 == 0) { -uint8_t x_200; lean_object* x_201; lean_object* x_266; uint8_t x_267; -x_266 = lean_ctor_get(x_197, 4); -lean_inc(x_266); -x_267 = lean_ctor_get_uint8(x_266, sizeof(void*)*1); -lean_dec(x_266); -if (x_267 == 0) -{ -uint8_t x_268; -x_268 = 0; -x_200 = x_268; -x_201 = x_197; -goto block_265; -} -else -{ -lean_object* x_269; lean_object* x_270; lean_object* x_271; lean_object* x_272; uint8_t x_273; -x_269 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__3; -x_270 = l___private_Init_Lean_Trace_5__checkTraceOption___at___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___spec__1(x_269, x_2, x_197); -x_271 = lean_ctor_get(x_270, 0); -lean_inc(x_271); -x_272 = lean_ctor_get(x_270, 1); -lean_inc(x_272); -lean_dec(x_270); -x_273 = lean_unbox(x_271); -lean_dec(x_271); -x_200 = x_273; -x_201 = x_272; -goto block_265; -} -block_265: -{ -if (x_200 == 0) -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; uint8_t x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; -x_202 = lean_ctor_get(x_201, 4); +lean_object* x_201; lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; uint8_t x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_201 = lean_ctor_get(x_200, 4); +lean_inc(x_201); +x_202 = lean_ctor_get(x_200, 0); lean_inc(x_202); -x_203 = lean_ctor_get(x_201, 0); +x_203 = lean_ctor_get(x_200, 1); lean_inc(x_203); -x_204 = lean_ctor_get(x_201, 1); +x_204 = lean_ctor_get(x_200, 2); lean_inc(x_204); -x_205 = lean_ctor_get(x_201, 2); +x_205 = lean_ctor_get(x_200, 3); lean_inc(x_205); -x_206 = lean_ctor_get(x_201, 3); +x_206 = lean_ctor_get(x_200, 5); lean_inc(x_206); -x_207 = lean_ctor_get(x_201, 5); -lean_inc(x_207); +if (lean_is_exclusive(x_200)) { + lean_ctor_release(x_200, 0); + lean_ctor_release(x_200, 1); + lean_ctor_release(x_200, 2); + lean_ctor_release(x_200, 3); + lean_ctor_release(x_200, 4); + lean_ctor_release(x_200, 5); + x_207 = x_200; +} else { + lean_dec_ref(x_200); + x_207 = lean_box(0); +} +x_208 = lean_ctor_get(x_201, 0); +lean_inc(x_208); if (lean_is_exclusive(x_201)) { lean_ctor_release(x_201, 0); - lean_ctor_release(x_201, 1); - lean_ctor_release(x_201, 2); - lean_ctor_release(x_201, 3); - lean_ctor_release(x_201, 4); - lean_ctor_release(x_201, 5); - x_208 = x_201; + x_209 = x_201; } else { lean_dec_ref(x_201); - x_208 = lean_box(0); + x_209 = lean_box(0); } -x_209 = lean_ctor_get(x_202, 0); -lean_inc(x_209); -if (lean_is_exclusive(x_202)) { - lean_ctor_release(x_202, 0); - x_210 = x_202; +x_210 = 1; +if (lean_is_scalar(x_209)) { + x_211 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_202); - x_210 = lean_box(0); + x_211 = x_209; } -x_211 = 1; -if (lean_is_scalar(x_210)) { - x_212 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_211, 0, x_208); +lean_ctor_set_uint8(x_211, sizeof(void*)*1, x_210); +if (lean_is_scalar(x_207)) { + x_212 = lean_alloc_ctor(0, 6, 0); } else { - x_212 = x_210; + x_212 = x_207; } -lean_ctor_set(x_212, 0, x_209); -lean_ctor_set_uint8(x_212, sizeof(void*)*1, x_211); -if (lean_is_scalar(x_208)) { - x_213 = lean_alloc_ctor(0, 6, 0); -} else { - x_213 = x_208; -} -lean_ctor_set(x_213, 0, x_203); -lean_ctor_set(x_213, 1, x_204); -lean_ctor_set(x_213, 2, x_205); -lean_ctor_set(x_213, 3, x_206); -lean_ctor_set(x_213, 4, x_212); -lean_ctor_set(x_213, 5, x_207); -x_214 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_1, x_2, x_213); -if (lean_obj_tag(x_214) == 0) +lean_ctor_set(x_212, 0, x_202); +lean_ctor_set(x_212, 1, x_203); +lean_ctor_set(x_212, 2, x_204); +lean_ctor_set(x_212, 3, x_205); +lean_ctor_set(x_212, 4, x_211); +lean_ctor_set(x_212, 5, x_206); +x_213 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_212); +if (lean_obj_tag(x_213) == 0) { -lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; uint8_t x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_215 = lean_ctor_get(x_214, 1); +lean_object* x_214; lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; uint8_t x_226; lean_object* x_227; lean_object* x_228; lean_object* x_229; +x_214 = lean_ctor_get(x_213, 1); +lean_inc(x_214); +x_215 = lean_ctor_get(x_214, 4); lean_inc(x_215); -x_216 = lean_ctor_get(x_215, 4); +x_216 = lean_ctor_get(x_213, 0); lean_inc(x_216); -x_217 = lean_ctor_get(x_214, 0); -lean_inc(x_217); +if (lean_is_exclusive(x_213)) { + lean_ctor_release(x_213, 0); + lean_ctor_release(x_213, 1); + x_217 = x_213; +} else { + lean_dec_ref(x_213); + x_217 = lean_box(0); +} +x_218 = lean_ctor_get(x_214, 0); +lean_inc(x_218); +x_219 = lean_ctor_get(x_214, 1); +lean_inc(x_219); +x_220 = lean_ctor_get(x_214, 2); +lean_inc(x_220); +x_221 = lean_ctor_get(x_214, 3); +lean_inc(x_221); +x_222 = lean_ctor_get(x_214, 5); +lean_inc(x_222); if (lean_is_exclusive(x_214)) { lean_ctor_release(x_214, 0); lean_ctor_release(x_214, 1); - x_218 = x_214; + lean_ctor_release(x_214, 2); + lean_ctor_release(x_214, 3); + lean_ctor_release(x_214, 4); + lean_ctor_release(x_214, 5); + x_223 = x_214; } else { lean_dec_ref(x_214); - x_218 = lean_box(0); + x_223 = lean_box(0); } -x_219 = lean_ctor_get(x_215, 0); -lean_inc(x_219); -x_220 = lean_ctor_get(x_215, 1); -lean_inc(x_220); -x_221 = lean_ctor_get(x_215, 2); -lean_inc(x_221); -x_222 = lean_ctor_get(x_215, 3); -lean_inc(x_222); -x_223 = lean_ctor_get(x_215, 5); -lean_inc(x_223); +x_224 = lean_ctor_get(x_215, 0); +lean_inc(x_224); if (lean_is_exclusive(x_215)) { lean_ctor_release(x_215, 0); - lean_ctor_release(x_215, 1); - lean_ctor_release(x_215, 2); - lean_ctor_release(x_215, 3); - lean_ctor_release(x_215, 4); - lean_ctor_release(x_215, 5); - x_224 = x_215; + x_225 = x_215; } else { lean_dec_ref(x_215); - x_224 = lean_box(0); + x_225 = lean_box(0); } -x_225 = lean_ctor_get(x_216, 0); -lean_inc(x_225); -if (lean_is_exclusive(x_216)) { - lean_ctor_release(x_216, 0); - x_226 = x_216; +x_226 = 0; +if (lean_is_scalar(x_225)) { + x_227 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_216); - x_226 = lean_box(0); + x_227 = x_225; } -x_227 = 0; -if (lean_is_scalar(x_226)) { - x_228 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_227, 0, x_224); +lean_ctor_set_uint8(x_227, sizeof(void*)*1, x_226); +if (lean_is_scalar(x_223)) { + x_228 = lean_alloc_ctor(0, 6, 0); } else { - x_228 = x_226; + x_228 = x_223; } -lean_ctor_set(x_228, 0, x_225); -lean_ctor_set_uint8(x_228, sizeof(void*)*1, x_227); -if (lean_is_scalar(x_224)) { - x_229 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_228, 0, x_218); +lean_ctor_set(x_228, 1, x_219); +lean_ctor_set(x_228, 2, x_220); +lean_ctor_set(x_228, 3, x_221); +lean_ctor_set(x_228, 4, x_227); +lean_ctor_set(x_228, 5, x_222); +if (lean_is_scalar(x_217)) { + x_229 = lean_alloc_ctor(0, 2, 0); } else { - x_229 = x_224; + x_229 = x_217; } -lean_ctor_set(x_229, 0, x_219); -lean_ctor_set(x_229, 1, x_220); -lean_ctor_set(x_229, 2, x_221); -lean_ctor_set(x_229, 3, x_222); -lean_ctor_set(x_229, 4, x_228); -lean_ctor_set(x_229, 5, x_223); -if (lean_is_scalar(x_218)) { - x_230 = lean_alloc_ctor(0, 2, 0); -} else { - x_230 = x_218; -} -lean_ctor_set(x_230, 0, x_217); -lean_ctor_set(x_230, 1, x_229); -return x_230; +lean_ctor_set(x_229, 0, x_216); +lean_ctor_set(x_229, 1, x_228); +return x_229; } else { -lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; uint8_t x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; -x_231 = lean_ctor_get(x_214, 1); +lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; lean_object* x_234; lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; lean_object* x_239; lean_object* x_240; lean_object* x_241; uint8_t x_242; lean_object* x_243; lean_object* x_244; lean_object* x_245; +x_230 = lean_ctor_get(x_213, 1); +lean_inc(x_230); +x_231 = lean_ctor_get(x_230, 4); lean_inc(x_231); -x_232 = lean_ctor_get(x_231, 4); +x_232 = lean_ctor_get(x_213, 0); lean_inc(x_232); -x_233 = lean_ctor_get(x_214, 0); -lean_inc(x_233); -if (lean_is_exclusive(x_214)) { - lean_ctor_release(x_214, 0); - lean_ctor_release(x_214, 1); - x_234 = x_214; +if (lean_is_exclusive(x_213)) { + lean_ctor_release(x_213, 0); + lean_ctor_release(x_213, 1); + x_233 = x_213; } else { - lean_dec_ref(x_214); - x_234 = lean_box(0); + lean_dec_ref(x_213); + x_233 = lean_box(0); } -x_235 = lean_ctor_get(x_231, 0); +x_234 = lean_ctor_get(x_230, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_230, 1); lean_inc(x_235); -x_236 = lean_ctor_get(x_231, 1); +x_236 = lean_ctor_get(x_230, 2); lean_inc(x_236); -x_237 = lean_ctor_get(x_231, 2); +x_237 = lean_ctor_get(x_230, 3); lean_inc(x_237); -x_238 = lean_ctor_get(x_231, 3); +x_238 = lean_ctor_get(x_230, 5); lean_inc(x_238); -x_239 = lean_ctor_get(x_231, 5); -lean_inc(x_239); +if (lean_is_exclusive(x_230)) { + lean_ctor_release(x_230, 0); + lean_ctor_release(x_230, 1); + lean_ctor_release(x_230, 2); + lean_ctor_release(x_230, 3); + lean_ctor_release(x_230, 4); + lean_ctor_release(x_230, 5); + x_239 = x_230; +} else { + lean_dec_ref(x_230); + x_239 = lean_box(0); +} +x_240 = lean_ctor_get(x_231, 0); +lean_inc(x_240); if (lean_is_exclusive(x_231)) { lean_ctor_release(x_231, 0); - lean_ctor_release(x_231, 1); - lean_ctor_release(x_231, 2); - lean_ctor_release(x_231, 3); - lean_ctor_release(x_231, 4); - lean_ctor_release(x_231, 5); - x_240 = x_231; + x_241 = x_231; } else { lean_dec_ref(x_231); - x_240 = lean_box(0); + x_241 = lean_box(0); } -x_241 = lean_ctor_get(x_232, 0); -lean_inc(x_241); -if (lean_is_exclusive(x_232)) { - lean_ctor_release(x_232, 0); - x_242 = x_232; +x_242 = 0; +if (lean_is_scalar(x_241)) { + x_243 = lean_alloc_ctor(0, 1, 1); } else { - lean_dec_ref(x_232); - x_242 = lean_box(0); + x_243 = x_241; } -x_243 = 0; -if (lean_is_scalar(x_242)) { - x_244 = lean_alloc_ctor(0, 1, 1); +lean_ctor_set(x_243, 0, x_240); +lean_ctor_set_uint8(x_243, sizeof(void*)*1, x_242); +if (lean_is_scalar(x_239)) { + x_244 = lean_alloc_ctor(0, 6, 0); } else { - x_244 = x_242; + x_244 = x_239; } -lean_ctor_set(x_244, 0, x_241); -lean_ctor_set_uint8(x_244, sizeof(void*)*1, x_243); -if (lean_is_scalar(x_240)) { - x_245 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_244, 0, x_234); +lean_ctor_set(x_244, 1, x_235); +lean_ctor_set(x_244, 2, x_236); +lean_ctor_set(x_244, 3, x_237); +lean_ctor_set(x_244, 4, x_243); +lean_ctor_set(x_244, 5, x_238); +if (lean_is_scalar(x_233)) { + x_245 = lean_alloc_ctor(1, 2, 0); } else { - x_245 = x_240; + x_245 = x_233; } -lean_ctor_set(x_245, 0, x_235); -lean_ctor_set(x_245, 1, x_236); -lean_ctor_set(x_245, 2, x_237); -lean_ctor_set(x_245, 3, x_238); -lean_ctor_set(x_245, 4, x_244); -lean_ctor_set(x_245, 5, x_239); -if (lean_is_scalar(x_234)) { - x_246 = lean_alloc_ctor(1, 2, 0); -} else { - x_246 = x_234; -} -lean_ctor_set(x_246, 0, x_233); -lean_ctor_set(x_246, 1, x_245); -return x_246; +lean_ctor_set(x_245, 0, x_232); +lean_ctor_set(x_245, 1, x_244); +return x_245; } } else { -lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; -x_247 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__6___rarg(x_201); -x_248 = lean_ctor_get(x_247, 0); +lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; +x_246 = l___private_Init_Lean_Trace_2__getResetTraces___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__6___rarg(x_200); +x_247 = lean_ctor_get(x_246, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_246, 1); lean_inc(x_248); -x_249 = lean_ctor_get(x_247, 1); -lean_inc(x_249); -lean_dec(x_247); -x_250 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main(x_1, x_2, x_249); -if (lean_obj_tag(x_250) == 0) +lean_dec(x_246); +x_249 = l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg(x_1, x_248); +if (lean_obj_tag(x_249) == 0) { -lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; -x_251 = lean_ctor_get(x_250, 0); +lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; +x_250 = lean_ctor_get(x_249, 0); +lean_inc(x_250); +x_251 = lean_ctor_get(x_249, 1); lean_inc(x_251); -x_252 = lean_ctor_get(x_250, 1); -lean_inc(x_252); -lean_dec(x_250); -x_253 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2; -x_254 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(x_248, x_253, x_2, x_252); -x_255 = lean_ctor_get(x_254, 1); -lean_inc(x_255); -if (lean_is_exclusive(x_254)) { - lean_ctor_release(x_254, 0); - lean_ctor_release(x_254, 1); - x_256 = x_254; +lean_dec(x_249); +x_252 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2; +x_253 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(x_247, x_252, x_1, x_251); +x_254 = lean_ctor_get(x_253, 1); +lean_inc(x_254); +if (lean_is_exclusive(x_253)) { + lean_ctor_release(x_253, 0); + lean_ctor_release(x_253, 1); + x_255 = x_253; } else { - lean_dec_ref(x_254); - x_256 = lean_box(0); + lean_dec_ref(x_253); + x_255 = lean_box(0); } -if (lean_is_scalar(x_256)) { - x_257 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_255)) { + x_256 = lean_alloc_ctor(0, 2, 0); } else { - x_257 = x_256; + x_256 = x_255; } -lean_ctor_set(x_257, 0, x_251); -lean_ctor_set(x_257, 1, x_255); -return x_257; +lean_ctor_set(x_256, 0, x_250); +lean_ctor_set(x_256, 1, x_254); +return x_256; } else { -lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; -x_258 = lean_ctor_get(x_250, 0); +lean_object* x_257; lean_object* x_258; lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; +x_257 = lean_ctor_get(x_249, 0); +lean_inc(x_257); +x_258 = lean_ctor_get(x_249, 1); lean_inc(x_258); -x_259 = lean_ctor_get(x_250, 1); -lean_inc(x_259); -lean_dec(x_250); -x_260 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2; -x_261 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___spec__7(x_248, x_260, x_2, x_259); -x_262 = lean_ctor_get(x_261, 1); -lean_inc(x_262); -if (lean_is_exclusive(x_261)) { - lean_ctor_release(x_261, 0); - lean_ctor_release(x_261, 1); - x_263 = x_261; +lean_dec(x_249); +x_259 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2; +x_260 = l___private_Init_Lean_Trace_1__addNode___at___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___spec__7(x_247, x_259, x_1, x_258); +x_261 = lean_ctor_get(x_260, 1); +lean_inc(x_261); +if (lean_is_exclusive(x_260)) { + lean_ctor_release(x_260, 0); + lean_ctor_release(x_260, 1); + x_262 = x_260; } else { - lean_dec_ref(x_261); - x_263 = lean_box(0); + lean_dec_ref(x_260); + x_262 = lean_box(0); } -if (lean_is_scalar(x_263)) { - x_264 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_262)) { + x_263 = lean_alloc_ctor(1, 2, 0); } else { - x_264 = x_263; - lean_ctor_set_tag(x_264, 1); + x_263 = x_262; + lean_ctor_set_tag(x_263, 1); } -lean_ctor_set(x_264, 0, x_258); -lean_ctor_set(x_264, 1, x_262); -return x_264; +lean_ctor_set(x_263, 0, x_257); +lean_ctor_set(x_263, 1, x_261); +return x_263; } } } } else { -uint8_t x_274; lean_object* x_275; lean_object* x_276; -x_274 = 1; -x_275 = lean_box(x_274); -x_276 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_276, 0, x_275); -lean_ctor_set(x_276, 1, x_197); -return x_276; +uint8_t x_273; lean_object* x_274; lean_object* x_275; +x_273 = 1; +x_274 = lean_box(x_273); +x_275 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_275, 0, x_274); +lean_ctor_set(x_275, 1, x_196); +return x_275; } } } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___boxed(lean_object* x_1, lean_object* x_2) { _start: { -uint8_t x_4; lean_object* x_5; -x_4 = lean_unbox(x_1); +lean_object* x_3; +x_3 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_1, x_2); lean_dec(x_1); -x_5 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(x_4, x_2, x_3); -lean_dec(x_2); -return x_5; +return x_3; } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_13__restore(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__restore(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { uint8_t x_6; @@ -5800,11 +5998,11 @@ return x_17; } } } -lean_object* l___private_Init_Lean_Meta_LevelDefEq_13__restore___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l___private_Init_Lean_Meta_LevelDefEq_12__restore___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { lean_object* x_6; -x_6 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_1, x_2, x_3, x_4, x_5); +x_6 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_1, x_2, x_3, x_4, x_5); lean_dec(x_4); return x_6; } @@ -5838,7 +6036,7 @@ lean_object* x_20; lean_object* x_21; uint8_t x_22; x_20 = lean_ctor_get(x_17, 1); lean_inc(x_20); lean_dec(x_17); -x_21 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_5, x_6, x_7, x_2, x_20); +x_21 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_5, x_6, x_7, x_2, x_20); lean_dec(x_2); x_22 = !lean_is_exclusive(x_21); if (x_22 == 0) @@ -5863,13 +6061,370 @@ return x_25; } else { -lean_object* x_26; uint8_t x_27; lean_object* x_28; +lean_object* x_26; lean_object* x_27; lean_dec(x_18); x_26 = lean_ctor_get(x_17, 1); lean_inc(x_26); lean_dec(x_17); -x_27 = 0; -x_28 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(x_27, x_2, x_26); +x_27 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_2, x_26); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; uint8_t x_29; +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +x_29 = lean_unbox(x_28); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; uint8_t x_32; +x_30 = lean_ctor_get(x_27, 1); +lean_inc(x_30); +lean_dec(x_27); +x_31 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_5, x_6, x_7, x_2, x_30); +lean_dec(x_2); +x_32 = !lean_is_exclusive(x_31); +if (x_32 == 0) +{ +lean_object* x_33; +x_33 = lean_ctor_get(x_31, 0); +lean_dec(x_33); +lean_ctor_set(x_31, 0, x_28); +return x_31; +} +else +{ +lean_object* x_34; lean_object* x_35; +x_34 = lean_ctor_get(x_31, 1); +lean_inc(x_34); +lean_dec(x_31); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_28); +lean_ctor_set(x_35, 1, x_34); +return x_35; +} +} +else +{ +uint8_t x_36; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_2); +x_36 = !lean_is_exclusive(x_27); +if (x_36 == 0) +{ +lean_object* x_37; +x_37 = lean_ctor_get(x_27, 0); +lean_dec(x_37); +return x_27; +} +else +{ +lean_object* x_38; lean_object* x_39; +x_38 = lean_ctor_get(x_27, 1); +lean_inc(x_38); +lean_dec(x_27); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_28); +lean_ctor_set(x_39, 1, x_38); +return x_39; +} +} +} +else +{ +lean_object* x_40; lean_object* x_41; +x_40 = lean_ctor_get(x_27, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_27, 1); +lean_inc(x_41); +lean_dec(x_27); +x_9 = x_40; +x_10 = x_41; +goto block_16; +} +} +} +else +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_17, 0); +lean_inc(x_42); +x_43 = lean_ctor_get(x_17, 1); +lean_inc(x_43); +lean_dec(x_17); +x_9 = x_42; +x_10 = x_43; +goto block_16; +} +block_16: +{ +lean_object* x_11; uint8_t x_12; +x_11 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_5, x_6, x_7, x_2, x_10); +lean_dec(x_2); +x_12 = !lean_is_exclusive(x_11); +if (x_12 == 0) +{ +lean_object* x_13; +x_13 = lean_ctor_get(x_11, 0); +lean_dec(x_13); +lean_ctor_set_tag(x_11, 1); +lean_ctor_set(x_11, 0, x_9); +return x_11; +} +else +{ +lean_object* x_14; lean_object* x_15; +x_14 = lean_ctor_get(x_11, 1); +lean_inc(x_14); +lean_dec(x_11); +x_15 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_15, 0, x_9); +lean_ctor_set(x_15, 1, x_14); +return x_15; +} +} +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_59; +x_44 = lean_ctor_get(x_3, 0); +x_45 = lean_ctor_get(x_3, 1); +x_46 = lean_ctor_get(x_3, 2); +x_47 = lean_ctor_get(x_3, 3); +x_48 = lean_ctor_get(x_3, 4); +x_49 = lean_ctor_get(x_3, 5); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_inc(x_45); +lean_inc(x_44); +lean_dec(x_3); +x_50 = l_PersistentArray_empty___closed__3; +lean_inc(x_45); +lean_inc(x_44); +x_51 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_51, 0, x_44); +lean_ctor_set(x_51, 1, x_45); +lean_ctor_set(x_51, 2, x_46); +lean_ctor_set(x_51, 3, x_47); +lean_ctor_set(x_51, 4, x_48); +lean_ctor_set(x_51, 5, x_50); +lean_inc(x_2); +x_59 = lean_apply_2(x_1, x_2, x_51); +if (lean_obj_tag(x_59) == 0) +{ +lean_object* x_60; uint8_t x_61; +x_60 = lean_ctor_get(x_59, 0); +lean_inc(x_60); +x_61 = lean_unbox(x_60); +if (x_61 == 0) +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_62 = lean_ctor_get(x_59, 1); +lean_inc(x_62); +lean_dec(x_59); +x_63 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_44, x_45, x_49, x_2, x_62); +lean_dec(x_2); +x_64 = lean_ctor_get(x_63, 1); +lean_inc(x_64); +if (lean_is_exclusive(x_63)) { + lean_ctor_release(x_63, 0); + lean_ctor_release(x_63, 1); + x_65 = x_63; +} else { + lean_dec_ref(x_63); + x_65 = lean_box(0); +} +if (lean_is_scalar(x_65)) { + x_66 = lean_alloc_ctor(0, 2, 0); +} else { + x_66 = x_65; +} +lean_ctor_set(x_66, 0, x_60); +lean_ctor_set(x_66, 1, x_64); +return x_66; +} +else +{ +lean_object* x_67; lean_object* x_68; +lean_dec(x_60); +x_67 = lean_ctor_get(x_59, 1); +lean_inc(x_67); +lean_dec(x_59); +x_68 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_2, x_67); +if (lean_obj_tag(x_68) == 0) +{ +lean_object* x_69; uint8_t x_70; +x_69 = lean_ctor_get(x_68, 0); +lean_inc(x_69); +x_70 = lean_unbox(x_69); +if (x_70 == 0) +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_71 = lean_ctor_get(x_68, 1); +lean_inc(x_71); +lean_dec(x_68); +x_72 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_44, x_45, x_49, x_2, x_71); +lean_dec(x_2); +x_73 = lean_ctor_get(x_72, 1); +lean_inc(x_73); +if (lean_is_exclusive(x_72)) { + lean_ctor_release(x_72, 0); + lean_ctor_release(x_72, 1); + x_74 = x_72; +} else { + lean_dec_ref(x_72); + x_74 = lean_box(0); +} +if (lean_is_scalar(x_74)) { + x_75 = lean_alloc_ctor(0, 2, 0); +} else { + x_75 = x_74; +} +lean_ctor_set(x_75, 0, x_69); +lean_ctor_set(x_75, 1, x_73); +return x_75; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +lean_dec(x_49); +lean_dec(x_45); +lean_dec(x_44); +lean_dec(x_2); +x_76 = lean_ctor_get(x_68, 1); +lean_inc(x_76); +if (lean_is_exclusive(x_68)) { + lean_ctor_release(x_68, 0); + lean_ctor_release(x_68, 1); + x_77 = x_68; +} else { + lean_dec_ref(x_68); + x_77 = lean_box(0); +} +if (lean_is_scalar(x_77)) { + x_78 = lean_alloc_ctor(0, 2, 0); +} else { + x_78 = x_77; +} +lean_ctor_set(x_78, 0, x_69); +lean_ctor_set(x_78, 1, x_76); +return x_78; +} +} +else +{ +lean_object* x_79; lean_object* x_80; +x_79 = lean_ctor_get(x_68, 0); +lean_inc(x_79); +x_80 = lean_ctor_get(x_68, 1); +lean_inc(x_80); +lean_dec(x_68); +x_52 = x_79; +x_53 = x_80; +goto block_58; +} +} +} +else +{ +lean_object* x_81; lean_object* x_82; +x_81 = lean_ctor_get(x_59, 0); +lean_inc(x_81); +x_82 = lean_ctor_get(x_59, 1); +lean_inc(x_82); +lean_dec(x_59); +x_52 = x_81; +x_53 = x_82; +goto block_58; +} +block_58: +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_54 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_44, x_45, x_49, x_2, x_53); +lean_dec(x_2); +x_55 = lean_ctor_get(x_54, 1); +lean_inc(x_55); +if (lean_is_exclusive(x_54)) { + lean_ctor_release(x_54, 0); + lean_ctor_release(x_54, 1); + x_56 = x_54; +} else { + lean_dec_ref(x_54); + x_56 = lean_box(0); +} +if (lean_is_scalar(x_56)) { + x_57 = lean_alloc_ctor(1, 2, 0); +} else { + x_57 = x_56; + lean_ctor_set_tag(x_57, 1); +} +lean_ctor_set(x_57, 0, x_52); +lean_ctor_set(x_57, 1, x_55); +return x_57; +} +} +} +} +lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; +x_5 = !lean_is_exclusive(x_4); +if (x_5 == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_18; +x_6 = lean_ctor_get(x_4, 0); +x_7 = lean_ctor_get(x_4, 1); +x_8 = lean_ctor_get(x_4, 5); +x_9 = l_PersistentArray_empty___closed__3; +lean_inc(x_7); +lean_inc(x_6); +lean_ctor_set(x_4, 5, x_9); +x_18 = l_Lean_Meta_isLevelDefEqAux___main(x_1, x_2, x_3, x_4); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; uint8_t x_20; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +x_20 = lean_unbox(x_19); +if (x_20 == 0) +{ +lean_object* x_21; lean_object* x_22; uint8_t x_23; +x_21 = lean_ctor_get(x_18, 1); +lean_inc(x_21); +lean_dec(x_18); +x_22 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_6, x_7, x_8, x_3, x_21); +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +lean_object* x_24; +x_24 = lean_ctor_get(x_22, 0); +lean_dec(x_24); +lean_ctor_set(x_22, 0, x_19); +return x_22; +} +else +{ +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_22, 1); +lean_inc(x_25); +lean_dec(x_22); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_19); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +else +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_19); +x_27 = lean_ctor_get(x_18, 1); +lean_inc(x_27); +lean_dec(x_18); +x_28 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_3, x_27); if (lean_obj_tag(x_28) == 0) { lean_object* x_29; uint8_t x_30; @@ -5882,8 +6437,7 @@ lean_object* x_31; lean_object* x_32; uint8_t x_33; x_31 = lean_ctor_get(x_28, 1); lean_inc(x_31); lean_dec(x_28); -x_32 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_5, x_6, x_7, x_2, x_31); -lean_dec(x_2); +x_32 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_6, x_7, x_8, x_3, x_31); x_33 = !lean_is_exclusive(x_32); if (x_33 == 0) { @@ -5908,10 +6462,9 @@ return x_36; else { uint8_t x_37; +lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_2); x_37 = !lean_is_exclusive(x_28); if (x_37 == 0) { @@ -5941,68 +6494,67 @@ lean_inc(x_41); x_42 = lean_ctor_get(x_28, 1); lean_inc(x_42); lean_dec(x_28); -x_9 = x_41; -x_10 = x_42; -goto block_16; +x_10 = x_41; +x_11 = x_42; +goto block_17; } } } else { lean_object* x_43; lean_object* x_44; -x_43 = lean_ctor_get(x_17, 0); +x_43 = lean_ctor_get(x_18, 0); lean_inc(x_43); -x_44 = lean_ctor_get(x_17, 1); +x_44 = lean_ctor_get(x_18, 1); lean_inc(x_44); -lean_dec(x_17); -x_9 = x_43; -x_10 = x_44; -goto block_16; +lean_dec(x_18); +x_10 = x_43; +x_11 = x_44; +goto block_17; } -block_16: +block_17: { -lean_object* x_11; uint8_t x_12; -x_11 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_5, x_6, x_7, x_2, x_10); -lean_dec(x_2); -x_12 = !lean_is_exclusive(x_11); -if (x_12 == 0) +lean_object* x_12; uint8_t x_13; +x_12 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_6, x_7, x_8, x_3, x_11); +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) { -lean_object* x_13; -x_13 = lean_ctor_get(x_11, 0); -lean_dec(x_13); -lean_ctor_set_tag(x_11, 1); -lean_ctor_set(x_11, 0, x_9); -return x_11; +lean_object* x_14; +x_14 = lean_ctor_get(x_12, 0); +lean_dec(x_14); +lean_ctor_set_tag(x_12, 1); +lean_ctor_set(x_12, 0, x_10); +return x_12; } else { -lean_object* x_14; lean_object* x_15; -x_14 = lean_ctor_get(x_11, 1); -lean_inc(x_14); -lean_dec(x_11); -x_15 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_15, 0, x_9); -lean_ctor_set(x_15, 1, x_14); -return x_15; +lean_object* x_15; lean_object* x_16; +x_15 = lean_ctor_get(x_12, 1); +lean_inc(x_15); +lean_dec(x_12); +x_16 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_16, 0, x_10); +lean_ctor_set(x_16, 1, x_15); +return x_16; } } } else { lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_60; -x_45 = lean_ctor_get(x_3, 0); -x_46 = lean_ctor_get(x_3, 1); -x_47 = lean_ctor_get(x_3, 2); -x_48 = lean_ctor_get(x_3, 3); -x_49 = lean_ctor_get(x_3, 4); -x_50 = lean_ctor_get(x_3, 5); +x_45 = lean_ctor_get(x_4, 0); +x_46 = lean_ctor_get(x_4, 1); +x_47 = lean_ctor_get(x_4, 2); +x_48 = lean_ctor_get(x_4, 3); +x_49 = lean_ctor_get(x_4, 4); +x_50 = lean_ctor_get(x_4, 5); lean_inc(x_50); lean_inc(x_49); lean_inc(x_48); lean_inc(x_47); lean_inc(x_46); lean_inc(x_45); -lean_dec(x_3); +lean_dec(x_4); x_51 = l_PersistentArray_empty___closed__3; lean_inc(x_46); lean_inc(x_45); @@ -6013,8 +6565,7 @@ lean_ctor_set(x_52, 2, x_47); lean_ctor_set(x_52, 3, x_48); lean_ctor_set(x_52, 4, x_49); lean_ctor_set(x_52, 5, x_51); -lean_inc(x_2); -x_60 = lean_apply_2(x_1, x_2, x_52); +x_60 = l_Lean_Meta_isLevelDefEqAux___main(x_1, x_2, x_3, x_52); if (lean_obj_tag(x_60) == 0) { lean_object* x_61; uint8_t x_62; @@ -6027,8 +6578,7 @@ lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean x_63 = lean_ctor_get(x_60, 1); lean_inc(x_63); lean_dec(x_60); -x_64 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_45, x_46, x_50, x_2, x_63); -lean_dec(x_2); +x_64 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_45, x_46, x_50, x_3, x_63); x_65 = lean_ctor_get(x_64, 1); lean_inc(x_65); if (lean_is_exclusive(x_64)) { @@ -6050,104 +6600,100 @@ return x_67; } else { -lean_object* x_68; uint8_t x_69; lean_object* x_70; +lean_object* x_68; lean_object* x_69; lean_dec(x_61); x_68 = lean_ctor_get(x_60, 1); lean_inc(x_68); lean_dec(x_60); -x_69 = 0; -x_70 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(x_69, x_2, x_68); -if (lean_obj_tag(x_70) == 0) +x_69 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_3, x_68); +if (lean_obj_tag(x_69) == 0) { -lean_object* x_71; uint8_t x_72; -x_71 = lean_ctor_get(x_70, 0); -lean_inc(x_71); -x_72 = lean_unbox(x_71); -if (x_72 == 0) +lean_object* x_70; uint8_t x_71; +x_70 = lean_ctor_get(x_69, 0); +lean_inc(x_70); +x_71 = lean_unbox(x_70); +if (x_71 == 0) { -lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_73 = lean_ctor_get(x_70, 1); -lean_inc(x_73); -lean_dec(x_70); -x_74 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_45, x_46, x_50, x_2, x_73); -lean_dec(x_2); -x_75 = lean_ctor_get(x_74, 1); -lean_inc(x_75); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - x_76 = x_74; +lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_72 = lean_ctor_get(x_69, 1); +lean_inc(x_72); +lean_dec(x_69); +x_73 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_45, x_46, x_50, x_3, x_72); +x_74 = lean_ctor_get(x_73, 1); +lean_inc(x_74); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + x_75 = x_73; } else { - lean_dec_ref(x_74); - x_76 = lean_box(0); + lean_dec_ref(x_73); + x_75 = lean_box(0); } -if (lean_is_scalar(x_76)) { - x_77 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_75)) { + x_76 = lean_alloc_ctor(0, 2, 0); } else { - x_77 = x_76; + x_76 = x_75; } -lean_ctor_set(x_77, 0, x_71); -lean_ctor_set(x_77, 1, x_75); -return x_77; +lean_ctor_set(x_76, 0, x_70); +lean_ctor_set(x_76, 1, x_74); +return x_76; } else { -lean_object* x_78; lean_object* x_79; lean_object* x_80; +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_dec(x_50); lean_dec(x_46); lean_dec(x_45); -lean_dec(x_2); -x_78 = lean_ctor_get(x_70, 1); -lean_inc(x_78); -if (lean_is_exclusive(x_70)) { - lean_ctor_release(x_70, 0); - lean_ctor_release(x_70, 1); - x_79 = x_70; +x_77 = lean_ctor_get(x_69, 1); +lean_inc(x_77); +if (lean_is_exclusive(x_69)) { + lean_ctor_release(x_69, 0); + lean_ctor_release(x_69, 1); + x_78 = x_69; } else { - lean_dec_ref(x_70); - x_79 = lean_box(0); + lean_dec_ref(x_69); + x_78 = lean_box(0); } -if (lean_is_scalar(x_79)) { - x_80 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_78)) { + x_79 = lean_alloc_ctor(0, 2, 0); } else { - x_80 = x_79; + x_79 = x_78; } -lean_ctor_set(x_80, 0, x_71); -lean_ctor_set(x_80, 1, x_78); -return x_80; +lean_ctor_set(x_79, 0, x_70); +lean_ctor_set(x_79, 1, x_77); +return x_79; } } else { -lean_object* x_81; lean_object* x_82; -x_81 = lean_ctor_get(x_70, 0); +lean_object* x_80; lean_object* x_81; +x_80 = lean_ctor_get(x_69, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_69, 1); lean_inc(x_81); -x_82 = lean_ctor_get(x_70, 1); -lean_inc(x_82); -lean_dec(x_70); -x_53 = x_81; -x_54 = x_82; +lean_dec(x_69); +x_53 = x_80; +x_54 = x_81; goto block_59; } } } else { -lean_object* x_83; lean_object* x_84; -x_83 = lean_ctor_get(x_60, 0); +lean_object* x_82; lean_object* x_83; +x_82 = lean_ctor_get(x_60, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_60, 1); lean_inc(x_83); -x_84 = lean_ctor_get(x_60, 1); -lean_inc(x_84); lean_dec(x_60); -x_53 = x_83; -x_54 = x_84; +x_53 = x_82; +x_54 = x_83; goto block_59; } block_59: { lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; -x_55 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_45, x_46, x_50, x_2, x_54); -lean_dec(x_2); +x_55 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_45, x_46, x_50, x_3, x_54); x_56 = lean_ctor_get(x_55, 1); lean_inc(x_56); if (lean_is_exclusive(x_55)) { @@ -6171,403 +6717,6 @@ return x_58; } } } -lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___lambda__1(uint8_t x_1, lean_object* x_2, lean_object* x_3) { -_start: -{ -if (x_1 == 0) -{ -uint8_t x_4; lean_object* x_5; lean_object* x_6; -x_4 = 0; -x_5 = lean_box(x_4); -x_6 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_6, 0, x_5); -lean_ctor_set(x_6, 1, x_3); -return x_6; -} -else -{ -uint8_t x_7; lean_object* x_8; -x_7 = 0; -x_8 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(x_7, x_2, x_3); -return x_8; -} -} -} -lean_object* _init_l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___closed__1() { -_start: -{ -lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___lambda__1___boxed), 3, 0); -return x_1; -} -} -lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { -_start: -{ -lean_object* x_5; uint8_t x_6; -x_5 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___boxed), 4, 2); -lean_closure_set(x_5, 0, x_1); -lean_closure_set(x_5, 1, x_2); -x_6 = !lean_is_exclusive(x_4); -if (x_6 == 0) -{ -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_19; lean_object* x_20; -x_7 = lean_ctor_get(x_4, 0); -x_8 = lean_ctor_get(x_4, 1); -x_9 = lean_ctor_get(x_4, 5); -x_10 = l_PersistentArray_empty___closed__3; -lean_inc(x_8); -lean_inc(x_7); -lean_ctor_set(x_4, 5, x_10); -x_19 = l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___closed__1; -lean_inc(x_3); -x_20 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_5, x_19, x_3, x_4); -if (lean_obj_tag(x_20) == 0) -{ -lean_object* x_21; uint8_t x_22; -x_21 = lean_ctor_get(x_20, 0); -lean_inc(x_21); -x_22 = lean_unbox(x_21); -if (x_22 == 0) -{ -lean_object* x_23; lean_object* x_24; uint8_t x_25; -x_23 = lean_ctor_get(x_20, 1); -lean_inc(x_23); -lean_dec(x_20); -x_24 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_7, x_8, x_9, x_3, x_23); -lean_dec(x_3); -x_25 = !lean_is_exclusive(x_24); -if (x_25 == 0) -{ -lean_object* x_26; -x_26 = lean_ctor_get(x_24, 0); -lean_dec(x_26); -lean_ctor_set(x_24, 0, x_21); -return x_24; -} -else -{ -lean_object* x_27; lean_object* x_28; -x_27 = lean_ctor_get(x_24, 1); -lean_inc(x_27); -lean_dec(x_24); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_21); -lean_ctor_set(x_28, 1, x_27); -return x_28; -} -} -else -{ -lean_object* x_29; uint8_t x_30; lean_object* x_31; -lean_dec(x_21); -x_29 = lean_ctor_get(x_20, 1); -lean_inc(x_29); -lean_dec(x_20); -x_30 = 0; -x_31 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(x_30, x_3, x_29); -if (lean_obj_tag(x_31) == 0) -{ -lean_object* x_32; uint8_t x_33; -x_32 = lean_ctor_get(x_31, 0); -lean_inc(x_32); -x_33 = lean_unbox(x_32); -if (x_33 == 0) -{ -lean_object* x_34; lean_object* x_35; uint8_t x_36; -x_34 = lean_ctor_get(x_31, 1); -lean_inc(x_34); -lean_dec(x_31); -x_35 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_7, x_8, x_9, x_3, x_34); -lean_dec(x_3); -x_36 = !lean_is_exclusive(x_35); -if (x_36 == 0) -{ -lean_object* x_37; -x_37 = lean_ctor_get(x_35, 0); -lean_dec(x_37); -lean_ctor_set(x_35, 0, x_32); -return x_35; -} -else -{ -lean_object* x_38; lean_object* x_39; -x_38 = lean_ctor_get(x_35, 1); -lean_inc(x_38); -lean_dec(x_35); -x_39 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_39, 0, x_32); -lean_ctor_set(x_39, 1, x_38); -return x_39; -} -} -else -{ -uint8_t x_40; -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_3); -x_40 = !lean_is_exclusive(x_31); -if (x_40 == 0) -{ -lean_object* x_41; -x_41 = lean_ctor_get(x_31, 0); -lean_dec(x_41); -return x_31; -} -else -{ -lean_object* x_42; lean_object* x_43; -x_42 = lean_ctor_get(x_31, 1); -lean_inc(x_42); -lean_dec(x_31); -x_43 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_43, 0, x_32); -lean_ctor_set(x_43, 1, x_42); -return x_43; -} -} -} -else -{ -lean_object* x_44; lean_object* x_45; -x_44 = lean_ctor_get(x_31, 0); -lean_inc(x_44); -x_45 = lean_ctor_get(x_31, 1); -lean_inc(x_45); -lean_dec(x_31); -x_11 = x_44; -x_12 = x_45; -goto block_18; -} -} -} -else -{ -lean_object* x_46; lean_object* x_47; -x_46 = lean_ctor_get(x_20, 0); -lean_inc(x_46); -x_47 = lean_ctor_get(x_20, 1); -lean_inc(x_47); -lean_dec(x_20); -x_11 = x_46; -x_12 = x_47; -goto block_18; -} -block_18: -{ -lean_object* x_13; uint8_t x_14; -x_13 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_7, x_8, x_9, x_3, x_12); -lean_dec(x_3); -x_14 = !lean_is_exclusive(x_13); -if (x_14 == 0) -{ -lean_object* x_15; -x_15 = lean_ctor_get(x_13, 0); -lean_dec(x_15); -lean_ctor_set_tag(x_13, 1); -lean_ctor_set(x_13, 0, x_11); -return x_13; -} -else -{ -lean_object* x_16; lean_object* x_17; -x_16 = lean_ctor_get(x_13, 1); -lean_inc(x_16); -lean_dec(x_13); -x_17 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_17, 0, x_11); -lean_ctor_set(x_17, 1, x_16); -return x_17; -} -} -} -else -{ -lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_63; lean_object* x_64; -x_48 = lean_ctor_get(x_4, 0); -x_49 = lean_ctor_get(x_4, 1); -x_50 = lean_ctor_get(x_4, 2); -x_51 = lean_ctor_get(x_4, 3); -x_52 = lean_ctor_get(x_4, 4); -x_53 = lean_ctor_get(x_4, 5); -lean_inc(x_53); -lean_inc(x_52); -lean_inc(x_51); -lean_inc(x_50); -lean_inc(x_49); -lean_inc(x_48); -lean_dec(x_4); -x_54 = l_PersistentArray_empty___closed__3; -lean_inc(x_49); -lean_inc(x_48); -x_55 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_55, 0, x_48); -lean_ctor_set(x_55, 1, x_49); -lean_ctor_set(x_55, 2, x_50); -lean_ctor_set(x_55, 3, x_51); -lean_ctor_set(x_55, 4, x_52); -lean_ctor_set(x_55, 5, x_54); -x_63 = l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___closed__1; -lean_inc(x_3); -x_64 = l_ReaderT_bind___at_Lean_Meta_forallTelescope___spec__3___rarg(x_5, x_63, x_3, x_55); -if (lean_obj_tag(x_64) == 0) -{ -lean_object* x_65; uint8_t x_66; -x_65 = lean_ctor_get(x_64, 0); -lean_inc(x_65); -x_66 = lean_unbox(x_65); -if (x_66 == 0) -{ -lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; -x_67 = lean_ctor_get(x_64, 1); -lean_inc(x_67); -lean_dec(x_64); -x_68 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_48, x_49, x_53, x_3, x_67); -lean_dec(x_3); -x_69 = lean_ctor_get(x_68, 1); -lean_inc(x_69); -if (lean_is_exclusive(x_68)) { - lean_ctor_release(x_68, 0); - lean_ctor_release(x_68, 1); - x_70 = x_68; -} else { - lean_dec_ref(x_68); - x_70 = lean_box(0); -} -if (lean_is_scalar(x_70)) { - x_71 = lean_alloc_ctor(0, 2, 0); -} else { - x_71 = x_70; -} -lean_ctor_set(x_71, 0, x_65); -lean_ctor_set(x_71, 1, x_69); -return x_71; -} -else -{ -lean_object* x_72; uint8_t x_73; lean_object* x_74; -lean_dec(x_65); -x_72 = lean_ctor_get(x_64, 1); -lean_inc(x_72); -lean_dec(x_64); -x_73 = 0; -x_74 = l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed(x_73, x_3, x_72); -if (lean_obj_tag(x_74) == 0) -{ -lean_object* x_75; uint8_t x_76; -x_75 = lean_ctor_get(x_74, 0); -lean_inc(x_75); -x_76 = lean_unbox(x_75); -if (x_76 == 0) -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_77 = lean_ctor_get(x_74, 1); -lean_inc(x_77); -lean_dec(x_74); -x_78 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_48, x_49, x_53, x_3, x_77); -lean_dec(x_3); -x_79 = lean_ctor_get(x_78, 1); -lean_inc(x_79); -if (lean_is_exclusive(x_78)) { - lean_ctor_release(x_78, 0); - lean_ctor_release(x_78, 1); - x_80 = x_78; -} else { - lean_dec_ref(x_78); - x_80 = lean_box(0); -} -if (lean_is_scalar(x_80)) { - x_81 = lean_alloc_ctor(0, 2, 0); -} else { - x_81 = x_80; -} -lean_ctor_set(x_81, 0, x_75); -lean_ctor_set(x_81, 1, x_79); -return x_81; -} -else -{ -lean_object* x_82; lean_object* x_83; lean_object* x_84; -lean_dec(x_53); -lean_dec(x_49); -lean_dec(x_48); -lean_dec(x_3); -x_82 = lean_ctor_get(x_74, 1); -lean_inc(x_82); -if (lean_is_exclusive(x_74)) { - lean_ctor_release(x_74, 0); - lean_ctor_release(x_74, 1); - x_83 = x_74; -} else { - lean_dec_ref(x_74); - x_83 = lean_box(0); -} -if (lean_is_scalar(x_83)) { - x_84 = lean_alloc_ctor(0, 2, 0); -} else { - x_84 = x_83; -} -lean_ctor_set(x_84, 0, x_75); -lean_ctor_set(x_84, 1, x_82); -return x_84; -} -} -else -{ -lean_object* x_85; lean_object* x_86; -x_85 = lean_ctor_get(x_74, 0); -lean_inc(x_85); -x_86 = lean_ctor_get(x_74, 1); -lean_inc(x_86); -lean_dec(x_74); -x_56 = x_85; -x_57 = x_86; -goto block_62; -} -} -} -else -{ -lean_object* x_87; lean_object* x_88; -x_87 = lean_ctor_get(x_64, 0); -lean_inc(x_87); -x_88 = lean_ctor_get(x_64, 1); -lean_inc(x_88); -lean_dec(x_64); -x_56 = x_87; -x_57 = x_88; -goto block_62; -} -block_62: -{ -lean_object* x_58; lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_58 = l___private_Init_Lean_Meta_LevelDefEq_13__restore(x_48, x_49, x_53, x_3, x_57); -lean_dec(x_3); -x_59 = lean_ctor_get(x_58, 1); -lean_inc(x_59); -if (lean_is_exclusive(x_58)) { - lean_ctor_release(x_58, 0); - lean_ctor_release(x_58, 1); - x_60 = x_58; -} else { - lean_dec_ref(x_58); - x_60 = lean_box(0); -} -if (lean_is_scalar(x_60)) { - x_61 = lean_alloc_ctor(1, 2, 0); -} else { - x_61 = x_60; - lean_ctor_set_tag(x_61, 1); -} -lean_ctor_set(x_61, 0, x_56); -lean_ctor_set(x_61, 1, x_59); -return x_61; -} -} -} -} lean_object* l_Lean_Meta_isLevelDefEq(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { @@ -6576,74 +6725,41 @@ x_5 = l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1(x_1, x_2, x_3, x_4); return x_5; } } -lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -uint8_t x_4; lean_object* x_5; -x_4 = lean_unbox(x_1); -lean_dec(x_1); -x_5 = l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___lambda__1(x_4, x_2, x_3); -lean_dec(x_2); +lean_object* x_5; +x_5 = l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1(x_1, x_2, x_3, x_4); +lean_dec(x_3); return x_5; } } -lean_object* l_Lean_Meta_isListLevelDefEq___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isLevelDefEq___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { -if (lean_obj_tag(x_1) == 0) -{ +lean_object* x_5; +x_5 = l_Lean_Meta_isLevelDefEq(x_1, x_2, x_3, x_4); lean_dec(x_3); -if (lean_obj_tag(x_2) == 0) -{ -uint8_t x_5; lean_object* x_6; lean_object* x_7; -x_5 = 1; -x_6 = lean_box(x_5); -x_7 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_7, 0, x_6); -lean_ctor_set(x_7, 1, x_4); -return x_7; -} -else -{ -uint8_t x_8; lean_object* x_9; lean_object* x_10; -lean_dec(x_2); -x_8 = 0; -x_9 = lean_box(x_8); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_4); -return x_10; +return x_5; } } -else +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: { -if (lean_obj_tag(x_2) == 0) +uint8_t x_5; +x_5 = !lean_is_exclusive(x_4); +if (x_5 == 0) { -uint8_t x_11; lean_object* x_12; lean_object* x_13; -lean_dec(x_3); -lean_dec(x_1); -x_11 = 0; -x_12 = lean_box(x_11); -x_13 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_13, 0, x_12); -lean_ctor_set(x_13, 1, x_4); -return x_13; -} -else -{ -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; -x_14 = lean_ctor_get(x_1, 0); -lean_inc(x_14); -x_15 = lean_ctor_get(x_1, 1); -lean_inc(x_15); -lean_dec(x_1); -x_16 = lean_ctor_get(x_2, 0); -lean_inc(x_16); -x_17 = lean_ctor_get(x_2, 1); -lean_inc(x_17); -lean_dec(x_2); +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_18; +x_6 = lean_ctor_get(x_4, 0); +x_7 = lean_ctor_get(x_4, 1); +x_8 = lean_ctor_get(x_4, 5); +x_9 = l_PersistentArray_empty___closed__3; +lean_inc(x_7); +lean_inc(x_6); +lean_ctor_set(x_4, 5, x_9); lean_inc(x_3); -x_18 = l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1(x_14, x_16, x_3, x_4); +x_18 = l_Lean_Meta_isExprDefEqAux(x_1, x_2, x_3, x_4); if (lean_obj_tag(x_18) == 0) { lean_object* x_19; uint8_t x_20; @@ -6652,77 +6768,346 @@ lean_inc(x_19); x_20 = lean_unbox(x_19); if (x_20 == 0) { -uint8_t x_21; -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_3); -x_21 = !lean_is_exclusive(x_18); -if (x_21 == 0) -{ -lean_object* x_22; -x_22 = lean_ctor_get(x_18, 0); -lean_dec(x_22); -return x_18; -} -else -{ -lean_object* x_23; lean_object* x_24; -x_23 = lean_ctor_get(x_18, 1); -lean_inc(x_23); +lean_object* x_21; lean_object* x_22; uint8_t x_23; +x_21 = lean_ctor_get(x_18, 1); +lean_inc(x_21); lean_dec(x_18); -x_24 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_24, 0, x_19); -lean_ctor_set(x_24, 1, x_23); -return x_24; -} +x_22 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_6, x_7, x_8, x_3, x_21); +lean_dec(x_3); +x_23 = !lean_is_exclusive(x_22); +if (x_23 == 0) +{ +lean_object* x_24; +x_24 = lean_ctor_get(x_22, 0); +lean_dec(x_24); +lean_ctor_set(x_22, 0, x_19); +return x_22; } else { -lean_object* x_25; -lean_dec(x_19); -x_25 = lean_ctor_get(x_18, 1); +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_22, 1); lean_inc(x_25); +lean_dec(x_22); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_19); +lean_ctor_set(x_26, 1, x_25); +return x_26; +} +} +else +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_19); +x_27 = lean_ctor_get(x_18, 1); +lean_inc(x_27); lean_dec(x_18); -x_1 = x_15; -x_2 = x_17; -x_4 = x_25; -goto _start; -} -} -else +x_28 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_3, x_27); +if (lean_obj_tag(x_28) == 0) { -uint8_t x_27; -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_3); -x_27 = !lean_is_exclusive(x_18); -if (x_27 == 0) -{ -return x_18; -} -else -{ -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_ctor_get(x_18, 0); -x_29 = lean_ctor_get(x_18, 1); +lean_object* x_29; uint8_t x_30; +x_29 = lean_ctor_get(x_28, 0); lean_inc(x_29); -lean_inc(x_28); +x_30 = lean_unbox(x_29); +if (x_30 == 0) +{ +lean_object* x_31; lean_object* x_32; uint8_t x_33; +x_31 = lean_ctor_get(x_28, 1); +lean_inc(x_31); +lean_dec(x_28); +x_32 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_6, x_7, x_8, x_3, x_31); +lean_dec(x_3); +x_33 = !lean_is_exclusive(x_32); +if (x_33 == 0) +{ +lean_object* x_34; +x_34 = lean_ctor_get(x_32, 0); +lean_dec(x_34); +lean_ctor_set(x_32, 0, x_29); +return x_32; +} +else +{ +lean_object* x_35; lean_object* x_36; +x_35 = lean_ctor_get(x_32, 1); +lean_inc(x_35); +lean_dec(x_32); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_29); +lean_ctor_set(x_36, 1, x_35); +return x_36; +} +} +else +{ +uint8_t x_37; +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_3); +x_37 = !lean_is_exclusive(x_28); +if (x_37 == 0) +{ +lean_object* x_38; +x_38 = lean_ctor_get(x_28, 0); +lean_dec(x_38); +return x_28; +} +else +{ +lean_object* x_39; lean_object* x_40; +x_39 = lean_ctor_get(x_28, 1); +lean_inc(x_39); +lean_dec(x_28); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_29); +lean_ctor_set(x_40, 1, x_39); +return x_40; +} +} +} +else +{ +lean_object* x_41; lean_object* x_42; +x_41 = lean_ctor_get(x_28, 0); +lean_inc(x_41); +x_42 = lean_ctor_get(x_28, 1); +lean_inc(x_42); +lean_dec(x_28); +x_10 = x_41; +x_11 = x_42; +goto block_17; +} +} +} +else +{ +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_18, 0); +lean_inc(x_43); +x_44 = lean_ctor_get(x_18, 1); +lean_inc(x_44); lean_dec(x_18); -x_30 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_30, 0, x_28); -lean_ctor_set(x_30, 1, x_29); -return x_30; +x_10 = x_43; +x_11 = x_44; +goto block_17; +} +block_17: +{ +lean_object* x_12; uint8_t x_13; +x_12 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_6, x_7, x_8, x_3, x_11); +lean_dec(x_3); +x_13 = !lean_is_exclusive(x_12); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_12, 0); +lean_dec(x_14); +lean_ctor_set_tag(x_12, 1); +lean_ctor_set(x_12, 0, x_10); +return x_12; +} +else +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_ctor_get(x_12, 1); +lean_inc(x_15); +lean_dec(x_12); +x_16 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_16, 0, x_10); +lean_ctor_set(x_16, 1, x_15); +return x_16; +} +} +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_60; +x_45 = lean_ctor_get(x_4, 0); +x_46 = lean_ctor_get(x_4, 1); +x_47 = lean_ctor_get(x_4, 2); +x_48 = lean_ctor_get(x_4, 3); +x_49 = lean_ctor_get(x_4, 4); +x_50 = lean_ctor_get(x_4, 5); +lean_inc(x_50); +lean_inc(x_49); +lean_inc(x_48); +lean_inc(x_47); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_4); +x_51 = l_PersistentArray_empty___closed__3; +lean_inc(x_46); +lean_inc(x_45); +x_52 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_52, 0, x_45); +lean_ctor_set(x_52, 1, x_46); +lean_ctor_set(x_52, 2, x_47); +lean_ctor_set(x_52, 3, x_48); +lean_ctor_set(x_52, 4, x_49); +lean_ctor_set(x_52, 5, x_51); +lean_inc(x_3); +x_60 = l_Lean_Meta_isExprDefEqAux(x_1, x_2, x_3, x_52); +if (lean_obj_tag(x_60) == 0) +{ +lean_object* x_61; uint8_t x_62; +x_61 = lean_ctor_get(x_60, 0); +lean_inc(x_61); +x_62 = lean_unbox(x_61); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; lean_object* x_67; +x_63 = lean_ctor_get(x_60, 1); +lean_inc(x_63); +lean_dec(x_60); +x_64 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_45, x_46, x_50, x_3, x_63); +lean_dec(x_3); +x_65 = lean_ctor_get(x_64, 1); +lean_inc(x_65); +if (lean_is_exclusive(x_64)) { + lean_ctor_release(x_64, 0); + lean_ctor_release(x_64, 1); + x_66 = x_64; +} else { + lean_dec_ref(x_64); + x_66 = lean_box(0); +} +if (lean_is_scalar(x_66)) { + x_67 = lean_alloc_ctor(0, 2, 0); +} else { + x_67 = x_66; +} +lean_ctor_set(x_67, 0, x_61); +lean_ctor_set(x_67, 1, x_65); +return x_67; +} +else +{ +lean_object* x_68; lean_object* x_69; +lean_dec(x_61); +x_68 = lean_ctor_get(x_60, 1); +lean_inc(x_68); +lean_dec(x_60); +x_69 = l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed(x_3, x_68); +if (lean_obj_tag(x_69) == 0) +{ +lean_object* x_70; uint8_t x_71; +x_70 = lean_ctor_get(x_69, 0); +lean_inc(x_70); +x_71 = lean_unbox(x_70); +if (x_71 == 0) +{ +lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_72 = lean_ctor_get(x_69, 1); +lean_inc(x_72); +lean_dec(x_69); +x_73 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_45, x_46, x_50, x_3, x_72); +lean_dec(x_3); +x_74 = lean_ctor_get(x_73, 1); +lean_inc(x_74); +if (lean_is_exclusive(x_73)) { + lean_ctor_release(x_73, 0); + lean_ctor_release(x_73, 1); + x_75 = x_73; +} else { + lean_dec_ref(x_73); + x_75 = lean_box(0); +} +if (lean_is_scalar(x_75)) { + x_76 = lean_alloc_ctor(0, 2, 0); +} else { + x_76 = x_75; +} +lean_ctor_set(x_76, 0, x_70); +lean_ctor_set(x_76, 1, x_74); +return x_76; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; +lean_dec(x_50); +lean_dec(x_46); +lean_dec(x_45); +lean_dec(x_3); +x_77 = lean_ctor_get(x_69, 1); +lean_inc(x_77); +if (lean_is_exclusive(x_69)) { + lean_ctor_release(x_69, 0); + lean_ctor_release(x_69, 1); + x_78 = x_69; +} else { + lean_dec_ref(x_69); + x_78 = lean_box(0); +} +if (lean_is_scalar(x_78)) { + x_79 = lean_alloc_ctor(0, 2, 0); +} else { + x_79 = x_78; +} +lean_ctor_set(x_79, 0, x_70); +lean_ctor_set(x_79, 1, x_77); +return x_79; +} +} +else +{ +lean_object* x_80; lean_object* x_81; +x_80 = lean_ctor_get(x_69, 0); +lean_inc(x_80); +x_81 = lean_ctor_get(x_69, 1); +lean_inc(x_81); +lean_dec(x_69); +x_53 = x_80; +x_54 = x_81; +goto block_59; +} +} +} +else +{ +lean_object* x_82; lean_object* x_83; +x_82 = lean_ctor_get(x_60, 0); +lean_inc(x_82); +x_83 = lean_ctor_get(x_60, 1); +lean_inc(x_83); +lean_dec(x_60); +x_53 = x_82; +x_54 = x_83; +goto block_59; +} +block_59: +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_55 = l___private_Init_Lean_Meta_LevelDefEq_12__restore(x_45, x_46, x_50, x_3, x_54); +lean_dec(x_3); +x_56 = lean_ctor_get(x_55, 1); +lean_inc(x_56); +if (lean_is_exclusive(x_55)) { + lean_ctor_release(x_55, 0); + lean_ctor_release(x_55, 1); + x_57 = x_55; +} else { + lean_dec_ref(x_55); + x_57 = lean_box(0); +} +if (lean_is_scalar(x_57)) { + x_58 = lean_alloc_ctor(1, 2, 0); +} else { + x_58 = x_57; + lean_ctor_set_tag(x_58, 1); +} +lean_ctor_set(x_58, 0, x_53); +lean_ctor_set(x_58, 1, x_56); +return x_58; } } } } -} -} -lean_object* l_Lean_Meta_isListLevelDefEq(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +lean_object* l_Lean_Meta_isExprDefEq(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { lean_object* x_5; -x_5 = l_Lean_Meta_isListLevelDefEq___main(x_1, x_2, x_3, x_4); +x_5 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_1, x_2, x_3, x_4); return x_5; } } @@ -6735,54 +7120,52 @@ _G_initialized = true; res = initialize_Init_Lean_Meta_Basic(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__1 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__1); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__2 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__2); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__3 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__3); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__4); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__5); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__6 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__6(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__6); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__7 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__7(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__7); -l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__8 = _init_l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__8(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_7__isLevelDefEqAux___main___closed__8); -l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__1 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__1); -l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__2); -l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__3 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedStep___closed__3); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__1 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__1); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__2 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__2); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__3); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__4 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__4(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__4); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__5 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__5(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__5); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__6 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__6(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__6); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__7 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__7(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__7); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__8 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__8(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__8); -l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__9 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__9(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponedAux___main___closed__9); -l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__1 = _init_l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__1(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__1); -l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2 = _init_l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__2); -l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__3 = _init_l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__3(); -lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_12__processPostponed___closed__3); -l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___closed__1 = _init_l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___closed__1(); -lean_mark_persistent(l_Lean_Meta_try___at_Lean_Meta_isLevelDefEq___spec__1___closed__1); +l_Lean_Meta_isLevelDefEqAux___main___closed__1 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__1(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__1); +l_Lean_Meta_isLevelDefEqAux___main___closed__2 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__2(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__2); +l_Lean_Meta_isLevelDefEqAux___main___closed__3 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__3(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__3); +l_Lean_Meta_isLevelDefEqAux___main___closed__4 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__4(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__4); +l_Lean_Meta_isLevelDefEqAux___main___closed__5 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__5(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__5); +l_Lean_Meta_isLevelDefEqAux___main___closed__6 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__6(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__6); +l_Lean_Meta_isLevelDefEqAux___main___closed__7 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__7(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__7); +l_Lean_Meta_isLevelDefEqAux___main___closed__8 = _init_l_Lean_Meta_isLevelDefEqAux___main___closed__8(); +lean_mark_persistent(l_Lean_Meta_isLevelDefEqAux___main___closed__8); +l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__1 = _init_l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__1); +l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2 = _init_l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__2); +l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__3 = _init_l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_9__processPostponedStep___closed__3); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__1 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__1); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__2 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__2); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__3); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__4 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__4(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__4); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__5 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__5(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__5); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__6 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__6(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__6); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__7 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__7(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__7); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__8 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__8(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__8); +l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__9 = _init_l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__9(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_10__processPostponedAux___main___rarg___closed__9); +l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__1 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__1(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__1); +l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__2); +l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__3 = _init_l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__3(); +lean_mark_persistent(l___private_Init_Lean_Meta_LevelDefEq_11__processPostponed___closed__3); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/library/Init/Lean/Meta/Offset.c b/stage0/library/Init/Lean/Meta/Offset.c index 29c73e8127..2238457d1d 100644 --- a/stage0/library/Init/Lean/Meta/Offset.c +++ b/stage0/library/Init/Lean/Meta/Offset.c @@ -13,14 +13,13 @@ #ifdef __cplusplus extern "C" { #endif +lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkCAppB(lean_object*, lean_object*, lean_object*); uint8_t lean_name_eq(lean_object*, lean_object*); -lean_object* l_Lean_Meta_isDefEqOffset___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_evalNat___main___closed__10; lean_object* l___private_Init_Lean_Meta_Offset_1__getOffset___main(lean_object*); lean_object* l___private_Init_Lean_Meta_Offset_1__getOffset(lean_object*); lean_object* l_Lean_Expr_getAppFn___main(lean_object*); -lean_object* l_Lean_Meta_isDefEqOffset___boxed(lean_object*); lean_object* l_Lean_Meta_evalNat(lean_object*); lean_object* lean_nat_add(lean_object*, lean_object*); lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); @@ -28,7 +27,7 @@ uint8_t lean_nat_dec_eq(lean_object*, lean_object*); lean_object* l_Lean_Meta_evalNat___main___closed__11; lean_object* lean_nat_sub(lean_object*, lean_object*); lean_object* l_Lean_Meta_evalNat___main(lean_object*); -lean_object* l_Lean_Meta_isDefEqOffset(lean_object*); +lean_object* l_Lean_Meta_isDefEqOffset(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_evalNat___main___closed__12; lean_object* lean_name_mk_string(lean_object*, lean_object*); extern lean_object* l_Lean_Literal_type___closed__1; @@ -1428,161 +1427,158 @@ return x_38; } } } -lean_object* l_Lean_Meta_isDefEqOffset___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +lean_object* l_Lean_Meta_isDefEqOffset(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { _start: { +lean_object* x_5; +lean_inc(x_1); +x_5 = l___private_Init_Lean_Meta_Offset_2__isOffset(x_1); +if (lean_obj_tag(x_5) == 0) +{ lean_object* x_6; -lean_inc(x_2); -x_6 = l___private_Init_Lean_Meta_Offset_2__isOffset(x_2); +x_6 = l_Lean_Meta_evalNat___main(x_1); if (lean_obj_tag(x_6) == 0) { -lean_object* x_7; -x_7 = l_Lean_Meta_evalNat___main(x_2); -if (lean_obj_tag(x_7) == 0) -{ -uint8_t x_8; lean_object* x_9; lean_object* x_10; -lean_dec(x_4); +uint8_t x_7; lean_object* x_8; lean_object* x_9; lean_dec(x_3); lean_dec(x_2); lean_dec(x_1); -x_8 = 2; -x_9 = lean_box(x_8); -x_10 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_10, 0, x_9); -lean_ctor_set(x_10, 1, x_5); -return x_10; +x_7 = 0; +x_8 = lean_box(x_7); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_4); +return x_9; } else { -lean_object* x_11; lean_object* x_12; -x_11 = lean_ctor_get(x_7, 0); -lean_inc(x_11); -lean_dec(x_7); -lean_inc(x_3); -x_12 = l___private_Init_Lean_Meta_Offset_2__isOffset(x_3); +lean_object* x_10; lean_object* x_11; +x_10 = lean_ctor_get(x_6, 0); +lean_inc(x_10); +lean_dec(x_6); +lean_inc(x_2); +x_11 = l___private_Init_Lean_Meta_Offset_2__isOffset(x_2); +if (lean_obj_tag(x_11) == 0) +{ +lean_object* x_12; +lean_dec(x_3); +lean_dec(x_1); +x_12 = l_Lean_Meta_evalNat___main(x_2); +lean_dec(x_2); if (lean_obj_tag(x_12) == 0) { -lean_object* x_13; -lean_dec(x_4); -lean_dec(x_2); -lean_dec(x_1); -x_13 = l_Lean_Meta_evalNat___main(x_3); -lean_dec(x_3); -if (lean_obj_tag(x_13) == 0) -{ -uint8_t x_14; lean_object* x_15; lean_object* x_16; -lean_dec(x_11); -x_14 = 2; -x_15 = lean_box(x_14); -x_16 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_16, 0, x_15); -lean_ctor_set(x_16, 1, x_5); -return x_16; +uint8_t x_13; lean_object* x_14; lean_object* x_15; +lean_dec(x_10); +x_13 = 0; +x_14 = lean_box(x_13); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_4); +return x_15; } else { -lean_object* x_17; uint8_t x_18; uint8_t x_19; lean_object* x_20; lean_object* x_21; -x_17 = lean_ctor_get(x_13, 0); -lean_inc(x_17); -lean_dec(x_13); -x_18 = lean_nat_dec_eq(x_11, x_17); -lean_dec(x_17); -lean_dec(x_11); -x_19 = l_Bool_toLBool(x_18); -x_20 = lean_box(x_19); -x_21 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_21, 0, x_20); -lean_ctor_set(x_21, 1, x_5); -return x_21; -} -} -else -{ -lean_object* x_22; lean_object* x_23; uint8_t x_24; -lean_dec(x_3); -x_22 = lean_ctor_get(x_12, 0); -lean_inc(x_22); +lean_object* x_16; uint8_t x_17; uint8_t x_18; lean_object* x_19; lean_object* x_20; +x_16 = lean_ctor_get(x_12, 0); +lean_inc(x_16); lean_dec(x_12); -x_23 = lean_ctor_get(x_22, 1); -lean_inc(x_23); +x_17 = lean_nat_dec_eq(x_10, x_16); +lean_dec(x_16); +lean_dec(x_10); +x_18 = l_Bool_toLBool(x_17); +x_19 = lean_box(x_18); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_4); +return x_20; +} +} +else +{ +lean_object* x_21; lean_object* x_22; uint8_t x_23; +lean_dec(x_2); +x_21 = lean_ctor_get(x_11, 0); +lean_inc(x_21); +lean_dec(x_11); +x_22 = lean_ctor_get(x_21, 1); +lean_inc(x_22); +lean_dec(x_21); +x_23 = lean_nat_dec_le(x_22, x_10); +if (x_23 == 0) +{ +uint8_t x_24; lean_object* x_25; lean_object* x_26; lean_dec(x_22); -x_24 = lean_nat_dec_le(x_23, x_11); -if (x_24 == 0) -{ -uint8_t x_25; lean_object* x_26; lean_object* x_27; -lean_dec(x_23); -lean_dec(x_11); -lean_dec(x_4); -lean_dec(x_2); +lean_dec(x_10); +lean_dec(x_3); lean_dec(x_1); -x_25 = 0; -x_26 = lean_box(x_25); -x_27 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_27, 0, x_26); -lean_ctor_set(x_27, 1, x_5); -return x_27; +x_24 = 0; +x_25 = lean_box(x_24); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_25); +lean_ctor_set(x_26, 1, x_4); +return x_26; } else { -lean_object* x_28; lean_object* x_29; lean_object* x_30; -x_28 = lean_nat_sub(x_11, x_23); -lean_dec(x_23); -lean_dec(x_11); -x_29 = l_Lean_mkNatLit(x_28); -x_30 = lean_apply_4(x_1, x_2, x_29, x_4, x_5); -if (lean_obj_tag(x_30) == 0) +lean_object* x_27; lean_object* x_28; lean_object* x_29; +x_27 = lean_nat_sub(x_10, x_22); +lean_dec(x_22); +lean_dec(x_10); +x_28 = l_Lean_mkNatLit(x_27); +x_29 = l_Lean_Meta_isExprDefEqAux(x_1, x_28, x_3, x_4); +if (lean_obj_tag(x_29) == 0) { -uint8_t x_31; -x_31 = !lean_is_exclusive(x_30); -if (x_31 == 0) +uint8_t x_30; +x_30 = !lean_is_exclusive(x_29); +if (x_30 == 0) { -lean_object* x_32; uint8_t x_33; uint8_t x_34; lean_object* x_35; -x_32 = lean_ctor_get(x_30, 0); -x_33 = lean_unbox(x_32); -lean_dec(x_32); -x_34 = l_Bool_toLBool(x_33); -x_35 = lean_box(x_34); -lean_ctor_set(x_30, 0, x_35); -return x_30; +lean_object* x_31; uint8_t x_32; uint8_t x_33; lean_object* x_34; +x_31 = lean_ctor_get(x_29, 0); +x_32 = lean_unbox(x_31); +lean_dec(x_31); +x_33 = l_Bool_toLBool(x_32); +x_34 = lean_box(x_33); +lean_ctor_set(x_29, 0, x_34); +return x_29; } else { -lean_object* x_36; lean_object* x_37; uint8_t x_38; uint8_t x_39; lean_object* x_40; lean_object* x_41; -x_36 = lean_ctor_get(x_30, 0); -x_37 = lean_ctor_get(x_30, 1); -lean_inc(x_37); +lean_object* x_35; lean_object* x_36; uint8_t x_37; uint8_t x_38; lean_object* x_39; lean_object* x_40; +x_35 = lean_ctor_get(x_29, 0); +x_36 = lean_ctor_get(x_29, 1); lean_inc(x_36); -lean_dec(x_30); -x_38 = lean_unbox(x_36); -lean_dec(x_36); -x_39 = l_Bool_toLBool(x_38); -x_40 = lean_box(x_39); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_40); -lean_ctor_set(x_41, 1, x_37); -return x_41; +lean_inc(x_35); +lean_dec(x_29); +x_37 = lean_unbox(x_35); +lean_dec(x_35); +x_38 = l_Bool_toLBool(x_37); +x_39 = lean_box(x_38); +x_40 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_40, 0, x_39); +lean_ctor_set(x_40, 1, x_36); +return x_40; } } else { -uint8_t x_42; -x_42 = !lean_is_exclusive(x_30); -if (x_42 == 0) +uint8_t x_41; +x_41 = !lean_is_exclusive(x_29); +if (x_41 == 0) { -return x_30; +return x_29; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_30, 0); -x_44 = lean_ctor_get(x_30, 1); -lean_inc(x_44); +lean_object* x_42; lean_object* x_43; lean_object* x_44; +x_42 = lean_ctor_get(x_29, 0); +x_43 = lean_ctor_get(x_29, 1); lean_inc(x_43); -lean_dec(x_30); -x_45 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_45, 0, x_43); -lean_ctor_set(x_45, 1, x_44); -return x_45; +lean_inc(x_42); +lean_dec(x_29); +x_44 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_44, 0, x_42); +lean_ctor_set(x_44, 1, x_43); +return x_44; } } } @@ -1591,334 +1587,332 @@ return x_45; } else { -lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; -lean_dec(x_2); -x_46 = lean_ctor_get(x_6, 0); +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +lean_dec(x_1); +x_45 = lean_ctor_get(x_5, 0); +lean_inc(x_45); +lean_dec(x_5); +x_46 = lean_ctor_get(x_45, 0); lean_inc(x_46); -lean_dec(x_6); -x_47 = lean_ctor_get(x_46, 0); +x_47 = lean_ctor_get(x_45, 1); lean_inc(x_47); -x_48 = lean_ctor_get(x_46, 1); -lean_inc(x_48); -lean_dec(x_46); -lean_inc(x_3); -x_49 = l___private_Init_Lean_Meta_Offset_2__isOffset(x_3); +lean_dec(x_45); +lean_inc(x_2); +x_48 = l___private_Init_Lean_Meta_Offset_2__isOffset(x_2); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; +x_49 = l_Lean_Meta_evalNat___main(x_2); +lean_dec(x_2); if (lean_obj_tag(x_49) == 0) { -lean_object* x_50; -x_50 = l_Lean_Meta_evalNat___main(x_3); -lean_dec(x_3); -if (lean_obj_tag(x_50) == 0) -{ -uint8_t x_51; lean_object* x_52; lean_object* x_53; -lean_dec(x_48); +uint8_t x_50; lean_object* x_51; lean_object* x_52; lean_dec(x_47); -lean_dec(x_4); -lean_dec(x_1); -x_51 = 2; -x_52 = lean_box(x_51); -x_53 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_53, 0, x_52); -lean_ctor_set(x_53, 1, x_5); -return x_53; -} -else -{ -lean_object* x_54; uint8_t x_55; -x_54 = lean_ctor_get(x_50, 0); -lean_inc(x_54); -lean_dec(x_50); -x_55 = lean_nat_dec_le(x_48, x_54); -if (x_55 == 0) -{ -uint8_t x_56; lean_object* x_57; lean_object* x_58; -lean_dec(x_54); -lean_dec(x_48); -lean_dec(x_47); -lean_dec(x_4); -lean_dec(x_1); -x_56 = 0; -x_57 = lean_box(x_56); -x_58 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_58, 0, x_57); -lean_ctor_set(x_58, 1, x_5); -return x_58; -} -else -{ -lean_object* x_59; lean_object* x_60; lean_object* x_61; -x_59 = lean_nat_sub(x_54, x_48); -lean_dec(x_48); -lean_dec(x_54); -x_60 = l_Lean_mkNatLit(x_59); -x_61 = lean_apply_4(x_1, x_47, x_60, x_4, x_5); -if (lean_obj_tag(x_61) == 0) -{ -uint8_t x_62; -x_62 = !lean_is_exclusive(x_61); -if (x_62 == 0) -{ -lean_object* x_63; uint8_t x_64; uint8_t x_65; lean_object* x_66; -x_63 = lean_ctor_get(x_61, 0); -x_64 = lean_unbox(x_63); -lean_dec(x_63); -x_65 = l_Bool_toLBool(x_64); -x_66 = lean_box(x_65); -lean_ctor_set(x_61, 0, x_66); -return x_61; -} -else -{ -lean_object* x_67; lean_object* x_68; uint8_t x_69; uint8_t x_70; lean_object* x_71; lean_object* x_72; -x_67 = lean_ctor_get(x_61, 0); -x_68 = lean_ctor_get(x_61, 1); -lean_inc(x_68); -lean_inc(x_67); -lean_dec(x_61); -x_69 = lean_unbox(x_67); -lean_dec(x_67); -x_70 = l_Bool_toLBool(x_69); -x_71 = lean_box(x_70); -x_72 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_72, 0, x_71); -lean_ctor_set(x_72, 1, x_68); -return x_72; -} -} -else -{ -uint8_t x_73; -x_73 = !lean_is_exclusive(x_61); -if (x_73 == 0) -{ -return x_61; -} -else -{ -lean_object* x_74; lean_object* x_75; lean_object* x_76; -x_74 = lean_ctor_get(x_61, 0); -x_75 = lean_ctor_get(x_61, 1); -lean_inc(x_75); -lean_inc(x_74); -lean_dec(x_61); -x_76 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_76, 0, x_74); -lean_ctor_set(x_76, 1, x_75); -return x_76; -} -} -} -} -} -else -{ -lean_object* x_77; lean_object* x_78; lean_object* x_79; uint8_t x_80; +lean_dec(x_46); lean_dec(x_3); -x_77 = lean_ctor_get(x_49, 0); -lean_inc(x_77); +x_50 = 2; +x_51 = lean_box(x_50); +x_52 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_52, 0, x_51); +lean_ctor_set(x_52, 1, x_4); +return x_52; +} +else +{ +lean_object* x_53; uint8_t x_54; +x_53 = lean_ctor_get(x_49, 0); +lean_inc(x_53); lean_dec(x_49); -x_78 = lean_ctor_get(x_77, 0); +x_54 = lean_nat_dec_le(x_47, x_53); +if (x_54 == 0) +{ +uint8_t x_55; lean_object* x_56; lean_object* x_57; +lean_dec(x_53); +lean_dec(x_47); +lean_dec(x_46); +lean_dec(x_3); +x_55 = 0; +x_56 = lean_box(x_55); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_4); +return x_57; +} +else +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_nat_sub(x_53, x_47); +lean_dec(x_47); +lean_dec(x_53); +x_59 = l_Lean_mkNatLit(x_58); +x_60 = l_Lean_Meta_isExprDefEqAux(x_46, x_59, x_3, x_4); +if (lean_obj_tag(x_60) == 0) +{ +uint8_t x_61; +x_61 = !lean_is_exclusive(x_60); +if (x_61 == 0) +{ +lean_object* x_62; uint8_t x_63; uint8_t x_64; lean_object* x_65; +x_62 = lean_ctor_get(x_60, 0); +x_63 = lean_unbox(x_62); +lean_dec(x_62); +x_64 = l_Bool_toLBool(x_63); +x_65 = lean_box(x_64); +lean_ctor_set(x_60, 0, x_65); +return x_60; +} +else +{ +lean_object* x_66; lean_object* x_67; uint8_t x_68; uint8_t x_69; lean_object* x_70; lean_object* x_71; +x_66 = lean_ctor_get(x_60, 0); +x_67 = lean_ctor_get(x_60, 1); +lean_inc(x_67); +lean_inc(x_66); +lean_dec(x_60); +x_68 = lean_unbox(x_66); +lean_dec(x_66); +x_69 = l_Bool_toLBool(x_68); +x_70 = lean_box(x_69); +x_71 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_71, 0, x_70); +lean_ctor_set(x_71, 1, x_67); +return x_71; +} +} +else +{ +uint8_t x_72; +x_72 = !lean_is_exclusive(x_60); +if (x_72 == 0) +{ +return x_60; +} +else +{ +lean_object* x_73; lean_object* x_74; lean_object* x_75; +x_73 = lean_ctor_get(x_60, 0); +x_74 = lean_ctor_get(x_60, 1); +lean_inc(x_74); +lean_inc(x_73); +lean_dec(x_60); +x_75 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_75, 0, x_73); +lean_ctor_set(x_75, 1, x_74); +return x_75; +} +} +} +} +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; uint8_t x_79; +lean_dec(x_2); +x_76 = lean_ctor_get(x_48, 0); +lean_inc(x_76); +lean_dec(x_48); +x_77 = lean_ctor_get(x_76, 0); +lean_inc(x_77); +x_78 = lean_ctor_get(x_76, 1); lean_inc(x_78); -x_79 = lean_ctor_get(x_77, 1); -lean_inc(x_79); -lean_dec(x_77); -x_80 = lean_nat_dec_eq(x_48, x_79); +lean_dec(x_76); +x_79 = lean_nat_dec_eq(x_47, x_78); +if (x_79 == 0) +{ +uint8_t x_80; +x_80 = lean_nat_dec_lt(x_47, x_78); if (x_80 == 0) { -uint8_t x_81; -x_81 = lean_nat_dec_lt(x_48, x_79); -if (x_81 == 0) +lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_81 = lean_nat_sub(x_47, x_78); +lean_dec(x_78); +lean_dec(x_47); +x_82 = l_Lean_mkNatLit(x_81); +x_83 = l_Lean_Meta_evalNat___main___closed__12; +x_84 = l_Lean_mkCAppB(x_83, x_46, x_82); +x_85 = l_Lean_Meta_isExprDefEqAux(x_84, x_77, x_3, x_4); +if (lean_obj_tag(x_85) == 0) { -lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; -x_82 = lean_nat_sub(x_48, x_79); -lean_dec(x_79); -lean_dec(x_48); -x_83 = l_Lean_mkNatLit(x_82); -x_84 = l_Lean_Meta_evalNat___main___closed__12; -x_85 = l_Lean_mkCAppB(x_84, x_47, x_83); -x_86 = lean_apply_4(x_1, x_85, x_78, x_4, x_5); -if (lean_obj_tag(x_86) == 0) +uint8_t x_86; +x_86 = !lean_is_exclusive(x_85); +if (x_86 == 0) { -uint8_t x_87; -x_87 = !lean_is_exclusive(x_86); -if (x_87 == 0) -{ -lean_object* x_88; uint8_t x_89; uint8_t x_90; lean_object* x_91; -x_88 = lean_ctor_get(x_86, 0); -x_89 = lean_unbox(x_88); -lean_dec(x_88); -x_90 = l_Bool_toLBool(x_89); -x_91 = lean_box(x_90); -lean_ctor_set(x_86, 0, x_91); -return x_86; +lean_object* x_87; uint8_t x_88; uint8_t x_89; lean_object* x_90; +x_87 = lean_ctor_get(x_85, 0); +x_88 = lean_unbox(x_87); +lean_dec(x_87); +x_89 = l_Bool_toLBool(x_88); +x_90 = lean_box(x_89); +lean_ctor_set(x_85, 0, x_90); +return x_85; } else { -lean_object* x_92; lean_object* x_93; uint8_t x_94; uint8_t x_95; lean_object* x_96; lean_object* x_97; -x_92 = lean_ctor_get(x_86, 0); -x_93 = lean_ctor_get(x_86, 1); -lean_inc(x_93); +lean_object* x_91; lean_object* x_92; uint8_t x_93; uint8_t x_94; lean_object* x_95; lean_object* x_96; +x_91 = lean_ctor_get(x_85, 0); +x_92 = lean_ctor_get(x_85, 1); lean_inc(x_92); -lean_dec(x_86); -x_94 = lean_unbox(x_92); -lean_dec(x_92); -x_95 = l_Bool_toLBool(x_94); -x_96 = lean_box(x_95); -x_97 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_97, 0, x_96); -lean_ctor_set(x_97, 1, x_93); -return x_97; +lean_inc(x_91); +lean_dec(x_85); +x_93 = lean_unbox(x_91); +lean_dec(x_91); +x_94 = l_Bool_toLBool(x_93); +x_95 = lean_box(x_94); +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_95); +lean_ctor_set(x_96, 1, x_92); +return x_96; } } else { -uint8_t x_98; -x_98 = !lean_is_exclusive(x_86); -if (x_98 == 0) +uint8_t x_97; +x_97 = !lean_is_exclusive(x_85); +if (x_97 == 0) { -return x_86; +return x_85; } else { -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_86, 0); -x_100 = lean_ctor_get(x_86, 1); -lean_inc(x_100); +lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_98 = lean_ctor_get(x_85, 0); +x_99 = lean_ctor_get(x_85, 1); lean_inc(x_99); -lean_dec(x_86); -x_101 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_101, 0, x_99); -lean_ctor_set(x_101, 1, x_100); -return x_101; +lean_inc(x_98); +lean_dec(x_85); +x_100 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_100, 0, x_98); +lean_ctor_set(x_100, 1, x_99); +return x_100; } } } else { -lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; -x_102 = lean_nat_sub(x_79, x_48); -lean_dec(x_48); -lean_dec(x_79); -x_103 = l_Lean_mkNatLit(x_102); -x_104 = l_Lean_Meta_evalNat___main___closed__12; -x_105 = l_Lean_mkCAppB(x_104, x_78, x_103); -x_106 = lean_apply_4(x_1, x_47, x_105, x_4, x_5); -if (lean_obj_tag(x_106) == 0) +lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; +x_101 = lean_nat_sub(x_78, x_47); +lean_dec(x_47); +lean_dec(x_78); +x_102 = l_Lean_mkNatLit(x_101); +x_103 = l_Lean_Meta_evalNat___main___closed__12; +x_104 = l_Lean_mkCAppB(x_103, x_77, x_102); +x_105 = l_Lean_Meta_isExprDefEqAux(x_46, x_104, x_3, x_4); +if (lean_obj_tag(x_105) == 0) { -uint8_t x_107; -x_107 = !lean_is_exclusive(x_106); -if (x_107 == 0) +uint8_t x_106; +x_106 = !lean_is_exclusive(x_105); +if (x_106 == 0) { -lean_object* x_108; uint8_t x_109; uint8_t x_110; lean_object* x_111; -x_108 = lean_ctor_get(x_106, 0); -x_109 = lean_unbox(x_108); -lean_dec(x_108); -x_110 = l_Bool_toLBool(x_109); -x_111 = lean_box(x_110); -lean_ctor_set(x_106, 0, x_111); -return x_106; +lean_object* x_107; uint8_t x_108; uint8_t x_109; lean_object* x_110; +x_107 = lean_ctor_get(x_105, 0); +x_108 = lean_unbox(x_107); +lean_dec(x_107); +x_109 = l_Bool_toLBool(x_108); +x_110 = lean_box(x_109); +lean_ctor_set(x_105, 0, x_110); +return x_105; } else { -lean_object* x_112; lean_object* x_113; uint8_t x_114; uint8_t x_115; lean_object* x_116; lean_object* x_117; -x_112 = lean_ctor_get(x_106, 0); -x_113 = lean_ctor_get(x_106, 1); -lean_inc(x_113); +lean_object* x_111; lean_object* x_112; uint8_t x_113; uint8_t x_114; lean_object* x_115; lean_object* x_116; +x_111 = lean_ctor_get(x_105, 0); +x_112 = lean_ctor_get(x_105, 1); lean_inc(x_112); -lean_dec(x_106); -x_114 = lean_unbox(x_112); -lean_dec(x_112); -x_115 = l_Bool_toLBool(x_114); -x_116 = lean_box(x_115); -x_117 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_117, 0, x_116); -lean_ctor_set(x_117, 1, x_113); -return x_117; +lean_inc(x_111); +lean_dec(x_105); +x_113 = lean_unbox(x_111); +lean_dec(x_111); +x_114 = l_Bool_toLBool(x_113); +x_115 = lean_box(x_114); +x_116 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_116, 0, x_115); +lean_ctor_set(x_116, 1, x_112); +return x_116; } } else { -uint8_t x_118; -x_118 = !lean_is_exclusive(x_106); -if (x_118 == 0) +uint8_t x_117; +x_117 = !lean_is_exclusive(x_105); +if (x_117 == 0) { -return x_106; +return x_105; } else { -lean_object* x_119; lean_object* x_120; lean_object* x_121; -x_119 = lean_ctor_get(x_106, 0); -x_120 = lean_ctor_get(x_106, 1); -lean_inc(x_120); +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_105, 0); +x_119 = lean_ctor_get(x_105, 1); lean_inc(x_119); -lean_dec(x_106); -x_121 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_121, 0, x_119); -lean_ctor_set(x_121, 1, x_120); +lean_inc(x_118); +lean_dec(x_105); +x_120 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_120, 0, x_118); +lean_ctor_set(x_120, 1, x_119); +return x_120; +} +} +} +} +else +{ +lean_object* x_121; +lean_dec(x_78); +lean_dec(x_47); +x_121 = l_Lean_Meta_isExprDefEqAux(x_46, x_77, x_3, x_4); +if (lean_obj_tag(x_121) == 0) +{ +uint8_t x_122; +x_122 = !lean_is_exclusive(x_121); +if (x_122 == 0) +{ +lean_object* x_123; uint8_t x_124; uint8_t x_125; lean_object* x_126; +x_123 = lean_ctor_get(x_121, 0); +x_124 = lean_unbox(x_123); +lean_dec(x_123); +x_125 = l_Bool_toLBool(x_124); +x_126 = lean_box(x_125); +lean_ctor_set(x_121, 0, x_126); return x_121; } -} -} -} else { -lean_object* x_122; -lean_dec(x_79); -lean_dec(x_48); -x_122 = lean_apply_4(x_1, x_47, x_78, x_4, x_5); -if (lean_obj_tag(x_122) == 0) -{ -uint8_t x_123; -x_123 = !lean_is_exclusive(x_122); -if (x_123 == 0) -{ -lean_object* x_124; uint8_t x_125; uint8_t x_126; lean_object* x_127; -x_124 = lean_ctor_get(x_122, 0); -x_125 = lean_unbox(x_124); -lean_dec(x_124); -x_126 = l_Bool_toLBool(x_125); -x_127 = lean_box(x_126); -lean_ctor_set(x_122, 0, x_127); -return x_122; -} -else -{ -lean_object* x_128; lean_object* x_129; uint8_t x_130; uint8_t x_131; lean_object* x_132; lean_object* x_133; -x_128 = lean_ctor_get(x_122, 0); -x_129 = lean_ctor_get(x_122, 1); -lean_inc(x_129); +lean_object* x_127; lean_object* x_128; uint8_t x_129; uint8_t x_130; lean_object* x_131; lean_object* x_132; +x_127 = lean_ctor_get(x_121, 0); +x_128 = lean_ctor_get(x_121, 1); lean_inc(x_128); -lean_dec(x_122); -x_130 = lean_unbox(x_128); -lean_dec(x_128); -x_131 = l_Bool_toLBool(x_130); -x_132 = lean_box(x_131); -x_133 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_133, 0, x_132); -lean_ctor_set(x_133, 1, x_129); -return x_133; +lean_inc(x_127); +lean_dec(x_121); +x_129 = lean_unbox(x_127); +lean_dec(x_127); +x_130 = l_Bool_toLBool(x_129); +x_131 = lean_box(x_130); +x_132 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_132, 0, x_131); +lean_ctor_set(x_132, 1, x_128); +return x_132; } } else { -uint8_t x_134; -x_134 = !lean_is_exclusive(x_122); -if (x_134 == 0) +uint8_t x_133; +x_133 = !lean_is_exclusive(x_121); +if (x_133 == 0) { -return x_122; +return x_121; } else { -lean_object* x_135; lean_object* x_136; lean_object* x_137; -x_135 = lean_ctor_get(x_122, 0); -x_136 = lean_ctor_get(x_122, 1); -lean_inc(x_136); +lean_object* x_134; lean_object* x_135; lean_object* x_136; +x_134 = lean_ctor_get(x_121, 0); +x_135 = lean_ctor_get(x_121, 1); lean_inc(x_135); -lean_dec(x_122); -x_137 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_137, 0, x_135); -lean_ctor_set(x_137, 1, x_136); -return x_137; +lean_inc(x_134); +lean_dec(x_121); +x_136 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_136, 0, x_134); +lean_ctor_set(x_136, 1, x_135); +return x_136; } } } @@ -1926,23 +1920,6 @@ return x_137; } } } -lean_object* l_Lean_Meta_isDefEqOffset(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_isDefEqOffset___rarg), 5, 0); -return x_2; -} -} -lean_object* l_Lean_Meta_isDefEqOffset___boxed(lean_object* x_1) { -_start: -{ -lean_object* x_2; -x_2 = l_Lean_Meta_isDefEqOffset(x_1); -lean_dec(x_1); -return x_2; -} -} lean_object* initialize_Init_Lean_LBool(lean_object*); lean_object* initialize_Init_Lean_Meta_InferType(lean_object*); static bool _G_initialized = false; diff --git a/stage0/library/Init/Lean/Meta/WHNF.c b/stage0/library/Init/Lean/Meta/WHNF.c index 8129644158..aa32519f3e 100644 --- a/stage0/library/Init/Lean/Meta/WHNF.c +++ b/stage0/library/Init/Lean/Meta/WHNF.c @@ -1,6 +1,6 @@ // Lean compiler output // Module: Init.Lean.Meta.WHNF -// Imports: Init.Lean.AuxRecursor Init.Lean.WHNF Init.Lean.Meta.Basic +// Imports: Init.Lean.AuxRecursor Init.Lean.WHNF Init.Lean.Meta.Basic Init.Lean.Meta.LevelDefEq #include "runtime/lean.h" #if defined(__clang__) #pragma clang diagnostic ignored "-Wunused-parameter" @@ -13,33 +13,145 @@ #ifdef __cplusplus extern "C" { #endif +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_mk_empty_array_with_capacity(lean_object*); lean_object* l_Lean_Meta_unfoldDefinitionAux(lean_object*); +lean_object* l_unreachable_x21___rarg(lean_object*); extern lean_object* l_EIO_Monad___closed__1; extern lean_object* l_Lean_noConfusionExt; -lean_object* l_Lean_Meta_whnfAux(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__33(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_4__getRecRuleFor(lean_object*, lean_object*); +lean_object* l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getExprMVarAssignment___boxed(lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__21___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at_Lean_Meta_whnfImpl___main___spec__5(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isExprDefEqAux(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l___private_Init_Lean_WHNF_6__isIdRhsApp(lean_object*); lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__19___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__22___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__29(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_isQuotRecStuck___at_Lean_Meta_whnfImpl___main___spec__25___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_ReaderT_Monad___rarg(lean_object*); +lean_object* l_Lean_Meta_setWHNFRef___closed__1; +lean_object* l_Lean_Meta_isAuxDef_x3f___boxed(lean_object*, lean_object*, lean_object*); +lean_object* lean_expr_instantiate1(lean_object*, lean_object*); +lean_object* lean_array_get_size(lean_object*); +lean_object* l_Lean_isRecStuck___at_Lean_Meta_whnfImpl___main___spec__26(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_getAppFn___main(lean_object*); +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__9___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_getAppArgs___closed__1; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__31(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__22(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1; +lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at_Lean_Meta_whnfImpl___main___spec__12(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__8; lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4; extern lean_object* l_Lean_auxRecExt; +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_nat_add(lean_object*, lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__7; +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__4___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__28(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_getAppNumArgsAux___main(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__27(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__4(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_RecursorVal_getMajorIdx(lean_object*); +lean_object* lean_array_fget(lean_object*, lean_object*); +uint8_t lean_nat_dec_eq(lean_object*, lean_object*); +lean_object* l_Lean_Meta_setWHNFRef(lean_object*); +lean_object* l___private_Init_Lean_WHNF_3__toCtorIfLit(lean_object*); +lean_object* lean_nat_sub(lean_object*, lean_object*); lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__3; +lean_object* l_Array_shrink___main___rarg(lean_object*, lean_object*); lean_object* l_Lean_Meta_getConstNoEx___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_whnfAux___main(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f___boxed(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_hasExprMVar(lean_object*); +lean_object* lean_array_get(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Expr_2__mkAppRangeAux___main(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_List_lengthAux___main___rarg(lean_object*, lean_object*); +lean_object* lean_instantiate_lparams(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_ConstantInfo_name(lean_object*); +lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__18___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_name_mk_string(lean_object*, lean_object*); +uint8_t l_Lean_ConstantInfo_hasValue(lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__6; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_unfoldDefinitionAux___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f(lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_isConstOf(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Expr_3__getAppArgsAux___main(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_getStuckMVar___main___at_Lean_Meta_whnfImpl___main___spec__24(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnf(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__13(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Lean_Expr_isLambda(lean_object*); +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__8___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isAuxDef_x3f(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_RecursorVal_getInduct(lean_object*); +lean_object* l_Lean_LocalDecl_value_x3f(lean_object*); +lean_object* l_Lean_ConstantInfo_lparams(lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* lean_instantiate_value_lparams(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_7__extractIdRhs(lean_object*); +lean_object* l_Lean_isRecStuck___at_Lean_Meta_whnfImpl___main___spec__26___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_getLocalDecl(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfEasyCases___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_whnfCore___main___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Meta_whnfAux___main___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_ReaderT_pure___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t lean_expr_eqv(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(lean_object*, lean_object*); +uint8_t lean_nat_dec_le(lean_object*, lean_object*); +lean_object* l_Lean_isQuotRecStuck___at_Lean_Meta_whnfImpl___main___spec__25(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_mkApp(lean_object*, lean_object*); +lean_object* l_Lean_Expr_betaRev(lean_object*, lean_object*); +lean_object* l_Lean_Meta_getConstAux(lean_object*, uint8_t, lean_object*, lean_object*); +lean_object* l_Lean_Expr_updateFn___main(lean_object*, lean_object*); +extern lean_object* l_Lean_Meta_whnfRef; +lean_object* l_Lean_Meta_synthPending(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnfImpl___main(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__30(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__9(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__19(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_inferType(lean_object*, lean_object*, lean_object*); +lean_object* lean_io_ref_set(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_isExprDefEq(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10(lean_object*, lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Expr_Inhabited; uint8_t l_Lean_TagDeclarationExtension_isTagged(lean_object*, lean_object*, lean_object*); +lean_object* lean_mk_array(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_1__getFirstCtor___at_Lean_Meta_whnfImpl___main___spec__7(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_unfoldDefinitionAux___at_Lean_Meta_whnfImpl___main___spec__11(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__9; +lean_object* lean_metavar_ctx_get_expr_assignment(lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__18(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34___closed__1; +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Expr_getRevArgD___main(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at_Lean_Meta_whnfImpl___main___spec__20(lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__21(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Meta_whnfImpl(lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__32(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_mkConst(lean_object*, lean_object*); +extern lean_object* l_Lean_smartUnfoldingSuffix; +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__17(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__14(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at_Lean_Meta_whnfImpl___main___spec__15(lean_object*, lean_object*, lean_object*); +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__8(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__17___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +uint8_t lean_nat_dec_lt(lean_object*, lean_object*); +lean_object* l_monadInhabited___rarg(lean_object*, lean_object*); lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5; -lean_object* l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Meta_isAuxDef_x3f(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; lean_object* x_5; uint8_t x_6; @@ -72,11 +184,11 @@ return x_13; } } } -lean_object* l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +lean_object* l_Lean_Meta_isAuxDef_x3f___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3) { _start: { lean_object* x_4; -x_4 = l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f(x_1, x_2, x_3); +x_4 = l_Lean_Meta_isAuxDef_x3f(x_1, x_2, x_3); lean_dec(x_2); lean_dec(x_1); return x_4; @@ -111,7 +223,7 @@ lean_object* _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__3() { _start: { lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l___private_Init_Lean_Meta_WHNF_1__isAuxDef_x3f___boxed), 3, 0); +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_isAuxDef_x3f___boxed), 3, 0); return x_1; } } @@ -119,7 +231,7 @@ lean_object* _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4() { _start: { lean_object* x_1; -x_1 = lean_alloc_closure((void*)(l_Lean_Meta_getLocalDecl), 3, 0); +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_whnf), 3, 0); return x_1; } } @@ -127,23 +239,59 @@ lean_object* _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5() { _start: { lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_inferType), 3, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__6() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_isExprDefEq), 4, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__7() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_synthPending), 3, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__8() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_getLocalDecl), 3, 0); +return x_1; +} +} +lean_object* _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__9() { +_start: +{ +lean_object* x_1; x_1 = lean_alloc_closure((void*)(l_Lean_Meta_getExprMVarAssignment___boxed), 3, 0); return x_1; } } -lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8, lean_object* x_9) { +lean_object* l_Lean_Meta_unfoldDefinitionAux___rarg(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { _start: { -lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; -x_10 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg___lambda__1___boxed), 4, 1); -lean_closure_set(x_10, 0, x_6); -x_11 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1; -x_12 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -x_13 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__3; -x_14 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4; -x_15 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5; -x_16 = l_Lean_unfoldDefinitionAux___rarg(x_11, x_12, x_13, x_1, x_2, x_3, x_4, x_14, x_15, x_5, x_10, x_7); -x_17 = lean_apply_2(x_16, x_8, x_9); +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_6 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg___lambda__1___boxed), 4, 1); +lean_closure_set(x_6, 0, x_2); +x_7 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1; +x_8 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +x_9 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__3; +x_10 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4; +x_11 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5; +x_12 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__6; +x_13 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__7; +x_14 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__8; +x_15 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__9; +x_16 = l_Lean_unfoldDefinitionAux___rarg(x_7, x_8, x_9, x_10, x_11, x_12, x_13, x_14, x_15, x_1, x_6, x_3); +x_17 = lean_apply_2(x_16, x_4, x_5); return x_17; } } @@ -151,7 +299,7 @@ lean_object* l_Lean_Meta_unfoldDefinitionAux(lean_object* x_1) { _start: { lean_object* x_2; -x_2 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 9, 0); +x_2 = lean_alloc_closure((void*)(l_Lean_Meta_unfoldDefinitionAux___rarg), 5, 0); return x_2; } } @@ -164,104 +312,11913 @@ lean_dec(x_2); return x_5; } } -lean_object* l_Lean_Meta_whnfAux___main___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { _start: { -lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; lean_object* x_14; lean_object* x_15; -lean_inc(x_3); -lean_inc(x_2); -lean_inc(x_1); -x_9 = lean_alloc_closure((void*)(l_Lean_Meta_whnfAux___main), 6, 3); -lean_closure_set(x_9, 0, x_1); -lean_closure_set(x_9, 1, x_2); -lean_closure_set(x_9, 2, x_3); -x_10 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; -x_11 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__3; -x_12 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4; -x_13 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5; -lean_inc(x_2); -lean_inc(x_1); -lean_inc(x_9); -x_14 = l_Lean_whnfCore___main___rarg(x_4, x_10, x_11, x_9, x_1, x_2, x_12, x_13, x_6); -lean_inc(x_7); -x_15 = lean_apply_2(x_14, x_7, x_8); -if (lean_obj_tag(x_15) == 0) +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) { -lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; -x_16 = lean_ctor_get(x_15, 0); +uint8_t x_14; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_14 = lean_expr_eqv(x_2, x_3); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; +x_15 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_8); +return x_16; +} +else +{ +lean_object* x_17; +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_1); +lean_ctor_set(x_17, 1, x_8); +return x_17; +} +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +lean_dec(x_1); +x_18 = lean_instantiate_value_lparams(x_4, x_5); +x_19 = l_Lean_Expr_betaRev(x_18, x_6); +lean_dec(x_18); +x_20 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_19); +x_21 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_20, x_7, x_8); +return x_21; +} +} +} +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__3(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; uint8_t x_113; lean_object* x_114; +x_113 = lean_ctor_get_uint8(x_4, sizeof(void*)*1); +x_114 = lean_box(x_113); +switch (lean_obj_tag(x_114)) { +case 2: +{ +lean_object* x_115; lean_object* x_116; +x_115 = lean_unsigned_to_nat(5u); +x_116 = lean_unsigned_to_nat(3u); +x_9 = x_115; +x_10 = x_116; +goto block_112; +} +case 3: +{ +lean_object* x_117; lean_object* x_118; +x_117 = lean_unsigned_to_nat(4u); +x_118 = lean_unsigned_to_nat(3u); +x_9 = x_117; +x_10 = x_118; +goto block_112; +} +default: +{ +uint8_t x_119; +lean_dec(x_114); +lean_dec(x_7); +x_119 = lean_expr_eqv(x_2, x_3); +if (x_119 == 0) +{ +lean_object* x_120; lean_object* x_121; +x_120 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_121 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_121, 0, x_120); +lean_ctor_set(x_121, 1, x_8); +return x_121; +} +else +{ +lean_object* x_122; +x_122 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_122, 0, x_1); +lean_ctor_set(x_122, 1, x_8); +return x_122; +} +} +} +block_112: +{ +lean_object* x_11; uint8_t x_12; +x_11 = lean_array_get_size(x_6); +x_12 = lean_nat_dec_lt(x_9, x_11); +if (x_12 == 0) +{ +uint8_t x_13; +lean_dec(x_11); +lean_dec(x_7); +x_13 = lean_expr_eqv(x_2, x_3); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_1); +lean_ctor_set(x_16, 1, x_8); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_array_fget(x_6, x_9); +lean_inc(x_7); +x_18 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_17, x_7, x_8); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +if (lean_obj_tag(x_19) == 5) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +if (lean_obj_tag(x_20) == 5) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +lean_dec(x_20); +if (lean_obj_tag(x_21) == 5) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +lean_dec(x_21); +if (lean_obj_tag(x_22) == 4) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_object* x_27; +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_dec(x_18); +x_24 = lean_ctor_get(x_19, 1); +lean_inc(x_24); +lean_dec(x_19); +x_25 = lean_ctor_get(x_22, 0); +lean_inc(x_25); +lean_dec(x_22); +x_26 = 0; +x_27 = l_Lean_Meta_getConstAux(x_25, x_26, x_7, x_23); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +if (lean_obj_tag(x_28) == 0) +{ +uint8_t x_29; +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_29 = !lean_is_exclusive(x_27); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_27, 0); +lean_dec(x_30); +x_31 = lean_expr_eqv(x_2, x_3); +if (x_31 == 0) +{ +lean_object* x_32; +x_32 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_32); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_33; uint8_t x_34; +x_33 = lean_ctor_get(x_27, 1); +lean_inc(x_33); +lean_dec(x_27); +x_34 = lean_expr_eqv(x_2, x_3); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; +x_35 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_33); +return x_36; +} +else +{ +lean_object* x_37; +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_1); +lean_ctor_set(x_37, 1, x_33); +return x_37; +} +} +} +else +{ +lean_object* x_38; +x_38 = lean_ctor_get(x_28, 0); +lean_inc(x_38); +lean_dec(x_28); +if (lean_obj_tag(x_38) == 4) +{ +lean_object* x_39; uint8_t x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +lean_dec(x_38); +x_40 = lean_ctor_get_uint8(x_39, sizeof(void*)*1); +lean_dec(x_39); +x_41 = lean_box(x_40); +if (lean_obj_tag(x_41) == 1) +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_1); +x_42 = lean_ctor_get(x_27, 1); +lean_inc(x_42); +lean_dec(x_27); +x_43 = l_Lean_Expr_Inhabited; +x_44 = lean_array_get(x_43, x_6, x_10); +x_45 = l_Lean_mkApp(x_44, x_24); +x_46 = lean_unsigned_to_nat(1u); +x_47 = lean_nat_add(x_9, x_46); +x_48 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_11, x_6, x_47, x_45); +lean_dec(x_11); +x_49 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_48, x_7, x_42); +return x_49; +} +else +{ +uint8_t x_50; +lean_dec(x_41); +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_50 = !lean_is_exclusive(x_27); +if (x_50 == 0) +{ +lean_object* x_51; uint8_t x_52; +x_51 = lean_ctor_get(x_27, 0); +lean_dec(x_51); +x_52 = lean_expr_eqv(x_2, x_3); +if (x_52 == 0) +{ +lean_object* x_53; +x_53 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_53); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_54; uint8_t x_55; +x_54 = lean_ctor_get(x_27, 1); +lean_inc(x_54); +lean_dec(x_27); +x_55 = lean_expr_eqv(x_2, x_3); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; +x_56 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_54); +return x_57; +} +else +{ +lean_object* x_58; +x_58 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_58, 0, x_1); +lean_ctor_set(x_58, 1, x_54); +return x_58; +} +} +} +} +else +{ +uint8_t x_59; +lean_dec(x_38); +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_59 = !lean_is_exclusive(x_27); +if (x_59 == 0) +{ +lean_object* x_60; uint8_t x_61; +x_60 = lean_ctor_get(x_27, 0); +lean_dec(x_60); +x_61 = lean_expr_eqv(x_2, x_3); +if (x_61 == 0) +{ +lean_object* x_62; +x_62 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_62); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_63; uint8_t x_64; +x_63 = lean_ctor_get(x_27, 1); +lean_inc(x_63); +lean_dec(x_27); +x_64 = lean_expr_eqv(x_2, x_3); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_63); +return x_66; +} +else +{ +lean_object* x_67; +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_1); +lean_ctor_set(x_67, 1, x_63); +return x_67; +} +} +} +} +} +else +{ +uint8_t x_68; +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_1); +x_68 = !lean_is_exclusive(x_27); +if (x_68 == 0) +{ +return x_27; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_27, 0); +x_70 = lean_ctor_get(x_27, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_27); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +uint8_t x_72; +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_72 = !lean_is_exclusive(x_18); +if (x_72 == 0) +{ +lean_object* x_73; uint8_t x_74; +x_73 = lean_ctor_get(x_18, 0); +lean_dec(x_73); +x_74 = lean_expr_eqv(x_2, x_3); +if (x_74 == 0) +{ +lean_object* x_75; +x_75 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_75); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_76; uint8_t x_77; +x_76 = lean_ctor_get(x_18, 1); +lean_inc(x_76); +lean_dec(x_18); +x_77 = lean_expr_eqv(x_2, x_3); +if (x_77 == 0) +{ +lean_object* x_78; lean_object* x_79; +x_78 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_79 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_79, 0, x_78); +lean_ctor_set(x_79, 1, x_76); +return x_79; +} +else +{ +lean_object* x_80; +x_80 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_80, 0, x_1); +lean_ctor_set(x_80, 1, x_76); +return x_80; +} +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_21); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_81 = !lean_is_exclusive(x_18); +if (x_81 == 0) +{ +lean_object* x_82; uint8_t x_83; +x_82 = lean_ctor_get(x_18, 0); +lean_dec(x_82); +x_83 = lean_expr_eqv(x_2, x_3); +if (x_83 == 0) +{ +lean_object* x_84; +x_84 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_84); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_85; uint8_t x_86; +x_85 = lean_ctor_get(x_18, 1); +lean_inc(x_85); +lean_dec(x_18); +x_86 = lean_expr_eqv(x_2, x_3); +if (x_86 == 0) +{ +lean_object* x_87; lean_object* x_88; +x_87 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_87); +lean_ctor_set(x_88, 1, x_85); +return x_88; +} +else +{ +lean_object* x_89; +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_1); +lean_ctor_set(x_89, 1, x_85); +return x_89; +} +} +} +} +else +{ +uint8_t x_90; +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_90 = !lean_is_exclusive(x_18); +if (x_90 == 0) +{ +lean_object* x_91; uint8_t x_92; +x_91 = lean_ctor_get(x_18, 0); +lean_dec(x_91); +x_92 = lean_expr_eqv(x_2, x_3); +if (x_92 == 0) +{ +lean_object* x_93; +x_93 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_93); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_94; uint8_t x_95; +x_94 = lean_ctor_get(x_18, 1); +lean_inc(x_94); +lean_dec(x_18); +x_95 = lean_expr_eqv(x_2, x_3); +if (x_95 == 0) +{ +lean_object* x_96; lean_object* x_97; +x_96 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_97 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_97, 0, x_96); +lean_ctor_set(x_97, 1, x_94); +return x_97; +} +else +{ +lean_object* x_98; +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_1); +lean_ctor_set(x_98, 1, x_94); +return x_98; +} +} +} +} +else +{ +uint8_t x_99; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_99 = !lean_is_exclusive(x_18); +if (x_99 == 0) +{ +lean_object* x_100; uint8_t x_101; +x_100 = lean_ctor_get(x_18, 0); +lean_dec(x_100); +x_101 = lean_expr_eqv(x_2, x_3); +if (x_101 == 0) +{ +lean_object* x_102; +x_102 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_102); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_103; uint8_t x_104; +x_103 = lean_ctor_get(x_18, 1); +lean_inc(x_103); +lean_dec(x_18); +x_104 = lean_expr_eqv(x_2, x_3); +if (x_104 == 0) +{ +lean_object* x_105; lean_object* x_106; +x_105 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_105); +lean_ctor_set(x_106, 1, x_103); +return x_106; +} +else +{ +lean_object* x_107; +x_107 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_1); +lean_ctor_set(x_107, 1, x_103); +return x_107; +} +} +} +} +else +{ +uint8_t x_108; +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_1); +x_108 = !lean_is_exclusive(x_18); +if (x_108 == 0) +{ +return x_18; +} +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_18, 0); +x_110 = lean_ctor_get(x_18, 1); +lean_inc(x_110); +lean_inc(x_109); +lean_dec(x_18); +x_111 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_111, 0, x_109); +lean_ctor_set(x_111, 1, x_110); +return x_111; +} +} +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_1__getFirstCtor___at_Lean_Meta_whnfImpl___main___spec__7(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +x_5 = lean_apply_3(x_1, x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +if (lean_obj_tag(x_6) == 0) +{ +uint8_t x_7; +x_7 = !lean_is_exclusive(x_5); +if (x_7 == 0) +{ +lean_object* x_8; lean_object* x_9; +x_8 = lean_ctor_get(x_5, 0); +lean_dec(x_8); +x_9 = lean_box(0); +lean_ctor_set(x_5, 0, x_9); +return x_5; +} +else +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_5, 1); +lean_inc(x_10); +lean_dec(x_5); +x_11 = lean_box(0); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_11); +lean_ctor_set(x_12, 1, x_10); +return x_12; +} +} +else +{ +uint8_t x_13; +x_13 = !lean_is_exclusive(x_6); +if (x_13 == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_6, 0); +if (lean_obj_tag(x_14) == 5) +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_ctor_get(x_14, 0); +lean_inc(x_15); +lean_dec(x_14); +x_16 = lean_ctor_get(x_15, 4); lean_inc(x_16); -x_17 = lean_ctor_get(x_15, 1); -lean_inc(x_17); lean_dec(x_15); -lean_inc(x_16); -x_18 = lean_alloc_closure((void*)(l_ReaderT_pure___rarg___boxed), 4, 3); -lean_closure_set(x_18, 0, x_5); -lean_closure_set(x_18, 1, lean_box(0)); -lean_closure_set(x_18, 2, x_16); -lean_inc(x_9); -x_19 = l_Lean_Meta_unfoldDefinitionAux___rarg(x_9, x_1, x_2, x_3, x_16, x_18, x_9, x_7, x_17); +if (lean_obj_tag(x_16) == 0) +{ +uint8_t x_17; +lean_free_object(x_6); +x_17 = !lean_is_exclusive(x_5); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; +x_18 = lean_ctor_get(x_5, 0); +lean_dec(x_18); +x_19 = lean_box(0); +lean_ctor_set(x_5, 0, x_19); +return x_5; +} +else +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; +x_20 = lean_ctor_get(x_5, 1); +lean_inc(x_20); +lean_dec(x_5); +x_21 = lean_box(0); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_20); +return x_22; +} +} +else +{ +uint8_t x_23; +x_23 = !lean_is_exclusive(x_5); +if (x_23 == 0) +{ +lean_object* x_24; lean_object* x_25; +x_24 = lean_ctor_get(x_5, 0); +lean_dec(x_24); +x_25 = lean_ctor_get(x_16, 0); +lean_inc(x_25); +lean_dec(x_16); +lean_ctor_set(x_6, 0, x_25); +return x_5; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_5, 1); +lean_inc(x_26); +lean_dec(x_5); +x_27 = lean_ctor_get(x_16, 0); +lean_inc(x_27); +lean_dec(x_16); +lean_ctor_set(x_6, 0, x_27); +x_28 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_28, 0, x_6); +lean_ctor_set(x_28, 1, x_26); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_free_object(x_6); +lean_dec(x_14); +x_29 = !lean_is_exclusive(x_5); +if (x_29 == 0) +{ +lean_object* x_30; lean_object* x_31; +x_30 = lean_ctor_get(x_5, 0); +lean_dec(x_30); +x_31 = lean_box(0); +lean_ctor_set(x_5, 0, x_31); +return x_5; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_5, 1); +lean_inc(x_32); +lean_dec(x_5); +x_33 = lean_box(0); +x_34 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_34, 0, x_33); +lean_ctor_set(x_34, 1, x_32); +return x_34; +} +} +} +else +{ +lean_object* x_35; +x_35 = lean_ctor_get(x_6, 0); +lean_inc(x_35); +lean_dec(x_6); +if (lean_obj_tag(x_35) == 5) +{ +lean_object* x_36; lean_object* x_37; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +lean_dec(x_35); +x_37 = lean_ctor_get(x_36, 4); +lean_inc(x_37); +lean_dec(x_36); +if (lean_obj_tag(x_37) == 0) +{ +lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_38 = lean_ctor_get(x_5, 1); +lean_inc(x_38); +if (lean_is_exclusive(x_5)) { + lean_ctor_release(x_5, 0); + lean_ctor_release(x_5, 1); + x_39 = x_5; +} else { + lean_dec_ref(x_5); + x_39 = lean_box(0); +} +x_40 = lean_box(0); +if (lean_is_scalar(x_39)) { + x_41 = lean_alloc_ctor(0, 2, 0); +} else { + x_41 = x_39; +} +lean_ctor_set(x_41, 0, x_40); +lean_ctor_set(x_41, 1, x_38); +return x_41; +} +else +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_42 = lean_ctor_get(x_5, 1); +lean_inc(x_42); +if (lean_is_exclusive(x_5)) { + lean_ctor_release(x_5, 0); + lean_ctor_release(x_5, 1); + x_43 = x_5; +} else { + lean_dec_ref(x_5); + x_43 = lean_box(0); +} +x_44 = lean_ctor_get(x_37, 0); +lean_inc(x_44); +lean_dec(x_37); +x_45 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_45, 0, x_44); +if (lean_is_scalar(x_43)) { + x_46 = lean_alloc_ctor(0, 2, 0); +} else { + x_46 = x_43; +} +lean_ctor_set(x_46, 0, x_45); +lean_ctor_set(x_46, 1, x_42); +return x_46; +} +} +else +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; +lean_dec(x_35); +x_47 = lean_ctor_get(x_5, 1); +lean_inc(x_47); +if (lean_is_exclusive(x_5)) { + lean_ctor_release(x_5, 0); + lean_ctor_release(x_5, 1); + x_48 = x_5; +} else { + lean_dec_ref(x_5); + x_48 = lean_box(0); +} +x_49 = lean_box(0); +if (lean_is_scalar(x_48)) { + x_50 = lean_alloc_ctor(0, 2, 0); +} else { + x_50 = x_48; +} +lean_ctor_set(x_50, 0, x_49); +lean_ctor_set(x_50, 1, x_47); +return x_50; +} +} +} +} +else +{ +uint8_t x_51; +x_51 = !lean_is_exclusive(x_5); +if (x_51 == 0) +{ +return x_5; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_5, 0); +x_53 = lean_ctor_get(x_5, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_5); +x_54 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_Expr_getAppFn___main(x_2); +if (lean_obj_tag(x_6) == 4) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_6, 0); +lean_inc(x_7); +x_8 = lean_ctor_get(x_6, 1); +lean_inc(x_8); +lean_dec(x_6); +x_9 = l___private_Init_Lean_WHNF_1__getFirstCtor___at_Lean_Meta_whnfImpl___main___spec__7(x_1, x_7, x_4, x_5); +if (lean_obj_tag(x_9) == 0) +{ +lean_object* x_10; +x_10 = lean_ctor_get(x_9, 0); +lean_inc(x_10); +if (lean_obj_tag(x_10) == 0) +{ +uint8_t x_11; +lean_dec(x_8); +lean_dec(x_2); +x_11 = !lean_is_exclusive(x_9); +if (x_11 == 0) +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_9, 0); +lean_dec(x_12); +x_13 = lean_box(0); +lean_ctor_set(x_9, 0, x_13); +return x_9; +} +else +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_9, 1); +lean_inc(x_14); +lean_dec(x_9); +x_15 = lean_box(0); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_14); +return x_16; +} +} +else +{ +uint8_t x_17; +x_17 = !lean_is_exclusive(x_9); +if (x_17 == 0) +{ +lean_object* x_18; uint8_t x_19; +x_18 = lean_ctor_get(x_9, 0); +lean_dec(x_18); +x_19 = !lean_is_exclusive(x_10); +if (x_19 == 0) +{ +lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_20 = lean_ctor_get(x_10, 0); +x_21 = l_Lean_mkConst(x_20, x_8); +x_22 = lean_unsigned_to_nat(0u); +x_23 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_22); +x_24 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_23); +x_25 = lean_mk_array(x_23, x_24); +x_26 = lean_unsigned_to_nat(1u); +x_27 = lean_nat_sub(x_23, x_26); +lean_dec(x_23); +x_28 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_25, x_27); +x_29 = l_Array_shrink___main___rarg(x_28, x_3); +x_30 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_29, x_29, x_22, x_21); +lean_dec(x_29); +lean_ctor_set(x_10, 0, x_30); +return x_9; +} +else +{ +lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_31 = lean_ctor_get(x_10, 0); +lean_inc(x_31); +lean_dec(x_10); +x_32 = l_Lean_mkConst(x_31, x_8); +x_33 = lean_unsigned_to_nat(0u); +x_34 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_33); +x_35 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_34); +x_36 = lean_mk_array(x_34, x_35); +x_37 = lean_unsigned_to_nat(1u); +x_38 = lean_nat_sub(x_34, x_37); +lean_dec(x_34); +x_39 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_36, x_38); +x_40 = l_Array_shrink___main___rarg(x_39, x_3); +x_41 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_40, x_40, x_33, x_32); +lean_dec(x_40); +x_42 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_42, 0, x_41); +lean_ctor_set(x_9, 0, x_42); +return x_9; +} +} +else +{ +lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_43 = lean_ctor_get(x_9, 1); +lean_inc(x_43); +lean_dec(x_9); +x_44 = lean_ctor_get(x_10, 0); +lean_inc(x_44); +if (lean_is_exclusive(x_10)) { + lean_ctor_release(x_10, 0); + x_45 = x_10; +} else { + lean_dec_ref(x_10); + x_45 = lean_box(0); +} +x_46 = l_Lean_mkConst(x_44, x_8); +x_47 = lean_unsigned_to_nat(0u); +x_48 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_47); +x_49 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_48); +x_50 = lean_mk_array(x_48, x_49); +x_51 = lean_unsigned_to_nat(1u); +x_52 = lean_nat_sub(x_48, x_51); +lean_dec(x_48); +x_53 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_50, x_52); +x_54 = l_Array_shrink___main___rarg(x_53, x_3); +x_55 = l_Array_iterateMAux___main___at_Lean_mkAppN___spec__1(x_54, x_54, x_47, x_46); +lean_dec(x_54); +if (lean_is_scalar(x_45)) { + x_56 = lean_alloc_ctor(1, 1, 0); +} else { + x_56 = x_45; +} +lean_ctor_set(x_56, 0, x_55); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_43); +return x_57; +} +} +} +else +{ +uint8_t x_58; +lean_dec(x_8); +lean_dec(x_2); +x_58 = !lean_is_exclusive(x_9); +if (x_58 == 0) +{ +return x_9; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_9, 0); +x_60 = lean_ctor_get(x_9, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_9); +x_61 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_61, 0, x_59); +lean_ctor_set(x_61, 1, x_60); +return x_61; +} +} +} +else +{ +lean_object* x_62; lean_object* x_63; +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_2); +lean_dec(x_1); +x_62 = lean_box(0); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_62); +lean_ctor_set(x_63, 1, x_5); +return x_63; +} +} +} +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__8(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; +x_5 = lean_nat_dec_lt(x_4, x_3); +if (x_5 == 0) +{ +uint8_t x_6; +lean_dec(x_4); +x_6 = 0; +return x_6; +} +else +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_fget(x_2, x_4); +x_8 = l_Lean_Expr_hasExprMVar(x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +x_9 = lean_unsigned_to_nat(1u); +x_10 = lean_nat_add(x_4, x_9); +lean_dec(x_4); +x_4 = x_10; +goto _start; +} +else +{ +lean_dec(x_4); +return x_8; +} +} +} +} +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__9(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_fget(x_3, x_5); +x_9 = l_Lean_Expr_hasExprMVar(x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_5, x_10); +lean_dec(x_5); +x_2 = lean_box(0); +x_5 = x_11; +goto _start; +} +else +{ +lean_dec(x_5); +return x_9; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at_Lean_Meta_whnfImpl___main___spec__5(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l_Lean_Meta_inferType(x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +lean_inc(x_3); +x_8 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_6, x_3, x_7); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_10 = lean_ctor_get(x_8, 0); +x_11 = lean_ctor_get(x_8, 1); +x_12 = l_Lean_Expr_getAppFn___main(x_10); +x_13 = l_Lean_RecursorVal_getInduct(x_1); +x_14 = l_Lean_Expr_isConstOf(x_12, x_13); +lean_dec(x_13); +lean_dec(x_12); +if (x_14 == 0) +{ +lean_object* x_15; +lean_dec(x_10); +lean_dec(x_3); +lean_dec(x_1); +x_15 = lean_box(0); +lean_ctor_set(x_8, 0, x_15); +return x_8; +} +else +{ +uint8_t x_16; +x_16 = l_Lean_Expr_hasExprMVar(x_10); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +lean_free_object(x_8); +x_17 = lean_ctor_get(x_1, 2); +lean_inc(x_17); +lean_dec(x_1); +x_18 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_19 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_18, x_10, x_17, x_3, x_11); +lean_dec(x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +if (lean_obj_tag(x_20) == 0) +{ +uint8_t x_21; +lean_dec(x_10); +lean_dec(x_3); +x_21 = !lean_is_exclusive(x_19); +if (x_21 == 0) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_19, 0); +lean_dec(x_22); return x_19; } else { -uint8_t x_20; +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_19, 1); +lean_inc(x_23); +lean_dec(x_19); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_20); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +else +{ +lean_object* x_25; uint8_t x_26; +x_25 = lean_ctor_get(x_19, 1); +lean_inc(x_25); +lean_dec(x_19); +x_26 = !lean_is_exclusive(x_20); +if (x_26 == 0) +{ +lean_object* x_27; lean_object* x_28; +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_3); +lean_inc(x_27); +x_28 = l_Lean_Meta_inferType(x_27, x_3, x_25); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = l_Lean_Meta_isExprDefEqAux(x_10, x_29, x_3, x_30); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; uint8_t x_33; +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_unbox(x_32); +lean_dec(x_32); +if (x_33 == 0) +{ +uint8_t x_34; +lean_free_object(x_20); +lean_dec(x_27); +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; +x_35 = lean_ctor_get(x_31, 0); +lean_dec(x_35); +x_36 = lean_box(0); +lean_ctor_set(x_31, 0, x_36); +return x_31; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_37 = lean_ctor_get(x_31, 1); +lean_inc(x_37); +lean_dec(x_31); +x_38 = lean_box(0); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_37); +return x_39; +} +} +else +{ +uint8_t x_40; +x_40 = !lean_is_exclusive(x_31); +if (x_40 == 0) +{ +lean_object* x_41; +x_41 = lean_ctor_get(x_31, 0); +lean_dec(x_41); +lean_ctor_set(x_31, 0, x_20); +return x_31; +} +else +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_31, 1); +lean_inc(x_42); +lean_dec(x_31); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_20); +lean_ctor_set(x_43, 1, x_42); +return x_43; +} +} +} +else +{ +uint8_t x_44; +lean_free_object(x_20); +lean_dec(x_27); +x_44 = !lean_is_exclusive(x_31); +if (x_44 == 0) +{ +return x_31; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_31, 0); +x_46 = lean_ctor_get(x_31, 1); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_31); +x_47 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_47, 0, x_45); +lean_ctor_set(x_47, 1, x_46); +return x_47; +} +} +} +else +{ +uint8_t x_48; +lean_free_object(x_20); +lean_dec(x_27); +lean_dec(x_10); +lean_dec(x_3); +x_48 = !lean_is_exclusive(x_28); +if (x_48 == 0) +{ +return x_28; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_28, 0); +x_50 = lean_ctor_get(x_28, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_28); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +else +{ +lean_object* x_52; lean_object* x_53; +x_52 = lean_ctor_get(x_20, 0); +lean_inc(x_52); +lean_dec(x_20); +lean_inc(x_3); +lean_inc(x_52); +x_53 = l_Lean_Meta_inferType(x_52, x_3, x_25); +if (lean_obj_tag(x_53) == 0) +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_54 = lean_ctor_get(x_53, 0); +lean_inc(x_54); +x_55 = lean_ctor_get(x_53, 1); +lean_inc(x_55); +lean_dec(x_53); +x_56 = l_Lean_Meta_isExprDefEqAux(x_10, x_54, x_3, x_55); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; uint8_t x_58; +x_57 = lean_ctor_get(x_56, 0); +lean_inc(x_57); +x_58 = lean_unbox(x_57); +lean_dec(x_57); +if (x_58 == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +lean_dec(x_52); +x_59 = lean_ctor_get(x_56, 1); +lean_inc(x_59); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_60 = x_56; +} else { + lean_dec_ref(x_56); + x_60 = lean_box(0); +} +x_61 = lean_box(0); +if (lean_is_scalar(x_60)) { + x_62 = lean_alloc_ctor(0, 2, 0); +} else { + x_62 = x_60; +} +lean_ctor_set(x_62, 0, x_61); +lean_ctor_set(x_62, 1, x_59); +return x_62; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_63 = lean_ctor_get(x_56, 1); +lean_inc(x_63); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_64 = x_56; +} else { + lean_dec_ref(x_56); + x_64 = lean_box(0); +} +x_65 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_65, 0, x_52); +if (lean_is_scalar(x_64)) { + x_66 = lean_alloc_ctor(0, 2, 0); +} else { + x_66 = x_64; +} +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_63); +return x_66; +} +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +lean_dec(x_52); +x_67 = lean_ctor_get(x_56, 0); +lean_inc(x_67); +x_68 = lean_ctor_get(x_56, 1); +lean_inc(x_68); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_69 = x_56; +} else { + lean_dec_ref(x_56); + x_69 = lean_box(0); +} +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(1, 2, 0); +} else { + x_70 = x_69; +} +lean_ctor_set(x_70, 0, x_67); +lean_ctor_set(x_70, 1, x_68); +return x_70; +} +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +lean_dec(x_52); +lean_dec(x_10); +lean_dec(x_3); +x_71 = lean_ctor_get(x_53, 0); +lean_inc(x_71); +x_72 = lean_ctor_get(x_53, 1); +lean_inc(x_72); +if (lean_is_exclusive(x_53)) { + lean_ctor_release(x_53, 0); + lean_ctor_release(x_53, 1); + x_73 = x_53; +} else { + lean_dec_ref(x_53); + x_73 = lean_box(0); +} +if (lean_is_scalar(x_73)) { + x_74 = lean_alloc_ctor(1, 2, 0); +} else { + x_74 = x_73; +} +lean_ctor_set(x_74, 0, x_71); +lean_ctor_set(x_74, 1, x_72); +return x_74; +} +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_10); +lean_dec(x_3); +x_75 = !lean_is_exclusive(x_19); +if (x_75 == 0) +{ +return x_19; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_19, 0); +x_77 = lean_ctor_get(x_19, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_19); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; uint8_t x_88; +x_79 = lean_unsigned_to_nat(0u); +x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_79); +x_81 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_80); +x_82 = lean_mk_array(x_80, x_81); +x_83 = lean_unsigned_to_nat(1u); +x_84 = lean_nat_sub(x_80, x_83); +lean_dec(x_80); +lean_inc(x_10); +x_85 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_10, x_82, x_84); +x_86 = lean_ctor_get(x_1, 2); +lean_inc(x_86); +lean_dec(x_1); +x_87 = lean_array_get_size(x_85); +x_88 = lean_nat_dec_le(x_87, x_87); +if (x_88 == 0) +{ +uint8_t x_89; +lean_inc(x_86); +x_89 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__8(x_10, x_85, x_87, x_86); +lean_dec(x_87); +lean_dec(x_85); +if (x_89 == 0) +{ +lean_object* x_90; lean_object* x_91; +lean_free_object(x_8); +x_90 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_91 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_90, x_10, x_86, x_3, x_11); +lean_dec(x_86); +if (lean_obj_tag(x_91) == 0) +{ +lean_object* x_92; +x_92 = lean_ctor_get(x_91, 0); +lean_inc(x_92); +if (lean_obj_tag(x_92) == 0) +{ +uint8_t x_93; +lean_dec(x_10); +lean_dec(x_3); +x_93 = !lean_is_exclusive(x_91); +if (x_93 == 0) +{ +lean_object* x_94; +x_94 = lean_ctor_get(x_91, 0); +lean_dec(x_94); +return x_91; +} +else +{ +lean_object* x_95; lean_object* x_96; +x_95 = lean_ctor_get(x_91, 1); +lean_inc(x_95); +lean_dec(x_91); +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_92); +lean_ctor_set(x_96, 1, x_95); +return x_96; +} +} +else +{ +lean_object* x_97; uint8_t x_98; +x_97 = lean_ctor_get(x_91, 1); +lean_inc(x_97); +lean_dec(x_91); +x_98 = !lean_is_exclusive(x_92); +if (x_98 == 0) +{ +lean_object* x_99; lean_object* x_100; +x_99 = lean_ctor_get(x_92, 0); +lean_inc(x_3); +lean_inc(x_99); +x_100 = l_Lean_Meta_inferType(x_99, x_3, x_97); +if (lean_obj_tag(x_100) == 0) +{ +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); +lean_inc(x_101); +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = l_Lean_Meta_isExprDefEqAux(x_10, x_101, x_3, x_102); +if (lean_obj_tag(x_103) == 0) +{ +lean_object* x_104; uint8_t x_105; +x_104 = lean_ctor_get(x_103, 0); +lean_inc(x_104); +x_105 = lean_unbox(x_104); +lean_dec(x_104); +if (x_105 == 0) +{ +uint8_t x_106; +lean_free_object(x_92); +lean_dec(x_99); +x_106 = !lean_is_exclusive(x_103); +if (x_106 == 0) +{ +lean_object* x_107; lean_object* x_108; +x_107 = lean_ctor_get(x_103, 0); +lean_dec(x_107); +x_108 = lean_box(0); +lean_ctor_set(x_103, 0, x_108); +return x_103; +} +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_103, 1); +lean_inc(x_109); +lean_dec(x_103); +x_110 = lean_box(0); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_109); +return x_111; +} +} +else +{ +uint8_t x_112; +x_112 = !lean_is_exclusive(x_103); +if (x_112 == 0) +{ +lean_object* x_113; +x_113 = lean_ctor_get(x_103, 0); +lean_dec(x_113); +lean_ctor_set(x_103, 0, x_92); +return x_103; +} +else +{ +lean_object* x_114; lean_object* x_115; +x_114 = lean_ctor_get(x_103, 1); +lean_inc(x_114); +lean_dec(x_103); +x_115 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_115, 0, x_92); +lean_ctor_set(x_115, 1, x_114); +return x_115; +} +} +} +else +{ +uint8_t x_116; +lean_free_object(x_92); +lean_dec(x_99); +x_116 = !lean_is_exclusive(x_103); +if (x_116 == 0) +{ +return x_103; +} +else +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_103, 0); +x_118 = lean_ctor_get(x_103, 1); +lean_inc(x_118); +lean_inc(x_117); +lean_dec(x_103); +x_119 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_119, 0, x_117); +lean_ctor_set(x_119, 1, x_118); +return x_119; +} +} +} +else +{ +uint8_t x_120; +lean_free_object(x_92); +lean_dec(x_99); +lean_dec(x_10); +lean_dec(x_3); +x_120 = !lean_is_exclusive(x_100); +if (x_120 == 0) +{ +return x_100; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; +x_121 = lean_ctor_get(x_100, 0); +x_122 = lean_ctor_get(x_100, 1); +lean_inc(x_122); +lean_inc(x_121); +lean_dec(x_100); +x_123 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_123, 0, x_121); +lean_ctor_set(x_123, 1, x_122); +return x_123; +} +} +} +else +{ +lean_object* x_124; lean_object* x_125; +x_124 = lean_ctor_get(x_92, 0); +lean_inc(x_124); +lean_dec(x_92); +lean_inc(x_3); +lean_inc(x_124); +x_125 = l_Lean_Meta_inferType(x_124, x_3, x_97); +if (lean_obj_tag(x_125) == 0) +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_125, 1); +lean_inc(x_127); +lean_dec(x_125); +x_128 = l_Lean_Meta_isExprDefEqAux(x_10, x_126, x_3, x_127); +if (lean_obj_tag(x_128) == 0) +{ +lean_object* x_129; uint8_t x_130; +x_129 = lean_ctor_get(x_128, 0); +lean_inc(x_129); +x_130 = lean_unbox(x_129); +lean_dec(x_129); +if (x_130 == 0) +{ +lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +lean_dec(x_124); +x_131 = lean_ctor_get(x_128, 1); +lean_inc(x_131); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_132 = x_128; +} else { + lean_dec_ref(x_128); + x_132 = lean_box(0); +} +x_133 = lean_box(0); +if (lean_is_scalar(x_132)) { + x_134 = lean_alloc_ctor(0, 2, 0); +} else { + x_134 = x_132; +} +lean_ctor_set(x_134, 0, x_133); +lean_ctor_set(x_134, 1, x_131); +return x_134; +} +else +{ +lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_135 = lean_ctor_get(x_128, 1); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_137, 0, x_124); +if (lean_is_scalar(x_136)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_136; +} +lean_ctor_set(x_138, 0, x_137); +lean_ctor_set(x_138, 1, x_135); +return x_138; +} +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; +lean_dec(x_124); +x_139 = lean_ctor_get(x_128, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_128, 1); +lean_inc(x_140); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_141 = x_128; +} else { + lean_dec_ref(x_128); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(1, 2, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_139); +lean_ctor_set(x_142, 1, x_140); +return x_142; +} +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; +lean_dec(x_124); +lean_dec(x_10); +lean_dec(x_3); +x_143 = lean_ctor_get(x_125, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_125, 1); +lean_inc(x_144); +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_145 = x_125; +} else { + lean_dec_ref(x_125); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(1, 2, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_143); +lean_ctor_set(x_146, 1, x_144); +return x_146; +} +} +} +} +else +{ +uint8_t x_147; +lean_dec(x_10); +lean_dec(x_3); +x_147 = !lean_is_exclusive(x_91); +if (x_147 == 0) +{ +return x_91; +} +else +{ +lean_object* x_148; lean_object* x_149; lean_object* x_150; +x_148 = lean_ctor_get(x_91, 0); +x_149 = lean_ctor_get(x_91, 1); +lean_inc(x_149); +lean_inc(x_148); +lean_dec(x_91); +x_150 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_150, 0, x_148); +lean_ctor_set(x_150, 1, x_149); +return x_150; +} +} +} +else +{ +lean_object* x_151; +lean_dec(x_86); +lean_dec(x_10); +lean_dec(x_3); +x_151 = lean_box(0); +lean_ctor_set(x_8, 0, x_151); +return x_8; +} +} +else +{ +uint8_t x_152; +lean_inc(x_86); +x_152 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__9(x_10, lean_box(0), x_85, x_87, x_86); +lean_dec(x_87); +lean_dec(x_85); +if (x_152 == 0) +{ +lean_object* x_153; lean_object* x_154; +lean_free_object(x_8); +x_153 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_154 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_153, x_10, x_86, x_3, x_11); +lean_dec(x_86); +if (lean_obj_tag(x_154) == 0) +{ +lean_object* x_155; +x_155 = lean_ctor_get(x_154, 0); +lean_inc(x_155); +if (lean_obj_tag(x_155) == 0) +{ +uint8_t x_156; +lean_dec(x_10); +lean_dec(x_3); +x_156 = !lean_is_exclusive(x_154); +if (x_156 == 0) +{ +lean_object* x_157; +x_157 = lean_ctor_get(x_154, 0); +lean_dec(x_157); +return x_154; +} +else +{ +lean_object* x_158; lean_object* x_159; +x_158 = lean_ctor_get(x_154, 1); +lean_inc(x_158); +lean_dec(x_154); +x_159 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_159, 0, x_155); +lean_ctor_set(x_159, 1, x_158); +return x_159; +} +} +else +{ +lean_object* x_160; uint8_t x_161; +x_160 = lean_ctor_get(x_154, 1); +lean_inc(x_160); +lean_dec(x_154); +x_161 = !lean_is_exclusive(x_155); +if (x_161 == 0) +{ +lean_object* x_162; lean_object* x_163; +x_162 = lean_ctor_get(x_155, 0); +lean_inc(x_3); +lean_inc(x_162); +x_163 = l_Lean_Meta_inferType(x_162, x_3, x_160); +if (lean_obj_tag(x_163) == 0) +{ +lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_164 = lean_ctor_get(x_163, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_163, 1); +lean_inc(x_165); +lean_dec(x_163); +x_166 = l_Lean_Meta_isExprDefEqAux(x_10, x_164, x_3, x_165); +if (lean_obj_tag(x_166) == 0) +{ +lean_object* x_167; uint8_t x_168; +x_167 = lean_ctor_get(x_166, 0); +lean_inc(x_167); +x_168 = lean_unbox(x_167); +lean_dec(x_167); +if (x_168 == 0) +{ +uint8_t x_169; +lean_free_object(x_155); +lean_dec(x_162); +x_169 = !lean_is_exclusive(x_166); +if (x_169 == 0) +{ +lean_object* x_170; lean_object* x_171; +x_170 = lean_ctor_get(x_166, 0); +lean_dec(x_170); +x_171 = lean_box(0); +lean_ctor_set(x_166, 0, x_171); +return x_166; +} +else +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_166, 1); +lean_inc(x_172); +lean_dec(x_166); +x_173 = lean_box(0); +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_173); +lean_ctor_set(x_174, 1, x_172); +return x_174; +} +} +else +{ +uint8_t x_175; +x_175 = !lean_is_exclusive(x_166); +if (x_175 == 0) +{ +lean_object* x_176; +x_176 = lean_ctor_get(x_166, 0); +lean_dec(x_176); +lean_ctor_set(x_166, 0, x_155); +return x_166; +} +else +{ +lean_object* x_177; lean_object* x_178; +x_177 = lean_ctor_get(x_166, 1); +lean_inc(x_177); +lean_dec(x_166); +x_178 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_178, 0, x_155); +lean_ctor_set(x_178, 1, x_177); +return x_178; +} +} +} +else +{ +uint8_t x_179; +lean_free_object(x_155); +lean_dec(x_162); +x_179 = !lean_is_exclusive(x_166); +if (x_179 == 0) +{ +return x_166; +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; +x_180 = lean_ctor_get(x_166, 0); +x_181 = lean_ctor_get(x_166, 1); +lean_inc(x_181); +lean_inc(x_180); +lean_dec(x_166); +x_182 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_182, 0, x_180); +lean_ctor_set(x_182, 1, x_181); +return x_182; +} +} +} +else +{ +uint8_t x_183; +lean_free_object(x_155); +lean_dec(x_162); +lean_dec(x_10); +lean_dec(x_3); +x_183 = !lean_is_exclusive(x_163); +if (x_183 == 0) +{ +return x_163; +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_184 = lean_ctor_get(x_163, 0); +x_185 = lean_ctor_get(x_163, 1); +lean_inc(x_185); +lean_inc(x_184); +lean_dec(x_163); +x_186 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_186, 0, x_184); +lean_ctor_set(x_186, 1, x_185); +return x_186; +} +} +} +else +{ +lean_object* x_187; lean_object* x_188; +x_187 = lean_ctor_get(x_155, 0); +lean_inc(x_187); +lean_dec(x_155); +lean_inc(x_3); +lean_inc(x_187); +x_188 = l_Lean_Meta_inferType(x_187, x_3, x_160); +if (lean_obj_tag(x_188) == 0) +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_189 = lean_ctor_get(x_188, 0); +lean_inc(x_189); +x_190 = lean_ctor_get(x_188, 1); +lean_inc(x_190); +lean_dec(x_188); +x_191 = l_Lean_Meta_isExprDefEqAux(x_10, x_189, x_3, x_190); +if (lean_obj_tag(x_191) == 0) +{ +lean_object* x_192; uint8_t x_193; +x_192 = lean_ctor_get(x_191, 0); +lean_inc(x_192); +x_193 = lean_unbox(x_192); +lean_dec(x_192); +if (x_193 == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; +lean_dec(x_187); +x_194 = lean_ctor_get(x_191, 1); +lean_inc(x_194); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_195 = x_191; +} else { + lean_dec_ref(x_191); + x_195 = lean_box(0); +} +x_196 = lean_box(0); +if (lean_is_scalar(x_195)) { + x_197 = lean_alloc_ctor(0, 2, 0); +} else { + x_197 = x_195; +} +lean_ctor_set(x_197, 0, x_196); +lean_ctor_set(x_197, 1, x_194); +return x_197; +} +else +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; +x_198 = lean_ctor_get(x_191, 1); +lean_inc(x_198); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_199 = x_191; +} else { + lean_dec_ref(x_191); + x_199 = lean_box(0); +} +x_200 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_200, 0, x_187); +if (lean_is_scalar(x_199)) { + x_201 = lean_alloc_ctor(0, 2, 0); +} else { + x_201 = x_199; +} +lean_ctor_set(x_201, 0, x_200); +lean_ctor_set(x_201, 1, x_198); +return x_201; +} +} +else +{ +lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; +lean_dec(x_187); +x_202 = lean_ctor_get(x_191, 0); +lean_inc(x_202); +x_203 = lean_ctor_get(x_191, 1); +lean_inc(x_203); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_204 = x_191; +} else { + lean_dec_ref(x_191); + x_204 = lean_box(0); +} +if (lean_is_scalar(x_204)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_204; +} +lean_ctor_set(x_205, 0, x_202); +lean_ctor_set(x_205, 1, x_203); +return x_205; +} +} +else +{ +lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +lean_dec(x_187); +lean_dec(x_10); +lean_dec(x_3); +x_206 = lean_ctor_get(x_188, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_188, 1); +lean_inc(x_207); +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + x_208 = x_188; +} else { + lean_dec_ref(x_188); + x_208 = lean_box(0); +} +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(1, 2, 0); +} else { + x_209 = x_208; +} +lean_ctor_set(x_209, 0, x_206); +lean_ctor_set(x_209, 1, x_207); +return x_209; +} +} +} +} +else +{ +uint8_t x_210; +lean_dec(x_10); +lean_dec(x_3); +x_210 = !lean_is_exclusive(x_154); +if (x_210 == 0) +{ +return x_154; +} +else +{ +lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_211 = lean_ctor_get(x_154, 0); +x_212 = lean_ctor_get(x_154, 1); +lean_inc(x_212); +lean_inc(x_211); +lean_dec(x_154); +x_213 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_213, 0, x_211); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +} +} +else +{ +lean_object* x_214; +lean_dec(x_86); +lean_dec(x_10); +lean_dec(x_3); +x_214 = lean_box(0); +lean_ctor_set(x_8, 0, x_214); +return x_8; +} +} +} +} +} +else +{ +lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; uint8_t x_219; +x_215 = lean_ctor_get(x_8, 0); +x_216 = lean_ctor_get(x_8, 1); +lean_inc(x_216); +lean_inc(x_215); +lean_dec(x_8); +x_217 = l_Lean_Expr_getAppFn___main(x_215); +x_218 = l_Lean_RecursorVal_getInduct(x_1); +x_219 = l_Lean_Expr_isConstOf(x_217, x_218); +lean_dec(x_218); +lean_dec(x_217); +if (x_219 == 0) +{ +lean_object* x_220; lean_object* x_221; +lean_dec(x_215); +lean_dec(x_3); +lean_dec(x_1); +x_220 = lean_box(0); +x_221 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_221, 0, x_220); +lean_ctor_set(x_221, 1, x_216); +return x_221; +} +else +{ +uint8_t x_222; +x_222 = l_Lean_Expr_hasExprMVar(x_215); +if (x_222 == 0) +{ +lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_223 = lean_ctor_get(x_1, 2); +lean_inc(x_223); +lean_dec(x_1); +x_224 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_225 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_224, x_215, x_223, x_3, x_216); +lean_dec(x_223); +if (lean_obj_tag(x_225) == 0) +{ +lean_object* x_226; +x_226 = lean_ctor_get(x_225, 0); +lean_inc(x_226); +if (lean_obj_tag(x_226) == 0) +{ +lean_object* x_227; lean_object* x_228; lean_object* x_229; +lean_dec(x_215); +lean_dec(x_3); +x_227 = lean_ctor_get(x_225, 1); +lean_inc(x_227); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + x_228 = x_225; +} else { + lean_dec_ref(x_225); + x_228 = lean_box(0); +} +if (lean_is_scalar(x_228)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_228; +} +lean_ctor_set(x_229, 0, x_226); +lean_ctor_set(x_229, 1, x_227); +return x_229; +} +else +{ +lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_230 = lean_ctor_get(x_225, 1); +lean_inc(x_230); +lean_dec(x_225); +x_231 = lean_ctor_get(x_226, 0); +lean_inc(x_231); +if (lean_is_exclusive(x_226)) { + lean_ctor_release(x_226, 0); + x_232 = x_226; +} else { + lean_dec_ref(x_226); + x_232 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_231); +x_233 = l_Lean_Meta_inferType(x_231, x_3, x_230); +if (lean_obj_tag(x_233) == 0) +{ +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = l_Lean_Meta_isExprDefEqAux(x_215, x_234, x_3, x_235); +if (lean_obj_tag(x_236) == 0) +{ +lean_object* x_237; uint8_t x_238; +x_237 = lean_ctor_get(x_236, 0); +lean_inc(x_237); +x_238 = lean_unbox(x_237); +lean_dec(x_237); +if (x_238 == 0) +{ +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; +lean_dec(x_232); +lean_dec(x_231); +x_239 = lean_ctor_get(x_236, 1); +lean_inc(x_239); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_240 = x_236; +} else { + lean_dec_ref(x_236); + x_240 = lean_box(0); +} +x_241 = lean_box(0); +if (lean_is_scalar(x_240)) { + x_242 = lean_alloc_ctor(0, 2, 0); +} else { + x_242 = x_240; +} +lean_ctor_set(x_242, 0, x_241); +lean_ctor_set(x_242, 1, x_239); +return x_242; +} +else +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_243 = lean_ctor_get(x_236, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_244 = x_236; +} else { + lean_dec_ref(x_236); + x_244 = lean_box(0); +} +if (lean_is_scalar(x_232)) { + x_245 = lean_alloc_ctor(1, 1, 0); +} else { + x_245 = x_232; +} +lean_ctor_set(x_245, 0, x_231); +if (lean_is_scalar(x_244)) { + x_246 = lean_alloc_ctor(0, 2, 0); +} else { + x_246 = x_244; +} +lean_ctor_set(x_246, 0, x_245); +lean_ctor_set(x_246, 1, x_243); +return x_246; +} +} +else +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; +lean_dec(x_232); +lean_dec(x_231); +x_247 = lean_ctor_get(x_236, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_236, 1); +lean_inc(x_248); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_249 = x_236; +} else { + lean_dec_ref(x_236); + x_249 = lean_box(0); +} +if (lean_is_scalar(x_249)) { + x_250 = lean_alloc_ctor(1, 2, 0); +} else { + x_250 = x_249; +} +lean_ctor_set(x_250, 0, x_247); +lean_ctor_set(x_250, 1, x_248); +return x_250; +} +} +else +{ +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; +lean_dec(x_232); +lean_dec(x_231); +lean_dec(x_215); +lean_dec(x_3); +x_251 = lean_ctor_get(x_233, 0); +lean_inc(x_251); +x_252 = lean_ctor_get(x_233, 1); +lean_inc(x_252); +if (lean_is_exclusive(x_233)) { + lean_ctor_release(x_233, 0); + lean_ctor_release(x_233, 1); + x_253 = x_233; +} else { + lean_dec_ref(x_233); + x_253 = lean_box(0); +} +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(1, 2, 0); +} else { + x_254 = x_253; +} +lean_ctor_set(x_254, 0, x_251); +lean_ctor_set(x_254, 1, x_252); +return x_254; +} +} +} +else +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +lean_dec(x_215); +lean_dec(x_3); +x_255 = lean_ctor_get(x_225, 0); +lean_inc(x_255); +x_256 = lean_ctor_get(x_225, 1); +lean_inc(x_256); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + x_257 = x_225; +} else { + lean_dec_ref(x_225); + x_257 = lean_box(0); +} +if (lean_is_scalar(x_257)) { + x_258 = lean_alloc_ctor(1, 2, 0); +} else { + x_258 = x_257; +} +lean_ctor_set(x_258, 0, x_255); +lean_ctor_set(x_258, 1, x_256); +return x_258; +} +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; uint8_t x_268; +x_259 = lean_unsigned_to_nat(0u); +x_260 = l_Lean_Expr_getAppNumArgsAux___main(x_215, x_259); +x_261 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_260); +x_262 = lean_mk_array(x_260, x_261); +x_263 = lean_unsigned_to_nat(1u); +x_264 = lean_nat_sub(x_260, x_263); +lean_dec(x_260); +lean_inc(x_215); +x_265 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_215, x_262, x_264); +x_266 = lean_ctor_get(x_1, 2); +lean_inc(x_266); +lean_dec(x_1); +x_267 = lean_array_get_size(x_265); +x_268 = lean_nat_dec_le(x_267, x_267); +if (x_268 == 0) +{ +uint8_t x_269; +lean_inc(x_266); +x_269 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__8(x_215, x_265, x_267, x_266); +lean_dec(x_267); +lean_dec(x_265); +if (x_269 == 0) +{ +lean_object* x_270; lean_object* x_271; +x_270 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_271 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_270, x_215, x_266, x_3, x_216); +lean_dec(x_266); +if (lean_obj_tag(x_271) == 0) +{ +lean_object* x_272; +x_272 = lean_ctor_get(x_271, 0); +lean_inc(x_272); +if (lean_obj_tag(x_272) == 0) +{ +lean_object* x_273; lean_object* x_274; lean_object* x_275; +lean_dec(x_215); +lean_dec(x_3); +x_273 = lean_ctor_get(x_271, 1); +lean_inc(x_273); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + x_274 = x_271; +} else { + lean_dec_ref(x_271); + x_274 = lean_box(0); +} +if (lean_is_scalar(x_274)) { + x_275 = lean_alloc_ctor(0, 2, 0); +} else { + x_275 = x_274; +} +lean_ctor_set(x_275, 0, x_272); +lean_ctor_set(x_275, 1, x_273); +return x_275; +} +else +{ +lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; +x_276 = lean_ctor_get(x_271, 1); +lean_inc(x_276); +lean_dec(x_271); +x_277 = lean_ctor_get(x_272, 0); +lean_inc(x_277); +if (lean_is_exclusive(x_272)) { + lean_ctor_release(x_272, 0); + x_278 = x_272; +} else { + lean_dec_ref(x_272); + x_278 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_277); +x_279 = l_Lean_Meta_inferType(x_277, x_3, x_276); +if (lean_obj_tag(x_279) == 0) +{ +lean_object* x_280; lean_object* x_281; lean_object* x_282; +x_280 = lean_ctor_get(x_279, 0); +lean_inc(x_280); +x_281 = lean_ctor_get(x_279, 1); +lean_inc(x_281); +lean_dec(x_279); +x_282 = l_Lean_Meta_isExprDefEqAux(x_215, x_280, x_3, x_281); +if (lean_obj_tag(x_282) == 0) +{ +lean_object* x_283; uint8_t x_284; +x_283 = lean_ctor_get(x_282, 0); +lean_inc(x_283); +x_284 = lean_unbox(x_283); +lean_dec(x_283); +if (x_284 == 0) +{ +lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; +lean_dec(x_278); +lean_dec(x_277); +x_285 = lean_ctor_get(x_282, 1); +lean_inc(x_285); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_286 = x_282; +} else { + lean_dec_ref(x_282); + x_286 = lean_box(0); +} +x_287 = lean_box(0); +if (lean_is_scalar(x_286)) { + x_288 = lean_alloc_ctor(0, 2, 0); +} else { + x_288 = x_286; +} +lean_ctor_set(x_288, 0, x_287); +lean_ctor_set(x_288, 1, x_285); +return x_288; +} +else +{ +lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; +x_289 = lean_ctor_get(x_282, 1); +lean_inc(x_289); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_290 = x_282; +} else { + lean_dec_ref(x_282); + x_290 = lean_box(0); +} +if (lean_is_scalar(x_278)) { + x_291 = lean_alloc_ctor(1, 1, 0); +} else { + x_291 = x_278; +} +lean_ctor_set(x_291, 0, x_277); +if (lean_is_scalar(x_290)) { + x_292 = lean_alloc_ctor(0, 2, 0); +} else { + x_292 = x_290; +} +lean_ctor_set(x_292, 0, x_291); +lean_ctor_set(x_292, 1, x_289); +return x_292; +} +} +else +{ +lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +lean_dec(x_278); +lean_dec(x_277); +x_293 = lean_ctor_get(x_282, 0); +lean_inc(x_293); +x_294 = lean_ctor_get(x_282, 1); +lean_inc(x_294); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_295 = x_282; +} else { + lean_dec_ref(x_282); + x_295 = lean_box(0); +} +if (lean_is_scalar(x_295)) { + x_296 = lean_alloc_ctor(1, 2, 0); +} else { + x_296 = x_295; +} +lean_ctor_set(x_296, 0, x_293); +lean_ctor_set(x_296, 1, x_294); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; +lean_dec(x_278); +lean_dec(x_277); +lean_dec(x_215); +lean_dec(x_3); +x_297 = lean_ctor_get(x_279, 0); +lean_inc(x_297); +x_298 = lean_ctor_get(x_279, 1); +lean_inc(x_298); +if (lean_is_exclusive(x_279)) { + lean_ctor_release(x_279, 0); + lean_ctor_release(x_279, 1); + x_299 = x_279; +} else { + lean_dec_ref(x_279); + x_299 = lean_box(0); +} +if (lean_is_scalar(x_299)) { + x_300 = lean_alloc_ctor(1, 2, 0); +} else { + x_300 = x_299; +} +lean_ctor_set(x_300, 0, x_297); +lean_ctor_set(x_300, 1, x_298); +return x_300; +} +} +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; +lean_dec(x_215); +lean_dec(x_3); +x_301 = lean_ctor_get(x_271, 0); +lean_inc(x_301); +x_302 = lean_ctor_get(x_271, 1); +lean_inc(x_302); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + x_303 = x_271; +} else { + lean_dec_ref(x_271); + x_303 = lean_box(0); +} +if (lean_is_scalar(x_303)) { + x_304 = lean_alloc_ctor(1, 2, 0); +} else { + x_304 = x_303; +} +lean_ctor_set(x_304, 0, x_301); +lean_ctor_set(x_304, 1, x_302); +return x_304; +} +} +else +{ +lean_object* x_305; lean_object* x_306; +lean_dec(x_266); +lean_dec(x_215); +lean_dec(x_3); +x_305 = lean_box(0); +x_306 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_306, 0, x_305); +lean_ctor_set(x_306, 1, x_216); +return x_306; +} +} +else +{ +uint8_t x_307; +lean_inc(x_266); +x_307 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__9(x_215, lean_box(0), x_265, x_267, x_266); +lean_dec(x_267); +lean_dec(x_265); +if (x_307 == 0) +{ +lean_object* x_308; lean_object* x_309; +x_308 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_309 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_308, x_215, x_266, x_3, x_216); +lean_dec(x_266); +if (lean_obj_tag(x_309) == 0) +{ +lean_object* x_310; +x_310 = lean_ctor_get(x_309, 0); +lean_inc(x_310); +if (lean_obj_tag(x_310) == 0) +{ +lean_object* x_311; lean_object* x_312; lean_object* x_313; +lean_dec(x_215); +lean_dec(x_3); +x_311 = lean_ctor_get(x_309, 1); +lean_inc(x_311); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_312 = x_309; +} else { + lean_dec_ref(x_309); + x_312 = lean_box(0); +} +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 2, 0); +} else { + x_313 = x_312; +} +lean_ctor_set(x_313, 0, x_310); +lean_ctor_set(x_313, 1, x_311); +return x_313; +} +else +{ +lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_314 = lean_ctor_get(x_309, 1); +lean_inc(x_314); +lean_dec(x_309); +x_315 = lean_ctor_get(x_310, 0); +lean_inc(x_315); +if (lean_is_exclusive(x_310)) { + lean_ctor_release(x_310, 0); + x_316 = x_310; +} else { + lean_dec_ref(x_310); + x_316 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_315); +x_317 = l_Lean_Meta_inferType(x_315, x_3, x_314); +if (lean_obj_tag(x_317) == 0) +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; +x_318 = lean_ctor_get(x_317, 0); +lean_inc(x_318); +x_319 = lean_ctor_get(x_317, 1); +lean_inc(x_319); +lean_dec(x_317); +x_320 = l_Lean_Meta_isExprDefEqAux(x_215, x_318, x_3, x_319); +if (lean_obj_tag(x_320) == 0) +{ +lean_object* x_321; uint8_t x_322; +x_321 = lean_ctor_get(x_320, 0); +lean_inc(x_321); +x_322 = lean_unbox(x_321); +lean_dec(x_321); +if (x_322 == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; +lean_dec(x_316); +lean_dec(x_315); +x_323 = lean_ctor_get(x_320, 1); +lean_inc(x_323); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_324 = x_320; +} else { + lean_dec_ref(x_320); + x_324 = lean_box(0); +} +x_325 = lean_box(0); +if (lean_is_scalar(x_324)) { + x_326 = lean_alloc_ctor(0, 2, 0); +} else { + x_326 = x_324; +} +lean_ctor_set(x_326, 0, x_325); +lean_ctor_set(x_326, 1, x_323); +return x_326; +} +else +{ +lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_327 = lean_ctor_get(x_320, 1); +lean_inc(x_327); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_328 = x_320; +} else { + lean_dec_ref(x_320); + x_328 = lean_box(0); +} +if (lean_is_scalar(x_316)) { + x_329 = lean_alloc_ctor(1, 1, 0); +} else { + x_329 = x_316; +} +lean_ctor_set(x_329, 0, x_315); +if (lean_is_scalar(x_328)) { + x_330 = lean_alloc_ctor(0, 2, 0); +} else { + x_330 = x_328; +} +lean_ctor_set(x_330, 0, x_329); +lean_ctor_set(x_330, 1, x_327); +return x_330; +} +} +else +{ +lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; +lean_dec(x_316); +lean_dec(x_315); +x_331 = lean_ctor_get(x_320, 0); +lean_inc(x_331); +x_332 = lean_ctor_get(x_320, 1); +lean_inc(x_332); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_333 = x_320; +} else { + lean_dec_ref(x_320); + x_333 = lean_box(0); +} +if (lean_is_scalar(x_333)) { + x_334 = lean_alloc_ctor(1, 2, 0); +} else { + x_334 = x_333; +} +lean_ctor_set(x_334, 0, x_331); +lean_ctor_set(x_334, 1, x_332); +return x_334; +} +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; +lean_dec(x_316); +lean_dec(x_315); +lean_dec(x_215); +lean_dec(x_3); +x_335 = lean_ctor_get(x_317, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_317, 1); +lean_inc(x_336); +if (lean_is_exclusive(x_317)) { + lean_ctor_release(x_317, 0); + lean_ctor_release(x_317, 1); + x_337 = x_317; +} else { + lean_dec_ref(x_317); + x_337 = lean_box(0); +} +if (lean_is_scalar(x_337)) { + x_338 = lean_alloc_ctor(1, 2, 0); +} else { + x_338 = x_337; +} +lean_ctor_set(x_338, 0, x_335); +lean_ctor_set(x_338, 1, x_336); +return x_338; +} +} +} +else +{ +lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; +lean_dec(x_215); +lean_dec(x_3); +x_339 = lean_ctor_get(x_309, 0); +lean_inc(x_339); +x_340 = lean_ctor_get(x_309, 1); +lean_inc(x_340); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_341 = x_309; +} else { + lean_dec_ref(x_309); + x_341 = lean_box(0); +} +if (lean_is_scalar(x_341)) { + x_342 = lean_alloc_ctor(1, 2, 0); +} else { + x_342 = x_341; +} +lean_ctor_set(x_342, 0, x_339); +lean_ctor_set(x_342, 1, x_340); +return x_342; +} +} +else +{ +lean_object* x_343; lean_object* x_344; +lean_dec(x_266); +lean_dec(x_215); +lean_dec(x_3); +x_343 = lean_box(0); +x_344 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_344, 0, x_343); +lean_ctor_set(x_344, 1, x_216); +return x_344; +} +} +} +} +} +} +else +{ +uint8_t x_345; +lean_dec(x_3); +lean_dec(x_1); +x_345 = !lean_is_exclusive(x_8); +if (x_345 == 0) +{ +return x_8; +} +else +{ +lean_object* x_346; lean_object* x_347; lean_object* x_348; +x_346 = lean_ctor_get(x_8, 0); +x_347 = lean_ctor_get(x_8, 1); +lean_inc(x_347); +lean_inc(x_346); +lean_dec(x_8); +x_348 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_348, 0, x_346); +lean_ctor_set(x_348, 1, x_347); +return x_348; +} +} +} +else +{ +uint8_t x_349; +lean_dec(x_3); +lean_dec(x_1); +x_349 = !lean_is_exclusive(x_5); +if (x_349 == 0) +{ +return x_5; +} +else +{ +lean_object* x_350; lean_object* x_351; lean_object* x_352; +x_350 = lean_ctor_get(x_5, 0); +x_351 = lean_ctor_get(x_5, 1); +lean_inc(x_351); +lean_inc(x_350); +lean_dec(x_5); +x_352 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_352, 0, x_350); +lean_ctor_set(x_352, 1, x_351); +return x_352; +} +} +} +} +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__4(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_9 = l_Lean_RecursorVal_getMajorIdx(x_4); +x_10 = lean_array_get_size(x_6); +x_11 = lean_nat_dec_lt(x_9, x_10); +if (x_11 == 0) +{ +uint8_t x_12; +lean_dec(x_10); lean_dec(x_9); lean_dec(x_7); lean_dec(x_5); +lean_dec(x_4); +x_12 = lean_expr_eqv(x_2, x_3); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_8); +return x_14; +} +else +{ +lean_object* x_15; +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_1); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_array_fget(x_6, x_9); +lean_inc(x_7); +x_17 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_16, x_7, x_8); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_62; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + lean_ctor_release(x_17, 1); + x_20 = x_17; +} else { + lean_dec_ref(x_17); + x_20 = lean_box(0); +} +x_62 = lean_ctor_get_uint8(x_4, sizeof(void*)*7); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; +lean_dec(x_20); +x_63 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_18); +lean_dec(x_18); +lean_inc(x_4); +x_64 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_63); +if (lean_obj_tag(x_64) == 0) +{ +uint8_t x_65; +lean_dec(x_63); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_65 = lean_expr_eqv(x_2, x_3); +if (x_65 == 0) +{ +lean_object* x_66; lean_object* x_67; +x_66 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_19); +return x_67; +} +else +{ +lean_object* x_68; +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_1); +lean_ctor_set(x_68, 1, x_19); +return x_68; +} +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; uint8_t x_81; +x_69 = lean_ctor_get(x_64, 0); +lean_inc(x_69); +lean_dec(x_64); +x_70 = lean_unsigned_to_nat(0u); +x_71 = l_Lean_Expr_getAppNumArgsAux___main(x_63, x_70); +x_72 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_71); +x_73 = lean_mk_array(x_71, x_72); +x_74 = lean_unsigned_to_nat(1u); +x_75 = lean_nat_sub(x_71, x_74); +lean_dec(x_71); +x_76 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_63, x_73, x_75); +x_77 = l_List_lengthAux___main___rarg(x_5, x_70); +x_78 = lean_ctor_get(x_4, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_78, 1); +lean_inc(x_79); +lean_dec(x_78); +x_80 = l_List_lengthAux___main___rarg(x_79, x_70); +x_81 = lean_nat_dec_eq(x_77, x_80); +lean_dec(x_80); +lean_dec(x_77); +if (x_81 == 0) +{ +uint8_t x_82; +lean_dec(x_79); +lean_dec(x_76); +lean_dec(x_69); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_82 = lean_expr_eqv(x_2, x_3); +if (x_82 == 0) +{ +lean_object* x_83; lean_object* x_84; +x_83 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_84 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_19); +return x_84; +} +else +{ +lean_object* x_85; +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_1); +lean_ctor_set(x_85, 1, x_19); +return x_85; +} +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +lean_dec(x_1); +x_86 = lean_ctor_get(x_69, 2); +lean_inc(x_86); +x_87 = lean_instantiate_lparams(x_86, x_79, x_5); +x_88 = lean_ctor_get(x_4, 2); +lean_inc(x_88); +x_89 = lean_ctor_get(x_4, 4); +lean_inc(x_89); +x_90 = lean_nat_add(x_88, x_89); +lean_dec(x_89); +lean_dec(x_88); +x_91 = lean_ctor_get(x_4, 5); +lean_inc(x_91); +lean_dec(x_4); +x_92 = lean_nat_add(x_90, x_91); +lean_dec(x_91); +lean_dec(x_90); +x_93 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_92, x_6, x_70, x_87); +lean_dec(x_92); +x_94 = lean_array_get_size(x_76); +x_95 = lean_ctor_get(x_69, 1); +lean_inc(x_95); +lean_dec(x_69); +x_96 = lean_nat_sub(x_94, x_95); +lean_dec(x_95); +x_97 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_94, x_76, x_96, x_93); +lean_dec(x_76); +lean_dec(x_94); +x_98 = lean_nat_add(x_9, x_74); +lean_dec(x_9); +x_99 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_98, x_97); +lean_dec(x_10); +x_100 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_99, x_7, x_19); +return x_100; +} +} +} +else +{ +lean_object* x_101; +lean_inc(x_7); +lean_inc(x_18); +lean_inc(x_4); +x_101 = l___private_Init_Lean_WHNF_5__toCtorWhenK___at_Lean_Meta_whnfImpl___main___spec__5(x_4, x_18, x_7, x_19); +if (lean_obj_tag(x_101) == 0) +{ +lean_object* x_102; +x_102 = lean_ctor_get(x_101, 0); +lean_inc(x_102); +if (lean_obj_tag(x_102) == 0) +{ +lean_object* x_103; +x_103 = lean_ctor_get(x_101, 1); +lean_inc(x_103); +lean_dec(x_101); +x_21 = x_18; +x_22 = x_103; +goto block_61; +} +else +{ +lean_object* x_104; lean_object* x_105; +lean_dec(x_18); +x_104 = lean_ctor_get(x_101, 1); +lean_inc(x_104); +lean_dec(x_101); +x_105 = lean_ctor_get(x_102, 0); +lean_inc(x_105); +lean_dec(x_102); +x_21 = x_105; +x_22 = x_104; +goto block_61; +} +} +else +{ +uint8_t x_106; +lean_dec(x_20); +lean_dec(x_18); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_106 = !lean_is_exclusive(x_101); +if (x_106 == 0) +{ +return x_101; +} +else +{ +lean_object* x_107; lean_object* x_108; lean_object* x_109; +x_107 = lean_ctor_get(x_101, 0); +x_108 = lean_ctor_get(x_101, 1); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_101); +x_109 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_109, 0, x_107); +lean_ctor_set(x_109, 1, x_108); +return x_109; +} +} +} +block_61: +{ +lean_object* x_23; lean_object* x_24; +x_23 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_21); +lean_dec(x_21); +lean_inc(x_4); +x_24 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_23); +if (lean_obj_tag(x_24) == 0) +{ +uint8_t x_25; +lean_dec(x_23); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_25 = lean_expr_eqv(x_2, x_3); +if (x_25 == 0) +{ +lean_object* x_26; lean_object* x_27; +x_26 = l_Lean_Expr_updateFn___main(x_1, x_3); +if (lean_is_scalar(x_20)) { + x_27 = lean_alloc_ctor(0, 2, 0); +} else { + x_27 = x_20; +} +lean_ctor_set(x_27, 0, x_26); +lean_ctor_set(x_27, 1, x_22); +return x_27; +} +else +{ +lean_object* x_28; +if (lean_is_scalar(x_20)) { + x_28 = lean_alloc_ctor(0, 2, 0); +} else { + x_28 = x_20; +} +lean_ctor_set(x_28, 0, x_1); +lean_ctor_set(x_28, 1, x_22); +return x_28; +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; uint8_t x_41; +x_29 = lean_ctor_get(x_24, 0); +lean_inc(x_29); +lean_dec(x_24); +x_30 = lean_unsigned_to_nat(0u); +x_31 = l_Lean_Expr_getAppNumArgsAux___main(x_23, x_30); +x_32 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_31); +x_33 = lean_mk_array(x_31, x_32); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_sub(x_31, x_34); +lean_dec(x_31); +x_36 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_23, x_33, x_35); +x_37 = l_List_lengthAux___main___rarg(x_5, x_30); +x_38 = lean_ctor_get(x_4, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_38, 1); +lean_inc(x_39); +lean_dec(x_38); +x_40 = l_List_lengthAux___main___rarg(x_39, x_30); +x_41 = lean_nat_dec_eq(x_37, x_40); +lean_dec(x_40); +lean_dec(x_37); +if (x_41 == 0) +{ +uint8_t x_42; +lean_dec(x_39); +lean_dec(x_36); +lean_dec(x_29); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_42 = lean_expr_eqv(x_2, x_3); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = l_Lean_Expr_updateFn___main(x_1, x_3); +if (lean_is_scalar(x_20)) { + x_44 = lean_alloc_ctor(0, 2, 0); +} else { + x_44 = x_20; +} +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_22); +return x_44; +} +else +{ +lean_object* x_45; +if (lean_is_scalar(x_20)) { + x_45 = lean_alloc_ctor(0, 2, 0); +} else { + x_45 = x_20; +} +lean_ctor_set(x_45, 0, x_1); +lean_ctor_set(x_45, 1, x_22); +return x_45; +} +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +lean_dec(x_20); +lean_dec(x_1); +x_46 = lean_ctor_get(x_29, 2); +lean_inc(x_46); +x_47 = lean_instantiate_lparams(x_46, x_39, x_5); +x_48 = lean_ctor_get(x_4, 2); +lean_inc(x_48); +x_49 = lean_ctor_get(x_4, 4); +lean_inc(x_49); +x_50 = lean_nat_add(x_48, x_49); +lean_dec(x_49); +lean_dec(x_48); +x_51 = lean_ctor_get(x_4, 5); +lean_inc(x_51); +lean_dec(x_4); +x_52 = lean_nat_add(x_50, x_51); +lean_dec(x_51); +lean_dec(x_50); +x_53 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_52, x_6, x_30, x_47); +lean_dec(x_52); +x_54 = lean_array_get_size(x_36); +x_55 = lean_ctor_get(x_29, 1); +lean_inc(x_55); +lean_dec(x_29); +x_56 = lean_nat_sub(x_54, x_55); +lean_dec(x_55); +x_57 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_54, x_36, x_56, x_53); +lean_dec(x_36); +lean_dec(x_54); +x_58 = lean_nat_add(x_9, x_34); +lean_dec(x_9); +x_59 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_58, x_57); +lean_dec(x_10); +x_60 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_59, x_7, x_22); +return x_60; +} +} +} +} +else +{ +uint8_t x_110; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_110 = !lean_is_exclusive(x_17); +if (x_110 == 0) +{ +return x_17; +} +else +{ +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_17, 0); +x_112 = lean_ctor_get(x_17, 1); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_17); +x_113 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_113, 0, x_111); +lean_ctor_set(x_113, 1, x_112); +return x_113; +} +} +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_LocalDecl_value_x3f(x_3); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_1, 0); +lean_inc(x_7); +lean_dec(x_1); +x_8 = lean_ctor_get(x_7, 1); +lean_inc(x_8); +lean_dec(x_7); +x_9 = lean_apply_4(x_8, lean_box(0), x_2, x_4, x_5); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_2); +x_10 = lean_ctor_get(x_6, 0); +lean_inc(x_10); +lean_dec(x_6); +x_11 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10(x_1, x_10, x_4, x_5); +return x_11; +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +lean_dec(x_1); +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_4, x_5); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_2); +x_9 = lean_ctor_get(x_3, 0); +lean_inc(x_9); +lean_dec(x_3); +x_10 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10(x_1, x_9, x_4, x_5); +return x_10; +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +switch (lean_obj_tag(x_2)) { +case 0: +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +lean_dec(x_2); +x_10 = l_Lean_Expr_Inhabited; +x_11 = l_monadInhabited___rarg(x_1, x_10); +x_12 = l_unreachable_x21___rarg(x_11); +x_13 = lean_apply_2(x_12, x_3, x_4); +return x_13; +} +case 1: +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_14 = lean_ctor_get(x_2, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_1, 1); +lean_inc(x_15); +x_16 = lean_alloc_closure((void*)(l_Lean_Meta_getLocalDecl), 3, 1); +lean_closure_set(x_16, 0, x_14); +x_17 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__1___boxed), 5, 2); +lean_closure_set(x_17, 0, x_1); +lean_closure_set(x_17, 1, x_2); +x_18 = lean_apply_6(x_15, lean_box(0), lean_box(0), x_16, x_17, x_3, x_4); +return x_18; +} +case 2: +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_19 = lean_ctor_get(x_2, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_1, 1); +lean_inc(x_20); +x_21 = lean_alloc_closure((void*)(l_Lean_Meta_getExprMVarAssignment___boxed), 3, 1); +lean_closure_set(x_21, 0, x_19); +x_22 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__2), 5, 2); +lean_closure_set(x_22, 0, x_1); +lean_closure_set(x_22, 1, x_2); +x_23 = lean_apply_6(x_20, lean_box(0), lean_box(0), x_21, x_22, x_3, x_4); +return x_23; +} +case 4: +{ +lean_object* x_24; +lean_dec(x_3); +lean_dec(x_1); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_2); +lean_ctor_set(x_24, 1, x_4); +return x_24; +} +case 5: +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_dec(x_1); +x_25 = lean_ctor_get(x_2, 0); +lean_inc(x_25); +x_26 = l_Lean_Expr_getAppFn___main(x_25); +lean_dec(x_25); +lean_inc(x_3); +lean_inc(x_26); +x_27 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_26, x_3, x_4); +if (lean_obj_tag(x_27) == 0) +{ +uint8_t x_28; +x_28 = !lean_is_exclusive(x_27); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; uint8_t x_31; +x_29 = lean_ctor_get(x_27, 0); +x_30 = lean_ctor_get(x_27, 1); +x_31 = l_Lean_Expr_isLambda(x_29); +if (x_31 == 0) +{ +if (lean_obj_tag(x_29) == 4) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; +lean_free_object(x_27); +x_32 = lean_ctor_get(x_29, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_29, 1); +lean_inc(x_33); +x_34 = 0; +x_35 = l_Lean_Meta_getConstAux(x_32, x_34, x_3, x_30); +if (lean_obj_tag(x_35) == 0) +{ +lean_object* x_36; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +if (lean_obj_tag(x_36) == 0) +{ +uint8_t x_37; +lean_dec(x_33); +lean_dec(x_3); +x_37 = !lean_is_exclusive(x_35); +if (x_37 == 0) +{ +lean_object* x_38; uint8_t x_39; +x_38 = lean_ctor_get(x_35, 0); +lean_dec(x_38); +x_39 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_39 == 0) +{ +lean_object* x_40; +x_40 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_40); +return x_35; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_2); +return x_35; +} +} +else +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 1); +lean_inc(x_41); +lean_dec(x_35); +x_42 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_41); +return x_44; +} +else +{ +lean_object* x_45; +lean_dec(x_29); +x_45 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_45, 0, x_2); +lean_ctor_set(x_45, 1, x_41); +return x_45; +} +} +} +else +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_36, 0); +lean_inc(x_46); +lean_dec(x_36); +switch (lean_obj_tag(x_46)) { +case 1: +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; uint8_t x_51; +x_47 = lean_ctor_get(x_35, 1); +lean_inc(x_47); +lean_dec(x_35); +x_48 = l_Lean_ConstantInfo_name(x_46); +x_49 = l_Lean_Meta_isAuxDef_x3f(x_48, x_3, x_47); +lean_dec(x_48); +x_50 = lean_ctor_get(x_49, 0); +lean_inc(x_50); +x_51 = lean_unbox(x_50); +lean_dec(x_50); +if (x_51 == 0) +{ +uint8_t x_52; +lean_dec(x_46); +lean_dec(x_33); +lean_dec(x_3); +x_52 = !lean_is_exclusive(x_49); +if (x_52 == 0) +{ +lean_object* x_53; uint8_t x_54; +x_53 = lean_ctor_get(x_49, 0); +lean_dec(x_53); +x_54 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_54 == 0) +{ +lean_object* x_55; +x_55 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_49, 0, x_55); +return x_49; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_49, 0, x_2); +return x_49; +} +} +else +{ +lean_object* x_56; uint8_t x_57; +x_56 = lean_ctor_get(x_49, 1); +lean_inc(x_56); +lean_dec(x_49); +x_57 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; +x_58 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_58); +lean_ctor_set(x_59, 1, x_56); +return x_59; +} +else +{ +lean_object* x_60; +lean_dec(x_29); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_2); +lean_ctor_set(x_60, 1, x_56); +return x_60; +} +} +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_61 = lean_ctor_get(x_49, 1); +lean_inc(x_61); +lean_dec(x_49); +x_62 = lean_unsigned_to_nat(0u); +x_63 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_62); +x_64 = lean_mk_empty_array_with_capacity(x_63); +lean_dec(x_63); +lean_inc(x_2); +x_65 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_64); +x_66 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__2(x_2, x_26, x_29, x_46, x_33, x_65, x_3, x_61); +lean_dec(x_29); +lean_dec(x_26); +return x_66; +} +} +case 4: +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_67 = lean_ctor_get(x_35, 1); +lean_inc(x_67); +lean_dec(x_35); +x_68 = lean_ctor_get(x_46, 0); +lean_inc(x_68); +lean_dec(x_46); +x_69 = lean_unsigned_to_nat(0u); +x_70 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_69); +x_71 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_70); +x_72 = lean_mk_array(x_70, x_71); +x_73 = lean_unsigned_to_nat(1u); +x_74 = lean_nat_sub(x_70, x_73); +lean_dec(x_70); +lean_inc(x_2); +x_75 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_72, x_74); +x_76 = l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__3(x_2, x_26, x_29, x_68, x_33, x_75, x_3, x_67); +lean_dec(x_75); +lean_dec(x_33); +lean_dec(x_68); +lean_dec(x_29); +lean_dec(x_26); +return x_76; +} +case 7: +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_77 = lean_ctor_get(x_35, 1); +lean_inc(x_77); +lean_dec(x_35); +x_78 = lean_ctor_get(x_46, 0); +lean_inc(x_78); +lean_dec(x_46); +x_79 = lean_unsigned_to_nat(0u); +x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_79); +x_81 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_80); +x_82 = lean_mk_array(x_80, x_81); +x_83 = lean_unsigned_to_nat(1u); +x_84 = lean_nat_sub(x_80, x_83); +lean_dec(x_80); +lean_inc(x_2); +x_85 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_82, x_84); +x_86 = l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__4(x_2, x_26, x_29, x_78, x_33, x_85, x_3, x_77); +lean_dec(x_85); +lean_dec(x_29); +lean_dec(x_26); +return x_86; +} +default: +{ +uint8_t x_87; +lean_dec(x_46); +lean_dec(x_33); +lean_dec(x_3); +x_87 = !lean_is_exclusive(x_35); +if (x_87 == 0) +{ +lean_object* x_88; uint8_t x_89; +x_88 = lean_ctor_get(x_35, 0); +lean_dec(x_88); +x_89 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_89 == 0) +{ +lean_object* x_90; +x_90 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_90); +return x_35; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_2); +return x_35; +} +} +else +{ +lean_object* x_91; uint8_t x_92; +x_91 = lean_ctor_get(x_35, 1); +lean_inc(x_91); +lean_dec(x_35); +x_92 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_92 == 0) +{ +lean_object* x_93; lean_object* x_94; +x_93 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_94 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_94, 0, x_93); +lean_ctor_set(x_94, 1, x_91); +return x_94; +} +else +{ +lean_object* x_95; +lean_dec(x_29); +x_95 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_95, 0, x_2); +lean_ctor_set(x_95, 1, x_91); +return x_95; +} +} +} +} +} +} +else +{ +uint8_t x_96; +lean_dec(x_33); +lean_dec(x_29); +lean_dec(x_26); lean_dec(x_3); lean_dec(x_2); +x_96 = !lean_is_exclusive(x_35); +if (x_96 == 0) +{ +return x_35; +} +else +{ +lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_97 = lean_ctor_get(x_35, 0); +x_98 = lean_ctor_get(x_35, 1); +lean_inc(x_98); +lean_inc(x_97); +lean_dec(x_35); +x_99 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_99, 0, x_97); +lean_ctor_set(x_99, 1, x_98); +return x_99; +} +} +} +else +{ +uint8_t x_100; +lean_dec(x_3); +x_100 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_100 == 0) +{ +lean_object* x_101; +x_101 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_27, 0, x_101); +return x_27; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_27, 0, x_2); +return x_27; +} +} +} +else +{ +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +lean_free_object(x_27); +lean_dec(x_29); +x_102 = lean_unsigned_to_nat(0u); +x_103 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_102); +x_104 = lean_mk_empty_array_with_capacity(x_103); +lean_dec(x_103); +x_105 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_104); +x_106 = l_Lean_Expr_betaRev(x_26, x_105); +lean_dec(x_26); +x_107 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_106, x_3, x_30); +return x_107; +} +} +else +{ +lean_object* x_108; lean_object* x_109; uint8_t x_110; +x_108 = lean_ctor_get(x_27, 0); +x_109 = lean_ctor_get(x_27, 1); +lean_inc(x_109); +lean_inc(x_108); +lean_dec(x_27); +x_110 = l_Lean_Expr_isLambda(x_108); +if (x_110 == 0) +{ +if (lean_obj_tag(x_108) == 4) +{ +lean_object* x_111; lean_object* x_112; uint8_t x_113; lean_object* x_114; +x_111 = lean_ctor_get(x_108, 0); +lean_inc(x_111); +x_112 = lean_ctor_get(x_108, 1); +lean_inc(x_112); +x_113 = 0; +x_114 = l_Lean_Meta_getConstAux(x_111, x_113, x_3, x_109); +if (lean_obj_tag(x_114) == 0) +{ +lean_object* x_115; +x_115 = lean_ctor_get(x_114, 0); +lean_inc(x_115); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; uint8_t x_118; +lean_dec(x_112); +lean_dec(x_3); +x_116 = lean_ctor_get(x_114, 1); +lean_inc(x_116); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_117 = x_114; +} else { + lean_dec_ref(x_114); + x_117 = lean_box(0); +} +x_118 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_118 == 0) +{ +lean_object* x_119; lean_object* x_120; +x_119 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_117)) { + x_120 = lean_alloc_ctor(0, 2, 0); +} else { + x_120 = x_117; +} +lean_ctor_set(x_120, 0, x_119); +lean_ctor_set(x_120, 1, x_116); +return x_120; +} +else +{ +lean_object* x_121; +lean_dec(x_108); +if (lean_is_scalar(x_117)) { + x_121 = lean_alloc_ctor(0, 2, 0); +} else { + x_121 = x_117; +} +lean_ctor_set(x_121, 0, x_2); +lean_ctor_set(x_121, 1, x_116); +return x_121; +} +} +else +{ +lean_object* x_122; +x_122 = lean_ctor_get(x_115, 0); +lean_inc(x_122); +lean_dec(x_115); +switch (lean_obj_tag(x_122)) { +case 1: +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; uint8_t x_127; +x_123 = lean_ctor_get(x_114, 1); +lean_inc(x_123); +lean_dec(x_114); +x_124 = l_Lean_ConstantInfo_name(x_122); +x_125 = l_Lean_Meta_isAuxDef_x3f(x_124, x_3, x_123); +lean_dec(x_124); +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_unbox(x_126); +lean_dec(x_126); +if (x_127 == 0) +{ +lean_object* x_128; lean_object* x_129; uint8_t x_130; +lean_dec(x_122); +lean_dec(x_112); +lean_dec(x_3); +x_128 = lean_ctor_get(x_125, 1); +lean_inc(x_128); +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_129 = x_125; +} else { + lean_dec_ref(x_125); + x_129 = lean_box(0); +} +x_130 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_130 == 0) +{ +lean_object* x_131; lean_object* x_132; +x_131 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_129)) { + x_132 = lean_alloc_ctor(0, 2, 0); +} else { + x_132 = x_129; +} +lean_ctor_set(x_132, 0, x_131); +lean_ctor_set(x_132, 1, x_128); +return x_132; +} +else +{ +lean_object* x_133; +lean_dec(x_108); +if (lean_is_scalar(x_129)) { + x_133 = lean_alloc_ctor(0, 2, 0); +} else { + x_133 = x_129; +} +lean_ctor_set(x_133, 0, x_2); +lean_ctor_set(x_133, 1, x_128); +return x_133; +} +} +else +{ +lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; +x_134 = lean_ctor_get(x_125, 1); +lean_inc(x_134); +lean_dec(x_125); +x_135 = lean_unsigned_to_nat(0u); +x_136 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_135); +x_137 = lean_mk_empty_array_with_capacity(x_136); +lean_dec(x_136); +lean_inc(x_2); +x_138 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_137); +x_139 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__2(x_2, x_26, x_108, x_122, x_112, x_138, x_3, x_134); +lean_dec(x_108); +lean_dec(x_26); +return x_139; +} +} +case 4: +{ +lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_140 = lean_ctor_get(x_114, 1); +lean_inc(x_140); +lean_dec(x_114); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +lean_dec(x_122); +x_142 = lean_unsigned_to_nat(0u); +x_143 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_142); +x_144 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_143); +x_145 = lean_mk_array(x_143, x_144); +x_146 = lean_unsigned_to_nat(1u); +x_147 = lean_nat_sub(x_143, x_146); +lean_dec(x_143); +lean_inc(x_2); +x_148 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_145, x_147); +x_149 = l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__3(x_2, x_26, x_108, x_141, x_112, x_148, x_3, x_140); +lean_dec(x_148); +lean_dec(x_112); +lean_dec(x_141); +lean_dec(x_108); +lean_dec(x_26); +return x_149; +} +case 7: +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_150 = lean_ctor_get(x_114, 1); +lean_inc(x_150); +lean_dec(x_114); +x_151 = lean_ctor_get(x_122, 0); +lean_inc(x_151); +lean_dec(x_122); +x_152 = lean_unsigned_to_nat(0u); +x_153 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_152); +x_154 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_153); +x_155 = lean_mk_array(x_153, x_154); +x_156 = lean_unsigned_to_nat(1u); +x_157 = lean_nat_sub(x_153, x_156); +lean_dec(x_153); +lean_inc(x_2); +x_158 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_155, x_157); +x_159 = l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__4(x_2, x_26, x_108, x_151, x_112, x_158, x_3, x_150); +lean_dec(x_158); +lean_dec(x_108); +lean_dec(x_26); +return x_159; +} +default: +{ +lean_object* x_160; lean_object* x_161; uint8_t x_162; +lean_dec(x_122); +lean_dec(x_112); +lean_dec(x_3); +x_160 = lean_ctor_get(x_114, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_161 = x_114; +} else { + lean_dec_ref(x_114); + x_161 = lean_box(0); +} +x_162 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_162 == 0) +{ +lean_object* x_163; lean_object* x_164; +x_163 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_161)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_161; +} +lean_ctor_set(x_164, 0, x_163); +lean_ctor_set(x_164, 1, x_160); +return x_164; +} +else +{ +lean_object* x_165; +lean_dec(x_108); +if (lean_is_scalar(x_161)) { + x_165 = lean_alloc_ctor(0, 2, 0); +} else { + x_165 = x_161; +} +lean_ctor_set(x_165, 0, x_2); +lean_ctor_set(x_165, 1, x_160); +return x_165; +} +} +} +} +} +else +{ +lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; +lean_dec(x_112); +lean_dec(x_108); +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_166 = lean_ctor_get(x_114, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_114, 1); +lean_inc(x_167); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_168 = x_114; +} else { + lean_dec_ref(x_114); + x_168 = lean_box(0); +} +if (lean_is_scalar(x_168)) { + x_169 = lean_alloc_ctor(1, 2, 0); +} else { + x_169 = x_168; +} +lean_ctor_set(x_169, 0, x_166); +lean_ctor_set(x_169, 1, x_167); +return x_169; +} +} +else +{ +uint8_t x_170; +lean_dec(x_3); +x_170 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_170 == 0) +{ +lean_object* x_171; lean_object* x_172; +x_171 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_171); +lean_ctor_set(x_172, 1, x_109); +return x_172; +} +else +{ +lean_object* x_173; +lean_dec(x_108); +x_173 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_173, 0, x_2); +lean_ctor_set(x_173, 1, x_109); +return x_173; +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; +lean_dec(x_108); +x_174 = lean_unsigned_to_nat(0u); +x_175 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_174); +x_176 = lean_mk_empty_array_with_capacity(x_175); +lean_dec(x_175); +x_177 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_176); +x_178 = l_Lean_Expr_betaRev(x_26, x_177); +lean_dec(x_26); +x_179 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_178, x_3, x_109); +return x_179; +} +} +} +else +{ +uint8_t x_180; +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_180 = !lean_is_exclusive(x_27); +if (x_180 == 0) +{ +return x_27; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_27, 0); +x_182 = lean_ctor_get(x_27, 1); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_27); +x_183 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_183, 0, x_181); +lean_ctor_set(x_183, 1, x_182); +return x_183; +} +} +} +case 8: +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; lean_dec(x_1); -x_20 = !lean_is_exclusive(x_15); -if (x_20 == 0) +x_184 = lean_ctor_get(x_2, 2); +lean_inc(x_184); +x_185 = lean_ctor_get(x_2, 3); +lean_inc(x_185); +lean_dec(x_2); +x_186 = lean_expr_instantiate1(x_185, x_184); +lean_dec(x_184); +lean_dec(x_185); +x_187 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_186, x_3, x_4); +return x_187; +} +case 10: +{ +lean_object* x_188; +x_188 = lean_ctor_get(x_2, 1); +lean_inc(x_188); +lean_dec(x_2); +x_2 = x_188; +goto _start; +} +case 11: +{ +lean_object* x_190; lean_object* x_191; lean_object* x_192; +lean_dec(x_1); +x_190 = lean_ctor_get(x_2, 1); +lean_inc(x_190); +x_191 = lean_ctor_get(x_2, 2); +lean_inc(x_191); +lean_inc(x_3); +x_192 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_191, x_3, x_4); +if (lean_obj_tag(x_192) == 0) +{ +uint8_t x_193; +x_193 = !lean_is_exclusive(x_192); +if (x_193 == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; +x_194 = lean_ctor_get(x_192, 0); +x_195 = lean_ctor_get(x_192, 1); +x_196 = l_Lean_Expr_getAppFn___main(x_194); +if (lean_obj_tag(x_196) == 4) +{ +lean_object* x_197; uint8_t x_198; lean_object* x_199; +lean_free_object(x_192); +x_197 = lean_ctor_get(x_196, 0); +lean_inc(x_197); +lean_dec(x_196); +x_198 = 0; +x_199 = l_Lean_Meta_getConstAux(x_197, x_198, x_3, x_195); +lean_dec(x_3); +if (lean_obj_tag(x_199) == 0) +{ +lean_object* x_200; +x_200 = lean_ctor_get(x_199, 0); +lean_inc(x_200); +if (lean_obj_tag(x_200) == 0) +{ +uint8_t x_201; +lean_dec(x_194); +lean_dec(x_190); +x_201 = !lean_is_exclusive(x_199); +if (x_201 == 0) +{ +lean_object* x_202; +x_202 = lean_ctor_get(x_199, 0); +lean_dec(x_202); +lean_ctor_set(x_199, 0, x_2); +return x_199; +} +else +{ +lean_object* x_203; lean_object* x_204; +x_203 = lean_ctor_get(x_199, 1); +lean_inc(x_203); +lean_dec(x_199); +x_204 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_204, 0, x_2); +lean_ctor_set(x_204, 1, x_203); +return x_204; +} +} +else +{ +lean_object* x_205; +x_205 = lean_ctor_get(x_200, 0); +lean_inc(x_205); +lean_dec(x_200); +if (lean_obj_tag(x_205) == 6) +{ +uint8_t x_206; +x_206 = !lean_is_exclusive(x_199); +if (x_206 == 0) +{ +lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_207 = lean_ctor_get(x_199, 0); +lean_dec(x_207); +x_208 = lean_ctor_get(x_205, 0); +lean_inc(x_208); +lean_dec(x_205); +x_209 = lean_ctor_get(x_208, 3); +lean_inc(x_209); +lean_dec(x_208); +x_210 = lean_nat_add(x_209, x_190); +lean_dec(x_190); +lean_dec(x_209); +x_211 = lean_unsigned_to_nat(0u); +x_212 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_211); +x_213 = lean_nat_sub(x_212, x_210); +lean_dec(x_210); +lean_dec(x_212); +x_214 = lean_unsigned_to_nat(1u); +x_215 = lean_nat_sub(x_213, x_214); +lean_dec(x_213); +x_216 = l_Lean_Expr_getRevArgD___main(x_194, x_215, x_2); +lean_dec(x_2); +lean_dec(x_194); +lean_ctor_set(x_199, 0, x_216); +return x_199; +} +else +{ +lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; +x_217 = lean_ctor_get(x_199, 1); +lean_inc(x_217); +lean_dec(x_199); +x_218 = lean_ctor_get(x_205, 0); +lean_inc(x_218); +lean_dec(x_205); +x_219 = lean_ctor_get(x_218, 3); +lean_inc(x_219); +lean_dec(x_218); +x_220 = lean_nat_add(x_219, x_190); +lean_dec(x_190); +lean_dec(x_219); +x_221 = lean_unsigned_to_nat(0u); +x_222 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_221); +x_223 = lean_nat_sub(x_222, x_220); +lean_dec(x_220); +lean_dec(x_222); +x_224 = lean_unsigned_to_nat(1u); +x_225 = lean_nat_sub(x_223, x_224); +lean_dec(x_223); +x_226 = l_Lean_Expr_getRevArgD___main(x_194, x_225, x_2); +lean_dec(x_2); +lean_dec(x_194); +x_227 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_227, 0, x_226); +lean_ctor_set(x_227, 1, x_217); +return x_227; +} +} +else +{ +uint8_t x_228; +lean_dec(x_205); +lean_dec(x_194); +lean_dec(x_190); +x_228 = !lean_is_exclusive(x_199); +if (x_228 == 0) +{ +lean_object* x_229; +x_229 = lean_ctor_get(x_199, 0); +lean_dec(x_229); +lean_ctor_set(x_199, 0, x_2); +return x_199; +} +else +{ +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_199, 1); +lean_inc(x_230); +lean_dec(x_199); +x_231 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_231, 0, x_2); +lean_ctor_set(x_231, 1, x_230); +return x_231; +} +} +} +} +else +{ +uint8_t x_232; +lean_dec(x_194); +lean_dec(x_190); +lean_dec(x_2); +x_232 = !lean_is_exclusive(x_199); +if (x_232 == 0) +{ +return x_199; +} +else +{ +lean_object* x_233; lean_object* x_234; lean_object* x_235; +x_233 = lean_ctor_get(x_199, 0); +x_234 = lean_ctor_get(x_199, 1); +lean_inc(x_234); +lean_inc(x_233); +lean_dec(x_199); +x_235 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_235, 0, x_233); +lean_ctor_set(x_235, 1, x_234); +return x_235; +} +} +} +else +{ +lean_dec(x_196); +lean_dec(x_194); +lean_dec(x_190); +lean_dec(x_3); +lean_ctor_set(x_192, 0, x_2); +return x_192; +} +} +else +{ +lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_236 = lean_ctor_get(x_192, 0); +x_237 = lean_ctor_get(x_192, 1); +lean_inc(x_237); +lean_inc(x_236); +lean_dec(x_192); +x_238 = l_Lean_Expr_getAppFn___main(x_236); +if (lean_obj_tag(x_238) == 4) +{ +lean_object* x_239; uint8_t x_240; lean_object* x_241; +x_239 = lean_ctor_get(x_238, 0); +lean_inc(x_239); +lean_dec(x_238); +x_240 = 0; +x_241 = l_Lean_Meta_getConstAux(x_239, x_240, x_3, x_237); +lean_dec(x_3); +if (lean_obj_tag(x_241) == 0) +{ +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; +lean_dec(x_236); +lean_dec(x_190); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_244 = x_241; +} else { + lean_dec_ref(x_241); + x_244 = lean_box(0); +} +if (lean_is_scalar(x_244)) { + x_245 = lean_alloc_ctor(0, 2, 0); +} else { + x_245 = x_244; +} +lean_ctor_set(x_245, 0, x_2); +lean_ctor_set(x_245, 1, x_243); +return x_245; +} +else +{ +lean_object* x_246; +x_246 = lean_ctor_get(x_242, 0); +lean_inc(x_246); +lean_dec(x_242); +if (lean_obj_tag(x_246) == 6) +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; +} else { + lean_dec_ref(x_241); + x_248 = lean_box(0); +} +x_249 = lean_ctor_get(x_246, 0); +lean_inc(x_249); +lean_dec(x_246); +x_250 = lean_ctor_get(x_249, 3); +lean_inc(x_250); +lean_dec(x_249); +x_251 = lean_nat_add(x_250, x_190); +lean_dec(x_190); +lean_dec(x_250); +x_252 = lean_unsigned_to_nat(0u); +x_253 = l_Lean_Expr_getAppNumArgsAux___main(x_236, x_252); +x_254 = lean_nat_sub(x_253, x_251); +lean_dec(x_251); +lean_dec(x_253); +x_255 = lean_unsigned_to_nat(1u); +x_256 = lean_nat_sub(x_254, x_255); +lean_dec(x_254); +x_257 = l_Lean_Expr_getRevArgD___main(x_236, x_256, x_2); +lean_dec(x_2); +lean_dec(x_236); +if (lean_is_scalar(x_248)) { + x_258 = lean_alloc_ctor(0, 2, 0); +} else { + x_258 = x_248; +} +lean_ctor_set(x_258, 0, x_257); +lean_ctor_set(x_258, 1, x_247); +return x_258; +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; +lean_dec(x_246); +lean_dec(x_236); +lean_dec(x_190); +x_259 = lean_ctor_get(x_241, 1); +lean_inc(x_259); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_260 = x_241; +} else { + lean_dec_ref(x_241); + x_260 = lean_box(0); +} +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 2, 0); +} else { + x_261 = x_260; +} +lean_ctor_set(x_261, 0, x_2); +lean_ctor_set(x_261, 1, x_259); +return x_261; +} +} +} +else +{ +lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; +lean_dec(x_236); +lean_dec(x_190); +lean_dec(x_2); +x_262 = lean_ctor_get(x_241, 0); +lean_inc(x_262); +x_263 = lean_ctor_get(x_241, 1); +lean_inc(x_263); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_264 = x_241; +} else { + lean_dec_ref(x_241); + x_264 = lean_box(0); +} +if (lean_is_scalar(x_264)) { + x_265 = lean_alloc_ctor(1, 2, 0); +} else { + x_265 = x_264; +} +lean_ctor_set(x_265, 0, x_262); +lean_ctor_set(x_265, 1, x_263); +return x_265; +} +} +else +{ +lean_object* x_266; +lean_dec(x_238); +lean_dec(x_236); +lean_dec(x_190); +lean_dec(x_3); +x_266 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_266, 0, x_2); +lean_ctor_set(x_266, 1, x_237); +return x_266; +} +} +} +else +{ +uint8_t x_267; +lean_dec(x_190); +lean_dec(x_3); +lean_dec(x_2); +x_267 = !lean_is_exclusive(x_192); +if (x_267 == 0) +{ +return x_192; +} +else +{ +lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_268 = lean_ctor_get(x_192, 0); +x_269 = lean_ctor_get(x_192, 1); +lean_inc(x_269); +lean_inc(x_268); +lean_dec(x_192); +x_270 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_270, 0, x_268); +lean_ctor_set(x_270, 1, x_269); +return x_270; +} +} +} +case 12: +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; +lean_dec(x_2); +x_271 = l_Lean_Expr_Inhabited; +x_272 = l_monadInhabited___rarg(x_1, x_271); +x_273 = l_unreachable_x21___rarg(x_272); +x_274 = lean_apply_2(x_273, x_3, x_4); +return x_274; +} +default: +{ +lean_object* x_275; +x_275 = lean_box(0); +x_5 = x_275; +goto block_9; +} +} +block_9: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +lean_dec(x_5); +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +lean_dec(x_1); +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_3, x_4); +return x_8; +} +} +} +lean_object* l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1; +x_5 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10(x_4, x_1, x_2, x_3); +return x_5; +} +} +lean_object* l___private_Init_Lean_WHNF_8__deltaDefinition___at_Lean_Meta_whnfImpl___main___spec__12(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; lean_object* x_9; uint8_t x_10; +x_6 = l_Lean_ConstantInfo_lparams(x_2); +x_7 = lean_unsigned_to_nat(0u); +x_8 = l_List_lengthAux___main___rarg(x_6, x_7); +lean_dec(x_6); +x_9 = l_List_lengthAux___main___rarg(x_3, x_7); +x_10 = lean_nat_dec_eq(x_8, x_9); +lean_dec(x_9); +lean_dec(x_8); +if (x_10 == 0) +{ +lean_object* x_11; +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_1); +lean_ctor_set(x_11, 1, x_5); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; lean_object* x_14; +lean_dec(x_1); +x_12 = lean_instantiate_value_lparams(x_2, x_3); +x_13 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_12); +x_14 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_13, x_4, x_5); +return x_14; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__13(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__14(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__17(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; uint8_t x_13; +x_9 = l_Lean_ConstantInfo_lparams(x_4); +x_10 = lean_unsigned_to_nat(0u); +x_11 = l_List_lengthAux___main___rarg(x_9, x_10); +lean_dec(x_9); +x_12 = l_List_lengthAux___main___rarg(x_5, x_10); +x_13 = lean_nat_dec_eq(x_11, x_12); +lean_dec(x_12); +lean_dec(x_11); +if (x_13 == 0) +{ +uint8_t x_14; +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +x_14 = lean_expr_eqv(x_2, x_3); +if (x_14 == 0) +{ +lean_object* x_15; lean_object* x_16; +x_15 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_15); +lean_ctor_set(x_16, 1, x_8); +return x_16; +} +else +{ +lean_object* x_17; +x_17 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_17, 0, x_1); +lean_ctor_set(x_17, 1, x_8); +return x_17; +} +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; +lean_dec(x_1); +x_18 = lean_instantiate_value_lparams(x_4, x_5); +x_19 = l_Lean_Expr_betaRev(x_18, x_6); +lean_dec(x_18); +x_20 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_19); +x_21 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_20, x_7, x_8); +return x_21; +} +} +} +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__18(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; uint8_t x_113; lean_object* x_114; +x_113 = lean_ctor_get_uint8(x_4, sizeof(void*)*1); +x_114 = lean_box(x_113); +switch (lean_obj_tag(x_114)) { +case 2: +{ +lean_object* x_115; lean_object* x_116; +x_115 = lean_unsigned_to_nat(5u); +x_116 = lean_unsigned_to_nat(3u); +x_9 = x_115; +x_10 = x_116; +goto block_112; +} +case 3: +{ +lean_object* x_117; lean_object* x_118; +x_117 = lean_unsigned_to_nat(4u); +x_118 = lean_unsigned_to_nat(3u); +x_9 = x_117; +x_10 = x_118; +goto block_112; +} +default: +{ +uint8_t x_119; +lean_dec(x_114); +lean_dec(x_7); +x_119 = lean_expr_eqv(x_2, x_3); +if (x_119 == 0) +{ +lean_object* x_120; lean_object* x_121; +x_120 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_121 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_121, 0, x_120); +lean_ctor_set(x_121, 1, x_8); +return x_121; +} +else +{ +lean_object* x_122; +x_122 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_122, 0, x_1); +lean_ctor_set(x_122, 1, x_8); +return x_122; +} +} +} +block_112: +{ +lean_object* x_11; uint8_t x_12; +x_11 = lean_array_get_size(x_6); +x_12 = lean_nat_dec_lt(x_9, x_11); +if (x_12 == 0) +{ +uint8_t x_13; +lean_dec(x_11); +lean_dec(x_7); +x_13 = lean_expr_eqv(x_2, x_3); +if (x_13 == 0) +{ +lean_object* x_14; lean_object* x_15; +x_14 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_14); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +else +{ +lean_object* x_16; +x_16 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_16, 0, x_1); +lean_ctor_set(x_16, 1, x_8); +return x_16; +} +} +else +{ +lean_object* x_17; lean_object* x_18; +x_17 = lean_array_fget(x_6, x_9); +lean_inc(x_7); +x_18 = l_Lean_Meta_whnf(x_17, x_7, x_8); +if (lean_obj_tag(x_18) == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_18, 0); +lean_inc(x_19); +if (lean_obj_tag(x_19) == 5) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +if (lean_obj_tag(x_20) == 5) +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_20, 0); +lean_inc(x_21); +lean_dec(x_20); +if (lean_obj_tag(x_21) == 5) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_21, 0); +lean_inc(x_22); +lean_dec(x_21); +if (lean_obj_tag(x_22) == 4) +{ +lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; lean_object* x_27; +x_23 = lean_ctor_get(x_18, 1); +lean_inc(x_23); +lean_dec(x_18); +x_24 = lean_ctor_get(x_19, 1); +lean_inc(x_24); +lean_dec(x_19); +x_25 = lean_ctor_get(x_22, 0); +lean_inc(x_25); +lean_dec(x_22); +x_26 = 0; +x_27 = l_Lean_Meta_getConstAux(x_25, x_26, x_7, x_23); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; +x_28 = lean_ctor_get(x_27, 0); +lean_inc(x_28); +if (lean_obj_tag(x_28) == 0) +{ +uint8_t x_29; +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_29 = !lean_is_exclusive(x_27); +if (x_29 == 0) +{ +lean_object* x_30; uint8_t x_31; +x_30 = lean_ctor_get(x_27, 0); +lean_dec(x_30); +x_31 = lean_expr_eqv(x_2, x_3); +if (x_31 == 0) +{ +lean_object* x_32; +x_32 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_32); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_33; uint8_t x_34; +x_33 = lean_ctor_get(x_27, 1); +lean_inc(x_33); +lean_dec(x_27); +x_34 = lean_expr_eqv(x_2, x_3); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; +x_35 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_36 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_36, 0, x_35); +lean_ctor_set(x_36, 1, x_33); +return x_36; +} +else +{ +lean_object* x_37; +x_37 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_37, 0, x_1); +lean_ctor_set(x_37, 1, x_33); +return x_37; +} +} +} +else +{ +lean_object* x_38; +x_38 = lean_ctor_get(x_28, 0); +lean_inc(x_38); +lean_dec(x_28); +if (lean_obj_tag(x_38) == 4) +{ +lean_object* x_39; uint8_t x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_38, 0); +lean_inc(x_39); +lean_dec(x_38); +x_40 = lean_ctor_get_uint8(x_39, sizeof(void*)*1); +lean_dec(x_39); +x_41 = lean_box(x_40); +if (lean_obj_tag(x_41) == 1) +{ +lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; +lean_dec(x_1); +x_42 = lean_ctor_get(x_27, 1); +lean_inc(x_42); +lean_dec(x_27); +x_43 = l_Lean_Expr_Inhabited; +x_44 = lean_array_get(x_43, x_6, x_10); +x_45 = l_Lean_mkApp(x_44, x_24); +x_46 = lean_unsigned_to_nat(1u); +x_47 = lean_nat_add(x_9, x_46); +x_48 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_11, x_6, x_47, x_45); +lean_dec(x_11); +x_49 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_48, x_7, x_42); +return x_49; +} +else +{ +uint8_t x_50; +lean_dec(x_41); +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_50 = !lean_is_exclusive(x_27); +if (x_50 == 0) +{ +lean_object* x_51; uint8_t x_52; +x_51 = lean_ctor_get(x_27, 0); +lean_dec(x_51); +x_52 = lean_expr_eqv(x_2, x_3); +if (x_52 == 0) +{ +lean_object* x_53; +x_53 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_53); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_54; uint8_t x_55; +x_54 = lean_ctor_get(x_27, 1); +lean_inc(x_54); +lean_dec(x_27); +x_55 = lean_expr_eqv(x_2, x_3); +if (x_55 == 0) +{ +lean_object* x_56; lean_object* x_57; +x_56 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_57 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_57, 0, x_56); +lean_ctor_set(x_57, 1, x_54); +return x_57; +} +else +{ +lean_object* x_58; +x_58 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_58, 0, x_1); +lean_ctor_set(x_58, 1, x_54); +return x_58; +} +} +} +} +else +{ +uint8_t x_59; +lean_dec(x_38); +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +x_59 = !lean_is_exclusive(x_27); +if (x_59 == 0) +{ +lean_object* x_60; uint8_t x_61; +x_60 = lean_ctor_get(x_27, 0); +lean_dec(x_60); +x_61 = lean_expr_eqv(x_2, x_3); +if (x_61 == 0) +{ +lean_object* x_62; +x_62 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_27, 0, x_62); +return x_27; +} +else +{ +lean_ctor_set(x_27, 0, x_1); +return x_27; +} +} +else +{ +lean_object* x_63; uint8_t x_64; +x_63 = lean_ctor_get(x_27, 1); +lean_inc(x_63); +lean_dec(x_27); +x_64 = lean_expr_eqv(x_2, x_3); +if (x_64 == 0) +{ +lean_object* x_65; lean_object* x_66; +x_65 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_63); +return x_66; +} +else +{ +lean_object* x_67; +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_1); +lean_ctor_set(x_67, 1, x_63); +return x_67; +} +} +} +} +} +else +{ +uint8_t x_68; +lean_dec(x_24); +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_1); +x_68 = !lean_is_exclusive(x_27); +if (x_68 == 0) +{ +return x_27; +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; +x_69 = lean_ctor_get(x_27, 0); +x_70 = lean_ctor_get(x_27, 1); +lean_inc(x_70); +lean_inc(x_69); +lean_dec(x_27); +x_71 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_71, 0, x_69); +lean_ctor_set(x_71, 1, x_70); +return x_71; +} +} +} +else +{ +uint8_t x_72; +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_72 = !lean_is_exclusive(x_18); +if (x_72 == 0) +{ +lean_object* x_73; uint8_t x_74; +x_73 = lean_ctor_get(x_18, 0); +lean_dec(x_73); +x_74 = lean_expr_eqv(x_2, x_3); +if (x_74 == 0) +{ +lean_object* x_75; +x_75 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_75); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_76; uint8_t x_77; +x_76 = lean_ctor_get(x_18, 1); +lean_inc(x_76); +lean_dec(x_18); +x_77 = lean_expr_eqv(x_2, x_3); +if (x_77 == 0) +{ +lean_object* x_78; lean_object* x_79; +x_78 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_79 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_79, 0, x_78); +lean_ctor_set(x_79, 1, x_76); +return x_79; +} +else +{ +lean_object* x_80; +x_80 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_80, 0, x_1); +lean_ctor_set(x_80, 1, x_76); +return x_80; +} +} +} +} +else +{ +uint8_t x_81; +lean_dec(x_21); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_81 = !lean_is_exclusive(x_18); +if (x_81 == 0) +{ +lean_object* x_82; uint8_t x_83; +x_82 = lean_ctor_get(x_18, 0); +lean_dec(x_82); +x_83 = lean_expr_eqv(x_2, x_3); +if (x_83 == 0) +{ +lean_object* x_84; +x_84 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_84); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_85; uint8_t x_86; +x_85 = lean_ctor_get(x_18, 1); +lean_inc(x_85); +lean_dec(x_18); +x_86 = lean_expr_eqv(x_2, x_3); +if (x_86 == 0) +{ +lean_object* x_87; lean_object* x_88; +x_87 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_87); +lean_ctor_set(x_88, 1, x_85); +return x_88; +} +else +{ +lean_object* x_89; +x_89 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_89, 0, x_1); +lean_ctor_set(x_89, 1, x_85); +return x_89; +} +} +} +} +else +{ +uint8_t x_90; +lean_dec(x_20); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_90 = !lean_is_exclusive(x_18); +if (x_90 == 0) +{ +lean_object* x_91; uint8_t x_92; +x_91 = lean_ctor_get(x_18, 0); +lean_dec(x_91); +x_92 = lean_expr_eqv(x_2, x_3); +if (x_92 == 0) +{ +lean_object* x_93; +x_93 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_93); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_94; uint8_t x_95; +x_94 = lean_ctor_get(x_18, 1); +lean_inc(x_94); +lean_dec(x_18); +x_95 = lean_expr_eqv(x_2, x_3); +if (x_95 == 0) +{ +lean_object* x_96; lean_object* x_97; +x_96 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_97 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_97, 0, x_96); +lean_ctor_set(x_97, 1, x_94); +return x_97; +} +else +{ +lean_object* x_98; +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_1); +lean_ctor_set(x_98, 1, x_94); +return x_98; +} +} +} +} +else +{ +uint8_t x_99; +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_7); +x_99 = !lean_is_exclusive(x_18); +if (x_99 == 0) +{ +lean_object* x_100; uint8_t x_101; +x_100 = lean_ctor_get(x_18, 0); +lean_dec(x_100); +x_101 = lean_expr_eqv(x_2, x_3); +if (x_101 == 0) +{ +lean_object* x_102; +x_102 = l_Lean_Expr_updateFn___main(x_1, x_3); +lean_ctor_set(x_18, 0, x_102); +return x_18; +} +else +{ +lean_ctor_set(x_18, 0, x_1); +return x_18; +} +} +else +{ +lean_object* x_103; uint8_t x_104; +x_103 = lean_ctor_get(x_18, 1); +lean_inc(x_103); +lean_dec(x_18); +x_104 = lean_expr_eqv(x_2, x_3); +if (x_104 == 0) +{ +lean_object* x_105; lean_object* x_106; +x_105 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_106 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_106, 0, x_105); +lean_ctor_set(x_106, 1, x_103); +return x_106; +} +else +{ +lean_object* x_107; +x_107 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_107, 0, x_1); +lean_ctor_set(x_107, 1, x_103); +return x_107; +} +} +} +} +else +{ +uint8_t x_108; +lean_dec(x_11); +lean_dec(x_7); +lean_dec(x_1); +x_108 = !lean_is_exclusive(x_18); +if (x_108 == 0) +{ +return x_18; +} +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_18, 0); +x_110 = lean_ctor_get(x_18, 1); +lean_inc(x_110); +lean_inc(x_109); +lean_dec(x_18); +x_111 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_111, 0, x_109); +lean_ctor_set(x_111, 1, x_110); +return x_111; +} +} +} +} +} +} +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__21(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; +x_5 = lean_nat_dec_lt(x_4, x_3); +if (x_5 == 0) +{ +uint8_t x_6; +lean_dec(x_4); +x_6 = 0; +return x_6; +} +else +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_fget(x_2, x_4); +x_8 = l_Lean_Expr_hasExprMVar(x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +x_9 = lean_unsigned_to_nat(1u); +x_10 = lean_nat_add(x_4, x_9); +lean_dec(x_4); +x_4 = x_10; +goto _start; +} +else +{ +lean_dec(x_4); +return x_8; +} +} +} +} +uint8_t l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__22(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_nat_dec_lt(x_5, x_4); +if (x_6 == 0) +{ +uint8_t x_7; +lean_dec(x_5); +x_7 = 0; +return x_7; +} +else +{ +lean_object* x_8; uint8_t x_9; +x_8 = lean_array_fget(x_3, x_5); +x_9 = l_Lean_Expr_hasExprMVar(x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +x_10 = lean_unsigned_to_nat(1u); +x_11 = lean_nat_add(x_5, x_10); +lean_dec(x_5); +x_2 = lean_box(0); +x_5 = x_11; +goto _start; +} +else +{ +lean_dec(x_5); +return x_9; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_5__toCtorWhenK___at_Lean_Meta_whnfImpl___main___spec__20(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +lean_inc(x_3); +x_5 = l_Lean_Meta_inferType(x_2, x_3, x_4); +if (lean_obj_tag(x_5) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_5, 0); +lean_inc(x_6); +x_7 = lean_ctor_get(x_5, 1); +lean_inc(x_7); +lean_dec(x_5); +lean_inc(x_3); +x_8 = l_Lean_Meta_whnf(x_6, x_3, x_7); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; uint8_t x_14; +x_10 = lean_ctor_get(x_8, 0); +x_11 = lean_ctor_get(x_8, 1); +x_12 = l_Lean_Expr_getAppFn___main(x_10); +x_13 = l_Lean_RecursorVal_getInduct(x_1); +x_14 = l_Lean_Expr_isConstOf(x_12, x_13); +lean_dec(x_13); +lean_dec(x_12); +if (x_14 == 0) +{ +lean_object* x_15; +lean_dec(x_10); +lean_dec(x_3); +lean_dec(x_1); +x_15 = lean_box(0); +lean_ctor_set(x_8, 0, x_15); +return x_8; +} +else +{ +uint8_t x_16; +x_16 = l_Lean_Expr_hasExprMVar(x_10); +if (x_16 == 0) +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +lean_free_object(x_8); +x_17 = lean_ctor_get(x_1, 2); +lean_inc(x_17); +lean_dec(x_1); +x_18 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_19 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_18, x_10, x_17, x_3, x_11); +lean_dec(x_17); +if (lean_obj_tag(x_19) == 0) +{ +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); +lean_inc(x_20); +if (lean_obj_tag(x_20) == 0) +{ +uint8_t x_21; +lean_dec(x_10); +lean_dec(x_3); +x_21 = !lean_is_exclusive(x_19); +if (x_21 == 0) +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_19, 0); +lean_dec(x_22); +return x_19; +} +else +{ +lean_object* x_23; lean_object* x_24; +x_23 = lean_ctor_get(x_19, 1); +lean_inc(x_23); +lean_dec(x_19); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_20); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +else +{ +lean_object* x_25; uint8_t x_26; +x_25 = lean_ctor_get(x_19, 1); +lean_inc(x_25); +lean_dec(x_19); +x_26 = !lean_is_exclusive(x_20); +if (x_26 == 0) +{ +lean_object* x_27; lean_object* x_28; +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_3); +lean_inc(x_27); +x_28 = l_Lean_Meta_inferType(x_27, x_3, x_25); +if (lean_obj_tag(x_28) == 0) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_28, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_28, 1); +lean_inc(x_30); +lean_dec(x_28); +x_31 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_10, x_29, x_3, x_30); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; uint8_t x_33; +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_unbox(x_32); +lean_dec(x_32); +if (x_33 == 0) +{ +uint8_t x_34; +lean_free_object(x_20); +lean_dec(x_27); +x_34 = !lean_is_exclusive(x_31); +if (x_34 == 0) +{ +lean_object* x_35; lean_object* x_36; +x_35 = lean_ctor_get(x_31, 0); +lean_dec(x_35); +x_36 = lean_box(0); +lean_ctor_set(x_31, 0, x_36); +return x_31; +} +else +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; +x_37 = lean_ctor_get(x_31, 1); +lean_inc(x_37); +lean_dec(x_31); +x_38 = lean_box(0); +x_39 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_39, 0, x_38); +lean_ctor_set(x_39, 1, x_37); +return x_39; +} +} +else +{ +uint8_t x_40; +x_40 = !lean_is_exclusive(x_31); +if (x_40 == 0) +{ +lean_object* x_41; +x_41 = lean_ctor_get(x_31, 0); +lean_dec(x_41); +lean_ctor_set(x_31, 0, x_20); +return x_31; +} +else +{ +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_31, 1); +lean_inc(x_42); +lean_dec(x_31); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_20); +lean_ctor_set(x_43, 1, x_42); +return x_43; +} +} +} +else +{ +uint8_t x_44; +lean_free_object(x_20); +lean_dec(x_27); +x_44 = !lean_is_exclusive(x_31); +if (x_44 == 0) +{ +return x_31; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_31, 0); +x_46 = lean_ctor_get(x_31, 1); +lean_inc(x_46); +lean_inc(x_45); +lean_dec(x_31); +x_47 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_47, 0, x_45); +lean_ctor_set(x_47, 1, x_46); +return x_47; +} +} +} +else +{ +uint8_t x_48; +lean_free_object(x_20); +lean_dec(x_27); +lean_dec(x_10); +lean_dec(x_3); +x_48 = !lean_is_exclusive(x_28); +if (x_48 == 0) +{ +return x_28; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_28, 0); +x_50 = lean_ctor_get(x_28, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_28); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +else +{ +lean_object* x_52; lean_object* x_53; +x_52 = lean_ctor_get(x_20, 0); +lean_inc(x_52); +lean_dec(x_20); +lean_inc(x_3); +lean_inc(x_52); +x_53 = l_Lean_Meta_inferType(x_52, x_3, x_25); +if (lean_obj_tag(x_53) == 0) +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; +x_54 = lean_ctor_get(x_53, 0); +lean_inc(x_54); +x_55 = lean_ctor_get(x_53, 1); +lean_inc(x_55); +lean_dec(x_53); +x_56 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_10, x_54, x_3, x_55); +if (lean_obj_tag(x_56) == 0) +{ +lean_object* x_57; uint8_t x_58; +x_57 = lean_ctor_get(x_56, 0); +lean_inc(x_57); +x_58 = lean_unbox(x_57); +lean_dec(x_57); +if (x_58 == 0) +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; lean_object* x_62; +lean_dec(x_52); +x_59 = lean_ctor_get(x_56, 1); +lean_inc(x_59); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_60 = x_56; +} else { + lean_dec_ref(x_56); + x_60 = lean_box(0); +} +x_61 = lean_box(0); +if (lean_is_scalar(x_60)) { + x_62 = lean_alloc_ctor(0, 2, 0); +} else { + x_62 = x_60; +} +lean_ctor_set(x_62, 0, x_61); +lean_ctor_set(x_62, 1, x_59); +return x_62; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_63 = lean_ctor_get(x_56, 1); +lean_inc(x_63); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_64 = x_56; +} else { + lean_dec_ref(x_56); + x_64 = lean_box(0); +} +x_65 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_65, 0, x_52); +if (lean_is_scalar(x_64)) { + x_66 = lean_alloc_ctor(0, 2, 0); +} else { + x_66 = x_64; +} +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_63); +return x_66; +} +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; +lean_dec(x_52); +x_67 = lean_ctor_get(x_56, 0); +lean_inc(x_67); +x_68 = lean_ctor_get(x_56, 1); +lean_inc(x_68); +if (lean_is_exclusive(x_56)) { + lean_ctor_release(x_56, 0); + lean_ctor_release(x_56, 1); + x_69 = x_56; +} else { + lean_dec_ref(x_56); + x_69 = lean_box(0); +} +if (lean_is_scalar(x_69)) { + x_70 = lean_alloc_ctor(1, 2, 0); +} else { + x_70 = x_69; +} +lean_ctor_set(x_70, 0, x_67); +lean_ctor_set(x_70, 1, x_68); +return x_70; +} +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +lean_dec(x_52); +lean_dec(x_10); +lean_dec(x_3); +x_71 = lean_ctor_get(x_53, 0); +lean_inc(x_71); +x_72 = lean_ctor_get(x_53, 1); +lean_inc(x_72); +if (lean_is_exclusive(x_53)) { + lean_ctor_release(x_53, 0); + lean_ctor_release(x_53, 1); + x_73 = x_53; +} else { + lean_dec_ref(x_53); + x_73 = lean_box(0); +} +if (lean_is_scalar(x_73)) { + x_74 = lean_alloc_ctor(1, 2, 0); +} else { + x_74 = x_73; +} +lean_ctor_set(x_74, 0, x_71); +lean_ctor_set(x_74, 1, x_72); +return x_74; +} +} +} +} +else +{ +uint8_t x_75; +lean_dec(x_10); +lean_dec(x_3); +x_75 = !lean_is_exclusive(x_19); +if (x_75 == 0) +{ +return x_19; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_19, 0); +x_77 = lean_ctor_get(x_19, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_19); +x_78 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_78, 0, x_76); +lean_ctor_set(x_78, 1, x_77); +return x_78; +} +} +} +else +{ +lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; uint8_t x_88; +x_79 = lean_unsigned_to_nat(0u); +x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_10, x_79); +x_81 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_80); +x_82 = lean_mk_array(x_80, x_81); +x_83 = lean_unsigned_to_nat(1u); +x_84 = lean_nat_sub(x_80, x_83); +lean_dec(x_80); +lean_inc(x_10); +x_85 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_10, x_82, x_84); +x_86 = lean_ctor_get(x_1, 2); +lean_inc(x_86); +lean_dec(x_1); +x_87 = lean_array_get_size(x_85); +x_88 = lean_nat_dec_le(x_87, x_87); +if (x_88 == 0) +{ +uint8_t x_89; +lean_inc(x_86); +x_89 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__21(x_10, x_85, x_87, x_86); +lean_dec(x_87); +lean_dec(x_85); +if (x_89 == 0) +{ +lean_object* x_90; lean_object* x_91; +lean_free_object(x_8); +x_90 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_91 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_90, x_10, x_86, x_3, x_11); +lean_dec(x_86); +if (lean_obj_tag(x_91) == 0) +{ +lean_object* x_92; +x_92 = lean_ctor_get(x_91, 0); +lean_inc(x_92); +if (lean_obj_tag(x_92) == 0) +{ +uint8_t x_93; +lean_dec(x_10); +lean_dec(x_3); +x_93 = !lean_is_exclusive(x_91); +if (x_93 == 0) +{ +lean_object* x_94; +x_94 = lean_ctor_get(x_91, 0); +lean_dec(x_94); +return x_91; +} +else +{ +lean_object* x_95; lean_object* x_96; +x_95 = lean_ctor_get(x_91, 1); +lean_inc(x_95); +lean_dec(x_91); +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_92); +lean_ctor_set(x_96, 1, x_95); +return x_96; +} +} +else +{ +lean_object* x_97; uint8_t x_98; +x_97 = lean_ctor_get(x_91, 1); +lean_inc(x_97); +lean_dec(x_91); +x_98 = !lean_is_exclusive(x_92); +if (x_98 == 0) +{ +lean_object* x_99; lean_object* x_100; +x_99 = lean_ctor_get(x_92, 0); +lean_inc(x_3); +lean_inc(x_99); +x_100 = l_Lean_Meta_inferType(x_99, x_3, x_97); +if (lean_obj_tag(x_100) == 0) +{ +lean_object* x_101; lean_object* x_102; lean_object* x_103; +x_101 = lean_ctor_get(x_100, 0); +lean_inc(x_101); +x_102 = lean_ctor_get(x_100, 1); +lean_inc(x_102); +lean_dec(x_100); +x_103 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_10, x_101, x_3, x_102); +if (lean_obj_tag(x_103) == 0) +{ +lean_object* x_104; uint8_t x_105; +x_104 = lean_ctor_get(x_103, 0); +lean_inc(x_104); +x_105 = lean_unbox(x_104); +lean_dec(x_104); +if (x_105 == 0) +{ +uint8_t x_106; +lean_free_object(x_92); +lean_dec(x_99); +x_106 = !lean_is_exclusive(x_103); +if (x_106 == 0) +{ +lean_object* x_107; lean_object* x_108; +x_107 = lean_ctor_get(x_103, 0); +lean_dec(x_107); +x_108 = lean_box(0); +lean_ctor_set(x_103, 0, x_108); +return x_103; +} +else +{ +lean_object* x_109; lean_object* x_110; lean_object* x_111; +x_109 = lean_ctor_get(x_103, 1); +lean_inc(x_109); +lean_dec(x_103); +x_110 = lean_box(0); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_110); +lean_ctor_set(x_111, 1, x_109); +return x_111; +} +} +else +{ +uint8_t x_112; +x_112 = !lean_is_exclusive(x_103); +if (x_112 == 0) +{ +lean_object* x_113; +x_113 = lean_ctor_get(x_103, 0); +lean_dec(x_113); +lean_ctor_set(x_103, 0, x_92); +return x_103; +} +else +{ +lean_object* x_114; lean_object* x_115; +x_114 = lean_ctor_get(x_103, 1); +lean_inc(x_114); +lean_dec(x_103); +x_115 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_115, 0, x_92); +lean_ctor_set(x_115, 1, x_114); +return x_115; +} +} +} +else +{ +uint8_t x_116; +lean_free_object(x_92); +lean_dec(x_99); +x_116 = !lean_is_exclusive(x_103); +if (x_116 == 0) +{ +return x_103; +} +else +{ +lean_object* x_117; lean_object* x_118; lean_object* x_119; +x_117 = lean_ctor_get(x_103, 0); +x_118 = lean_ctor_get(x_103, 1); +lean_inc(x_118); +lean_inc(x_117); +lean_dec(x_103); +x_119 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_119, 0, x_117); +lean_ctor_set(x_119, 1, x_118); +return x_119; +} +} +} +else +{ +uint8_t x_120; +lean_free_object(x_92); +lean_dec(x_99); +lean_dec(x_10); +lean_dec(x_3); +x_120 = !lean_is_exclusive(x_100); +if (x_120 == 0) +{ +return x_100; +} +else +{ +lean_object* x_121; lean_object* x_122; lean_object* x_123; +x_121 = lean_ctor_get(x_100, 0); +x_122 = lean_ctor_get(x_100, 1); +lean_inc(x_122); +lean_inc(x_121); +lean_dec(x_100); +x_123 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_123, 0, x_121); +lean_ctor_set(x_123, 1, x_122); +return x_123; +} +} +} +else +{ +lean_object* x_124; lean_object* x_125; +x_124 = lean_ctor_get(x_92, 0); +lean_inc(x_124); +lean_dec(x_92); +lean_inc(x_3); +lean_inc(x_124); +x_125 = l_Lean_Meta_inferType(x_124, x_3, x_97); +if (lean_obj_tag(x_125) == 0) +{ +lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_ctor_get(x_125, 1); +lean_inc(x_127); +lean_dec(x_125); +x_128 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_10, x_126, x_3, x_127); +if (lean_obj_tag(x_128) == 0) +{ +lean_object* x_129; uint8_t x_130; +x_129 = lean_ctor_get(x_128, 0); +lean_inc(x_129); +x_130 = lean_unbox(x_129); +lean_dec(x_129); +if (x_130 == 0) +{ +lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +lean_dec(x_124); +x_131 = lean_ctor_get(x_128, 1); +lean_inc(x_131); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_132 = x_128; +} else { + lean_dec_ref(x_128); + x_132 = lean_box(0); +} +x_133 = lean_box(0); +if (lean_is_scalar(x_132)) { + x_134 = lean_alloc_ctor(0, 2, 0); +} else { + x_134 = x_132; +} +lean_ctor_set(x_134, 0, x_133); +lean_ctor_set(x_134, 1, x_131); +return x_134; +} +else +{ +lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_135 = lean_ctor_get(x_128, 1); +lean_inc(x_135); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_136 = x_128; +} else { + lean_dec_ref(x_128); + x_136 = lean_box(0); +} +x_137 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_137, 0, x_124); +if (lean_is_scalar(x_136)) { + x_138 = lean_alloc_ctor(0, 2, 0); +} else { + x_138 = x_136; +} +lean_ctor_set(x_138, 0, x_137); +lean_ctor_set(x_138, 1, x_135); +return x_138; +} +} +else +{ +lean_object* x_139; lean_object* x_140; lean_object* x_141; lean_object* x_142; +lean_dec(x_124); +x_139 = lean_ctor_get(x_128, 0); +lean_inc(x_139); +x_140 = lean_ctor_get(x_128, 1); +lean_inc(x_140); +if (lean_is_exclusive(x_128)) { + lean_ctor_release(x_128, 0); + lean_ctor_release(x_128, 1); + x_141 = x_128; +} else { + lean_dec_ref(x_128); + x_141 = lean_box(0); +} +if (lean_is_scalar(x_141)) { + x_142 = lean_alloc_ctor(1, 2, 0); +} else { + x_142 = x_141; +} +lean_ctor_set(x_142, 0, x_139); +lean_ctor_set(x_142, 1, x_140); +return x_142; +} +} +else +{ +lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; +lean_dec(x_124); +lean_dec(x_10); +lean_dec(x_3); +x_143 = lean_ctor_get(x_125, 0); +lean_inc(x_143); +x_144 = lean_ctor_get(x_125, 1); +lean_inc(x_144); +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_145 = x_125; +} else { + lean_dec_ref(x_125); + x_145 = lean_box(0); +} +if (lean_is_scalar(x_145)) { + x_146 = lean_alloc_ctor(1, 2, 0); +} else { + x_146 = x_145; +} +lean_ctor_set(x_146, 0, x_143); +lean_ctor_set(x_146, 1, x_144); +return x_146; +} +} +} +} +else +{ +uint8_t x_147; +lean_dec(x_10); +lean_dec(x_3); +x_147 = !lean_is_exclusive(x_91); +if (x_147 == 0) +{ +return x_91; +} +else +{ +lean_object* x_148; lean_object* x_149; lean_object* x_150; +x_148 = lean_ctor_get(x_91, 0); +x_149 = lean_ctor_get(x_91, 1); +lean_inc(x_149); +lean_inc(x_148); +lean_dec(x_91); +x_150 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_150, 0, x_148); +lean_ctor_set(x_150, 1, x_149); +return x_150; +} +} +} +else +{ +lean_object* x_151; +lean_dec(x_86); +lean_dec(x_10); +lean_dec(x_3); +x_151 = lean_box(0); +lean_ctor_set(x_8, 0, x_151); +return x_8; +} +} +else +{ +uint8_t x_152; +lean_inc(x_86); +x_152 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__22(x_10, lean_box(0), x_85, x_87, x_86); +lean_dec(x_87); +lean_dec(x_85); +if (x_152 == 0) +{ +lean_object* x_153; lean_object* x_154; +lean_free_object(x_8); +x_153 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_10); +x_154 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_153, x_10, x_86, x_3, x_11); +lean_dec(x_86); +if (lean_obj_tag(x_154) == 0) +{ +lean_object* x_155; +x_155 = lean_ctor_get(x_154, 0); +lean_inc(x_155); +if (lean_obj_tag(x_155) == 0) +{ +uint8_t x_156; +lean_dec(x_10); +lean_dec(x_3); +x_156 = !lean_is_exclusive(x_154); +if (x_156 == 0) +{ +lean_object* x_157; +x_157 = lean_ctor_get(x_154, 0); +lean_dec(x_157); +return x_154; +} +else +{ +lean_object* x_158; lean_object* x_159; +x_158 = lean_ctor_get(x_154, 1); +lean_inc(x_158); +lean_dec(x_154); +x_159 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_159, 0, x_155); +lean_ctor_set(x_159, 1, x_158); +return x_159; +} +} +else +{ +lean_object* x_160; uint8_t x_161; +x_160 = lean_ctor_get(x_154, 1); +lean_inc(x_160); +lean_dec(x_154); +x_161 = !lean_is_exclusive(x_155); +if (x_161 == 0) +{ +lean_object* x_162; lean_object* x_163; +x_162 = lean_ctor_get(x_155, 0); +lean_inc(x_3); +lean_inc(x_162); +x_163 = l_Lean_Meta_inferType(x_162, x_3, x_160); +if (lean_obj_tag(x_163) == 0) +{ +lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_164 = lean_ctor_get(x_163, 0); +lean_inc(x_164); +x_165 = lean_ctor_get(x_163, 1); +lean_inc(x_165); +lean_dec(x_163); +x_166 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_10, x_164, x_3, x_165); +if (lean_obj_tag(x_166) == 0) +{ +lean_object* x_167; uint8_t x_168; +x_167 = lean_ctor_get(x_166, 0); +lean_inc(x_167); +x_168 = lean_unbox(x_167); +lean_dec(x_167); +if (x_168 == 0) +{ +uint8_t x_169; +lean_free_object(x_155); +lean_dec(x_162); +x_169 = !lean_is_exclusive(x_166); +if (x_169 == 0) +{ +lean_object* x_170; lean_object* x_171; +x_170 = lean_ctor_get(x_166, 0); +lean_dec(x_170); +x_171 = lean_box(0); +lean_ctor_set(x_166, 0, x_171); +return x_166; +} +else +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_166, 1); +lean_inc(x_172); +lean_dec(x_166); +x_173 = lean_box(0); +x_174 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_174, 0, x_173); +lean_ctor_set(x_174, 1, x_172); +return x_174; +} +} +else +{ +uint8_t x_175; +x_175 = !lean_is_exclusive(x_166); +if (x_175 == 0) +{ +lean_object* x_176; +x_176 = lean_ctor_get(x_166, 0); +lean_dec(x_176); +lean_ctor_set(x_166, 0, x_155); +return x_166; +} +else +{ +lean_object* x_177; lean_object* x_178; +x_177 = lean_ctor_get(x_166, 1); +lean_inc(x_177); +lean_dec(x_166); +x_178 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_178, 0, x_155); +lean_ctor_set(x_178, 1, x_177); +return x_178; +} +} +} +else +{ +uint8_t x_179; +lean_free_object(x_155); +lean_dec(x_162); +x_179 = !lean_is_exclusive(x_166); +if (x_179 == 0) +{ +return x_166; +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; +x_180 = lean_ctor_get(x_166, 0); +x_181 = lean_ctor_get(x_166, 1); +lean_inc(x_181); +lean_inc(x_180); +lean_dec(x_166); +x_182 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_182, 0, x_180); +lean_ctor_set(x_182, 1, x_181); +return x_182; +} +} +} +else +{ +uint8_t x_183; +lean_free_object(x_155); +lean_dec(x_162); +lean_dec(x_10); +lean_dec(x_3); +x_183 = !lean_is_exclusive(x_163); +if (x_183 == 0) +{ +return x_163; +} +else +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; +x_184 = lean_ctor_get(x_163, 0); +x_185 = lean_ctor_get(x_163, 1); +lean_inc(x_185); +lean_inc(x_184); +lean_dec(x_163); +x_186 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_186, 0, x_184); +lean_ctor_set(x_186, 1, x_185); +return x_186; +} +} +} +else +{ +lean_object* x_187; lean_object* x_188; +x_187 = lean_ctor_get(x_155, 0); +lean_inc(x_187); +lean_dec(x_155); +lean_inc(x_3); +lean_inc(x_187); +x_188 = l_Lean_Meta_inferType(x_187, x_3, x_160); +if (lean_obj_tag(x_188) == 0) +{ +lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_189 = lean_ctor_get(x_188, 0); +lean_inc(x_189); +x_190 = lean_ctor_get(x_188, 1); +lean_inc(x_190); +lean_dec(x_188); +x_191 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_10, x_189, x_3, x_190); +if (lean_obj_tag(x_191) == 0) +{ +lean_object* x_192; uint8_t x_193; +x_192 = lean_ctor_get(x_191, 0); +lean_inc(x_192); +x_193 = lean_unbox(x_192); +lean_dec(x_192); +if (x_193 == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; lean_object* x_197; +lean_dec(x_187); +x_194 = lean_ctor_get(x_191, 1); +lean_inc(x_194); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_195 = x_191; +} else { + lean_dec_ref(x_191); + x_195 = lean_box(0); +} +x_196 = lean_box(0); +if (lean_is_scalar(x_195)) { + x_197 = lean_alloc_ctor(0, 2, 0); +} else { + x_197 = x_195; +} +lean_ctor_set(x_197, 0, x_196); +lean_ctor_set(x_197, 1, x_194); +return x_197; +} +else +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; lean_object* x_201; +x_198 = lean_ctor_get(x_191, 1); +lean_inc(x_198); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_199 = x_191; +} else { + lean_dec_ref(x_191); + x_199 = lean_box(0); +} +x_200 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_200, 0, x_187); +if (lean_is_scalar(x_199)) { + x_201 = lean_alloc_ctor(0, 2, 0); +} else { + x_201 = x_199; +} +lean_ctor_set(x_201, 0, x_200); +lean_ctor_set(x_201, 1, x_198); +return x_201; +} +} +else +{ +lean_object* x_202; lean_object* x_203; lean_object* x_204; lean_object* x_205; +lean_dec(x_187); +x_202 = lean_ctor_get(x_191, 0); +lean_inc(x_202); +x_203 = lean_ctor_get(x_191, 1); +lean_inc(x_203); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_204 = x_191; +} else { + lean_dec_ref(x_191); + x_204 = lean_box(0); +} +if (lean_is_scalar(x_204)) { + x_205 = lean_alloc_ctor(1, 2, 0); +} else { + x_205 = x_204; +} +lean_ctor_set(x_205, 0, x_202); +lean_ctor_set(x_205, 1, x_203); +return x_205; +} +} +else +{ +lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +lean_dec(x_187); +lean_dec(x_10); +lean_dec(x_3); +x_206 = lean_ctor_get(x_188, 0); +lean_inc(x_206); +x_207 = lean_ctor_get(x_188, 1); +lean_inc(x_207); +if (lean_is_exclusive(x_188)) { + lean_ctor_release(x_188, 0); + lean_ctor_release(x_188, 1); + x_208 = x_188; +} else { + lean_dec_ref(x_188); + x_208 = lean_box(0); +} +if (lean_is_scalar(x_208)) { + x_209 = lean_alloc_ctor(1, 2, 0); +} else { + x_209 = x_208; +} +lean_ctor_set(x_209, 0, x_206); +lean_ctor_set(x_209, 1, x_207); +return x_209; +} +} +} +} +else +{ +uint8_t x_210; +lean_dec(x_10); +lean_dec(x_3); +x_210 = !lean_is_exclusive(x_154); +if (x_210 == 0) +{ +return x_154; +} +else +{ +lean_object* x_211; lean_object* x_212; lean_object* x_213; +x_211 = lean_ctor_get(x_154, 0); +x_212 = lean_ctor_get(x_154, 1); +lean_inc(x_212); +lean_inc(x_211); +lean_dec(x_154); +x_213 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_213, 0, x_211); +lean_ctor_set(x_213, 1, x_212); +return x_213; +} +} +} +else +{ +lean_object* x_214; +lean_dec(x_86); +lean_dec(x_10); +lean_dec(x_3); +x_214 = lean_box(0); +lean_ctor_set(x_8, 0, x_214); +return x_8; +} +} +} +} +} +else +{ +lean_object* x_215; lean_object* x_216; lean_object* x_217; lean_object* x_218; uint8_t x_219; +x_215 = lean_ctor_get(x_8, 0); +x_216 = lean_ctor_get(x_8, 1); +lean_inc(x_216); +lean_inc(x_215); +lean_dec(x_8); +x_217 = l_Lean_Expr_getAppFn___main(x_215); +x_218 = l_Lean_RecursorVal_getInduct(x_1); +x_219 = l_Lean_Expr_isConstOf(x_217, x_218); +lean_dec(x_218); +lean_dec(x_217); +if (x_219 == 0) +{ +lean_object* x_220; lean_object* x_221; +lean_dec(x_215); +lean_dec(x_3); +lean_dec(x_1); +x_220 = lean_box(0); +x_221 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_221, 0, x_220); +lean_ctor_set(x_221, 1, x_216); +return x_221; +} +else +{ +uint8_t x_222; +x_222 = l_Lean_Expr_hasExprMVar(x_215); +if (x_222 == 0) +{ +lean_object* x_223; lean_object* x_224; lean_object* x_225; +x_223 = lean_ctor_get(x_1, 2); +lean_inc(x_223); +lean_dec(x_1); +x_224 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_225 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_224, x_215, x_223, x_3, x_216); +lean_dec(x_223); +if (lean_obj_tag(x_225) == 0) +{ +lean_object* x_226; +x_226 = lean_ctor_get(x_225, 0); +lean_inc(x_226); +if (lean_obj_tag(x_226) == 0) +{ +lean_object* x_227; lean_object* x_228; lean_object* x_229; +lean_dec(x_215); +lean_dec(x_3); +x_227 = lean_ctor_get(x_225, 1); +lean_inc(x_227); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + x_228 = x_225; +} else { + lean_dec_ref(x_225); + x_228 = lean_box(0); +} +if (lean_is_scalar(x_228)) { + x_229 = lean_alloc_ctor(0, 2, 0); +} else { + x_229 = x_228; +} +lean_ctor_set(x_229, 0, x_226); +lean_ctor_set(x_229, 1, x_227); +return x_229; +} +else +{ +lean_object* x_230; lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_230 = lean_ctor_get(x_225, 1); +lean_inc(x_230); +lean_dec(x_225); +x_231 = lean_ctor_get(x_226, 0); +lean_inc(x_231); +if (lean_is_exclusive(x_226)) { + lean_ctor_release(x_226, 0); + x_232 = x_226; +} else { + lean_dec_ref(x_226); + x_232 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_231); +x_233 = l_Lean_Meta_inferType(x_231, x_3, x_230); +if (lean_obj_tag(x_233) == 0) +{ +lean_object* x_234; lean_object* x_235; lean_object* x_236; +x_234 = lean_ctor_get(x_233, 0); +lean_inc(x_234); +x_235 = lean_ctor_get(x_233, 1); +lean_inc(x_235); +lean_dec(x_233); +x_236 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_215, x_234, x_3, x_235); +if (lean_obj_tag(x_236) == 0) +{ +lean_object* x_237; uint8_t x_238; +x_237 = lean_ctor_get(x_236, 0); +lean_inc(x_237); +x_238 = lean_unbox(x_237); +lean_dec(x_237); +if (x_238 == 0) +{ +lean_object* x_239; lean_object* x_240; lean_object* x_241; lean_object* x_242; +lean_dec(x_232); +lean_dec(x_231); +x_239 = lean_ctor_get(x_236, 1); +lean_inc(x_239); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_240 = x_236; +} else { + lean_dec_ref(x_236); + x_240 = lean_box(0); +} +x_241 = lean_box(0); +if (lean_is_scalar(x_240)) { + x_242 = lean_alloc_ctor(0, 2, 0); +} else { + x_242 = x_240; +} +lean_ctor_set(x_242, 0, x_241); +lean_ctor_set(x_242, 1, x_239); +return x_242; +} +else +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; +x_243 = lean_ctor_get(x_236, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_244 = x_236; +} else { + lean_dec_ref(x_236); + x_244 = lean_box(0); +} +if (lean_is_scalar(x_232)) { + x_245 = lean_alloc_ctor(1, 1, 0); +} else { + x_245 = x_232; +} +lean_ctor_set(x_245, 0, x_231); +if (lean_is_scalar(x_244)) { + x_246 = lean_alloc_ctor(0, 2, 0); +} else { + x_246 = x_244; +} +lean_ctor_set(x_246, 0, x_245); +lean_ctor_set(x_246, 1, x_243); +return x_246; +} +} +else +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; +lean_dec(x_232); +lean_dec(x_231); +x_247 = lean_ctor_get(x_236, 0); +lean_inc(x_247); +x_248 = lean_ctor_get(x_236, 1); +lean_inc(x_248); +if (lean_is_exclusive(x_236)) { + lean_ctor_release(x_236, 0); + lean_ctor_release(x_236, 1); + x_249 = x_236; +} else { + lean_dec_ref(x_236); + x_249 = lean_box(0); +} +if (lean_is_scalar(x_249)) { + x_250 = lean_alloc_ctor(1, 2, 0); +} else { + x_250 = x_249; +} +lean_ctor_set(x_250, 0, x_247); +lean_ctor_set(x_250, 1, x_248); +return x_250; +} +} +else +{ +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; +lean_dec(x_232); +lean_dec(x_231); +lean_dec(x_215); +lean_dec(x_3); +x_251 = lean_ctor_get(x_233, 0); +lean_inc(x_251); +x_252 = lean_ctor_get(x_233, 1); +lean_inc(x_252); +if (lean_is_exclusive(x_233)) { + lean_ctor_release(x_233, 0); + lean_ctor_release(x_233, 1); + x_253 = x_233; +} else { + lean_dec_ref(x_233); + x_253 = lean_box(0); +} +if (lean_is_scalar(x_253)) { + x_254 = lean_alloc_ctor(1, 2, 0); +} else { + x_254 = x_253; +} +lean_ctor_set(x_254, 0, x_251); +lean_ctor_set(x_254, 1, x_252); +return x_254; +} +} +} +else +{ +lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +lean_dec(x_215); +lean_dec(x_3); +x_255 = lean_ctor_get(x_225, 0); +lean_inc(x_255); +x_256 = lean_ctor_get(x_225, 1); +lean_inc(x_256); +if (lean_is_exclusive(x_225)) { + lean_ctor_release(x_225, 0); + lean_ctor_release(x_225, 1); + x_257 = x_225; +} else { + lean_dec_ref(x_225); + x_257 = lean_box(0); +} +if (lean_is_scalar(x_257)) { + x_258 = lean_alloc_ctor(1, 2, 0); +} else { + x_258 = x_257; +} +lean_ctor_set(x_258, 0, x_255); +lean_ctor_set(x_258, 1, x_256); +return x_258; +} +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; uint8_t x_268; +x_259 = lean_unsigned_to_nat(0u); +x_260 = l_Lean_Expr_getAppNumArgsAux___main(x_215, x_259); +x_261 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_260); +x_262 = lean_mk_array(x_260, x_261); +x_263 = lean_unsigned_to_nat(1u); +x_264 = lean_nat_sub(x_260, x_263); +lean_dec(x_260); +lean_inc(x_215); +x_265 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_215, x_262, x_264); +x_266 = lean_ctor_get(x_1, 2); +lean_inc(x_266); +lean_dec(x_1); +x_267 = lean_array_get_size(x_265); +x_268 = lean_nat_dec_le(x_267, x_267); +if (x_268 == 0) +{ +uint8_t x_269; +lean_inc(x_266); +x_269 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__21(x_215, x_265, x_267, x_266); +lean_dec(x_267); +lean_dec(x_265); +if (x_269 == 0) +{ +lean_object* x_270; lean_object* x_271; +x_270 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_271 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_270, x_215, x_266, x_3, x_216); +lean_dec(x_266); +if (lean_obj_tag(x_271) == 0) +{ +lean_object* x_272; +x_272 = lean_ctor_get(x_271, 0); +lean_inc(x_272); +if (lean_obj_tag(x_272) == 0) +{ +lean_object* x_273; lean_object* x_274; lean_object* x_275; +lean_dec(x_215); +lean_dec(x_3); +x_273 = lean_ctor_get(x_271, 1); +lean_inc(x_273); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + x_274 = x_271; +} else { + lean_dec_ref(x_271); + x_274 = lean_box(0); +} +if (lean_is_scalar(x_274)) { + x_275 = lean_alloc_ctor(0, 2, 0); +} else { + x_275 = x_274; +} +lean_ctor_set(x_275, 0, x_272); +lean_ctor_set(x_275, 1, x_273); +return x_275; +} +else +{ +lean_object* x_276; lean_object* x_277; lean_object* x_278; lean_object* x_279; +x_276 = lean_ctor_get(x_271, 1); +lean_inc(x_276); +lean_dec(x_271); +x_277 = lean_ctor_get(x_272, 0); +lean_inc(x_277); +if (lean_is_exclusive(x_272)) { + lean_ctor_release(x_272, 0); + x_278 = x_272; +} else { + lean_dec_ref(x_272); + x_278 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_277); +x_279 = l_Lean_Meta_inferType(x_277, x_3, x_276); +if (lean_obj_tag(x_279) == 0) +{ +lean_object* x_280; lean_object* x_281; lean_object* x_282; +x_280 = lean_ctor_get(x_279, 0); +lean_inc(x_280); +x_281 = lean_ctor_get(x_279, 1); +lean_inc(x_281); +lean_dec(x_279); +x_282 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_215, x_280, x_3, x_281); +if (lean_obj_tag(x_282) == 0) +{ +lean_object* x_283; uint8_t x_284; +x_283 = lean_ctor_get(x_282, 0); +lean_inc(x_283); +x_284 = lean_unbox(x_283); +lean_dec(x_283); +if (x_284 == 0) +{ +lean_object* x_285; lean_object* x_286; lean_object* x_287; lean_object* x_288; +lean_dec(x_278); +lean_dec(x_277); +x_285 = lean_ctor_get(x_282, 1); +lean_inc(x_285); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_286 = x_282; +} else { + lean_dec_ref(x_282); + x_286 = lean_box(0); +} +x_287 = lean_box(0); +if (lean_is_scalar(x_286)) { + x_288 = lean_alloc_ctor(0, 2, 0); +} else { + x_288 = x_286; +} +lean_ctor_set(x_288, 0, x_287); +lean_ctor_set(x_288, 1, x_285); +return x_288; +} +else +{ +lean_object* x_289; lean_object* x_290; lean_object* x_291; lean_object* x_292; +x_289 = lean_ctor_get(x_282, 1); +lean_inc(x_289); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_290 = x_282; +} else { + lean_dec_ref(x_282); + x_290 = lean_box(0); +} +if (lean_is_scalar(x_278)) { + x_291 = lean_alloc_ctor(1, 1, 0); +} else { + x_291 = x_278; +} +lean_ctor_set(x_291, 0, x_277); +if (lean_is_scalar(x_290)) { + x_292 = lean_alloc_ctor(0, 2, 0); +} else { + x_292 = x_290; +} +lean_ctor_set(x_292, 0, x_291); +lean_ctor_set(x_292, 1, x_289); +return x_292; +} +} +else +{ +lean_object* x_293; lean_object* x_294; lean_object* x_295; lean_object* x_296; +lean_dec(x_278); +lean_dec(x_277); +x_293 = lean_ctor_get(x_282, 0); +lean_inc(x_293); +x_294 = lean_ctor_get(x_282, 1); +lean_inc(x_294); +if (lean_is_exclusive(x_282)) { + lean_ctor_release(x_282, 0); + lean_ctor_release(x_282, 1); + x_295 = x_282; +} else { + lean_dec_ref(x_282); + x_295 = lean_box(0); +} +if (lean_is_scalar(x_295)) { + x_296 = lean_alloc_ctor(1, 2, 0); +} else { + x_296 = x_295; +} +lean_ctor_set(x_296, 0, x_293); +lean_ctor_set(x_296, 1, x_294); +return x_296; +} +} +else +{ +lean_object* x_297; lean_object* x_298; lean_object* x_299; lean_object* x_300; +lean_dec(x_278); +lean_dec(x_277); +lean_dec(x_215); +lean_dec(x_3); +x_297 = lean_ctor_get(x_279, 0); +lean_inc(x_297); +x_298 = lean_ctor_get(x_279, 1); +lean_inc(x_298); +if (lean_is_exclusive(x_279)) { + lean_ctor_release(x_279, 0); + lean_ctor_release(x_279, 1); + x_299 = x_279; +} else { + lean_dec_ref(x_279); + x_299 = lean_box(0); +} +if (lean_is_scalar(x_299)) { + x_300 = lean_alloc_ctor(1, 2, 0); +} else { + x_300 = x_299; +} +lean_ctor_set(x_300, 0, x_297); +lean_ctor_set(x_300, 1, x_298); +return x_300; +} +} +} +else +{ +lean_object* x_301; lean_object* x_302; lean_object* x_303; lean_object* x_304; +lean_dec(x_215); +lean_dec(x_3); +x_301 = lean_ctor_get(x_271, 0); +lean_inc(x_301); +x_302 = lean_ctor_get(x_271, 1); +lean_inc(x_302); +if (lean_is_exclusive(x_271)) { + lean_ctor_release(x_271, 0); + lean_ctor_release(x_271, 1); + x_303 = x_271; +} else { + lean_dec_ref(x_271); + x_303 = lean_box(0); +} +if (lean_is_scalar(x_303)) { + x_304 = lean_alloc_ctor(1, 2, 0); +} else { + x_304 = x_303; +} +lean_ctor_set(x_304, 0, x_301); +lean_ctor_set(x_304, 1, x_302); +return x_304; +} +} +else +{ +lean_object* x_305; lean_object* x_306; +lean_dec(x_266); +lean_dec(x_215); +lean_dec(x_3); +x_305 = lean_box(0); +x_306 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_306, 0, x_305); +lean_ctor_set(x_306, 1, x_216); +return x_306; +} +} +else +{ +uint8_t x_307; +lean_inc(x_266); +x_307 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__22(x_215, lean_box(0), x_265, x_267, x_266); +lean_dec(x_267); +lean_dec(x_265); +if (x_307 == 0) +{ +lean_object* x_308; lean_object* x_309; +x_308 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2; +lean_inc(x_3); +lean_inc(x_215); +x_309 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_308, x_215, x_266, x_3, x_216); +lean_dec(x_266); +if (lean_obj_tag(x_309) == 0) +{ +lean_object* x_310; +x_310 = lean_ctor_get(x_309, 0); +lean_inc(x_310); +if (lean_obj_tag(x_310) == 0) +{ +lean_object* x_311; lean_object* x_312; lean_object* x_313; +lean_dec(x_215); +lean_dec(x_3); +x_311 = lean_ctor_get(x_309, 1); +lean_inc(x_311); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_312 = x_309; +} else { + lean_dec_ref(x_309); + x_312 = lean_box(0); +} +if (lean_is_scalar(x_312)) { + x_313 = lean_alloc_ctor(0, 2, 0); +} else { + x_313 = x_312; +} +lean_ctor_set(x_313, 0, x_310); +lean_ctor_set(x_313, 1, x_311); +return x_313; +} +else +{ +lean_object* x_314; lean_object* x_315; lean_object* x_316; lean_object* x_317; +x_314 = lean_ctor_get(x_309, 1); +lean_inc(x_314); +lean_dec(x_309); +x_315 = lean_ctor_get(x_310, 0); +lean_inc(x_315); +if (lean_is_exclusive(x_310)) { + lean_ctor_release(x_310, 0); + x_316 = x_310; +} else { + lean_dec_ref(x_310); + x_316 = lean_box(0); +} +lean_inc(x_3); +lean_inc(x_315); +x_317 = l_Lean_Meta_inferType(x_315, x_3, x_314); +if (lean_obj_tag(x_317) == 0) +{ +lean_object* x_318; lean_object* x_319; lean_object* x_320; +x_318 = lean_ctor_get(x_317, 0); +lean_inc(x_318); +x_319 = lean_ctor_get(x_317, 1); +lean_inc(x_319); +lean_dec(x_317); +x_320 = l_Lean_Meta_try___at_Lean_Meta_isExprDefEq___spec__1(x_215, x_318, x_3, x_319); +if (lean_obj_tag(x_320) == 0) +{ +lean_object* x_321; uint8_t x_322; +x_321 = lean_ctor_get(x_320, 0); +lean_inc(x_321); +x_322 = lean_unbox(x_321); +lean_dec(x_321); +if (x_322 == 0) +{ +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; +lean_dec(x_316); +lean_dec(x_315); +x_323 = lean_ctor_get(x_320, 1); +lean_inc(x_323); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_324 = x_320; +} else { + lean_dec_ref(x_320); + x_324 = lean_box(0); +} +x_325 = lean_box(0); +if (lean_is_scalar(x_324)) { + x_326 = lean_alloc_ctor(0, 2, 0); +} else { + x_326 = x_324; +} +lean_ctor_set(x_326, 0, x_325); +lean_ctor_set(x_326, 1, x_323); +return x_326; +} +else +{ +lean_object* x_327; lean_object* x_328; lean_object* x_329; lean_object* x_330; +x_327 = lean_ctor_get(x_320, 1); +lean_inc(x_327); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_328 = x_320; +} else { + lean_dec_ref(x_320); + x_328 = lean_box(0); +} +if (lean_is_scalar(x_316)) { + x_329 = lean_alloc_ctor(1, 1, 0); +} else { + x_329 = x_316; +} +lean_ctor_set(x_329, 0, x_315); +if (lean_is_scalar(x_328)) { + x_330 = lean_alloc_ctor(0, 2, 0); +} else { + x_330 = x_328; +} +lean_ctor_set(x_330, 0, x_329); +lean_ctor_set(x_330, 1, x_327); +return x_330; +} +} +else +{ +lean_object* x_331; lean_object* x_332; lean_object* x_333; lean_object* x_334; +lean_dec(x_316); +lean_dec(x_315); +x_331 = lean_ctor_get(x_320, 0); +lean_inc(x_331); +x_332 = lean_ctor_get(x_320, 1); +lean_inc(x_332); +if (lean_is_exclusive(x_320)) { + lean_ctor_release(x_320, 0); + lean_ctor_release(x_320, 1); + x_333 = x_320; +} else { + lean_dec_ref(x_320); + x_333 = lean_box(0); +} +if (lean_is_scalar(x_333)) { + x_334 = lean_alloc_ctor(1, 2, 0); +} else { + x_334 = x_333; +} +lean_ctor_set(x_334, 0, x_331); +lean_ctor_set(x_334, 1, x_332); +return x_334; +} +} +else +{ +lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; +lean_dec(x_316); +lean_dec(x_315); +lean_dec(x_215); +lean_dec(x_3); +x_335 = lean_ctor_get(x_317, 0); +lean_inc(x_335); +x_336 = lean_ctor_get(x_317, 1); +lean_inc(x_336); +if (lean_is_exclusive(x_317)) { + lean_ctor_release(x_317, 0); + lean_ctor_release(x_317, 1); + x_337 = x_317; +} else { + lean_dec_ref(x_317); + x_337 = lean_box(0); +} +if (lean_is_scalar(x_337)) { + x_338 = lean_alloc_ctor(1, 2, 0); +} else { + x_338 = x_337; +} +lean_ctor_set(x_338, 0, x_335); +lean_ctor_set(x_338, 1, x_336); +return x_338; +} +} +} +else +{ +lean_object* x_339; lean_object* x_340; lean_object* x_341; lean_object* x_342; +lean_dec(x_215); +lean_dec(x_3); +x_339 = lean_ctor_get(x_309, 0); +lean_inc(x_339); +x_340 = lean_ctor_get(x_309, 1); +lean_inc(x_340); +if (lean_is_exclusive(x_309)) { + lean_ctor_release(x_309, 0); + lean_ctor_release(x_309, 1); + x_341 = x_309; +} else { + lean_dec_ref(x_309); + x_341 = lean_box(0); +} +if (lean_is_scalar(x_341)) { + x_342 = lean_alloc_ctor(1, 2, 0); +} else { + x_342 = x_341; +} +lean_ctor_set(x_342, 0, x_339); +lean_ctor_set(x_342, 1, x_340); +return x_342; +} +} +else +{ +lean_object* x_343; lean_object* x_344; +lean_dec(x_266); +lean_dec(x_215); +lean_dec(x_3); +x_343 = lean_box(0); +x_344 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_344, 0, x_343); +lean_ctor_set(x_344, 1, x_216); +return x_344; +} +} +} +} +} +} +else +{ +uint8_t x_345; +lean_dec(x_3); +lean_dec(x_1); +x_345 = !lean_is_exclusive(x_8); +if (x_345 == 0) +{ +return x_8; +} +else +{ +lean_object* x_346; lean_object* x_347; lean_object* x_348; +x_346 = lean_ctor_get(x_8, 0); +x_347 = lean_ctor_get(x_8, 1); +lean_inc(x_347); +lean_inc(x_346); +lean_dec(x_8); +x_348 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_348, 0, x_346); +lean_ctor_set(x_348, 1, x_347); +return x_348; +} +} +} +else +{ +uint8_t x_349; +lean_dec(x_3); +lean_dec(x_1); +x_349 = !lean_is_exclusive(x_5); +if (x_349 == 0) +{ +return x_5; +} +else +{ +lean_object* x_350; lean_object* x_351; lean_object* x_352; +x_350 = lean_ctor_get(x_5, 0); +x_351 = lean_ctor_get(x_5, 1); +lean_inc(x_351); +lean_inc(x_350); +lean_dec(x_5); +x_352 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_352, 0, x_350); +lean_ctor_set(x_352, 1, x_351); +return x_352; +} +} +} +} +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__19(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_9 = l_Lean_RecursorVal_getMajorIdx(x_4); +x_10 = lean_array_get_size(x_6); +x_11 = lean_nat_dec_lt(x_9, x_10); +if (x_11 == 0) +{ +uint8_t x_12; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_12 = lean_expr_eqv(x_2, x_3); +if (x_12 == 0) +{ +lean_object* x_13; lean_object* x_14; +x_13 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_14 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_14, 0, x_13); +lean_ctor_set(x_14, 1, x_8); +return x_14; +} +else +{ +lean_object* x_15; +x_15 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_15, 0, x_1); +lean_ctor_set(x_15, 1, x_8); +return x_15; +} +} +else +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_array_fget(x_6, x_9); +lean_inc(x_7); +x_17 = l_Lean_Meta_whnf(x_16, x_7, x_8); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; uint8_t x_62; +x_18 = lean_ctor_get(x_17, 0); +lean_inc(x_18); +x_19 = lean_ctor_get(x_17, 1); +lean_inc(x_19); +if (lean_is_exclusive(x_17)) { + lean_ctor_release(x_17, 0); + lean_ctor_release(x_17, 1); + x_20 = x_17; +} else { + lean_dec_ref(x_17); + x_20 = lean_box(0); +} +x_62 = lean_ctor_get_uint8(x_4, sizeof(void*)*7); +if (x_62 == 0) +{ +lean_object* x_63; lean_object* x_64; +lean_dec(x_20); +x_63 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_18); +lean_dec(x_18); +lean_inc(x_4); +x_64 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_63); +if (lean_obj_tag(x_64) == 0) +{ +uint8_t x_65; +lean_dec(x_63); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_65 = lean_expr_eqv(x_2, x_3); +if (x_65 == 0) +{ +lean_object* x_66; lean_object* x_67; +x_66 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_67 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_67, 0, x_66); +lean_ctor_set(x_67, 1, x_19); +return x_67; +} +else +{ +lean_object* x_68; +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_1); +lean_ctor_set(x_68, 1, x_19); +return x_68; +} +} +else +{ +lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; uint8_t x_81; +x_69 = lean_ctor_get(x_64, 0); +lean_inc(x_69); +lean_dec(x_64); +x_70 = lean_unsigned_to_nat(0u); +x_71 = l_Lean_Expr_getAppNumArgsAux___main(x_63, x_70); +x_72 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_71); +x_73 = lean_mk_array(x_71, x_72); +x_74 = lean_unsigned_to_nat(1u); +x_75 = lean_nat_sub(x_71, x_74); +lean_dec(x_71); +x_76 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_63, x_73, x_75); +x_77 = l_List_lengthAux___main___rarg(x_5, x_70); +x_78 = lean_ctor_get(x_4, 0); +lean_inc(x_78); +x_79 = lean_ctor_get(x_78, 1); +lean_inc(x_79); +lean_dec(x_78); +x_80 = l_List_lengthAux___main___rarg(x_79, x_70); +x_81 = lean_nat_dec_eq(x_77, x_80); +lean_dec(x_80); +lean_dec(x_77); +if (x_81 == 0) +{ +uint8_t x_82; +lean_dec(x_79); +lean_dec(x_76); +lean_dec(x_69); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_82 = lean_expr_eqv(x_2, x_3); +if (x_82 == 0) +{ +lean_object* x_83; lean_object* x_84; +x_83 = l_Lean_Expr_updateFn___main(x_1, x_3); +x_84 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_84, 0, x_83); +lean_ctor_set(x_84, 1, x_19); +return x_84; +} +else +{ +lean_object* x_85; +x_85 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_85, 0, x_1); +lean_ctor_set(x_85, 1, x_19); +return x_85; +} +} +else +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +lean_dec(x_1); +x_86 = lean_ctor_get(x_69, 2); +lean_inc(x_86); +x_87 = lean_instantiate_lparams(x_86, x_79, x_5); +x_88 = lean_ctor_get(x_4, 2); +lean_inc(x_88); +x_89 = lean_ctor_get(x_4, 4); +lean_inc(x_89); +x_90 = lean_nat_add(x_88, x_89); +lean_dec(x_89); +lean_dec(x_88); +x_91 = lean_ctor_get(x_4, 5); +lean_inc(x_91); +lean_dec(x_4); +x_92 = lean_nat_add(x_90, x_91); +lean_dec(x_91); +lean_dec(x_90); +x_93 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_92, x_6, x_70, x_87); +lean_dec(x_92); +x_94 = lean_array_get_size(x_76); +x_95 = lean_ctor_get(x_69, 1); +lean_inc(x_95); +lean_dec(x_69); +x_96 = lean_nat_sub(x_94, x_95); +lean_dec(x_95); +x_97 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_94, x_76, x_96, x_93); +lean_dec(x_76); +lean_dec(x_94); +x_98 = lean_nat_add(x_9, x_74); +lean_dec(x_9); +x_99 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_98, x_97); +lean_dec(x_10); +x_100 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_99, x_7, x_19); +return x_100; +} +} +} +else +{ +lean_object* x_101; +lean_inc(x_7); +lean_inc(x_18); +lean_inc(x_4); +x_101 = l___private_Init_Lean_WHNF_5__toCtorWhenK___at_Lean_Meta_whnfImpl___main___spec__20(x_4, x_18, x_7, x_19); +if (lean_obj_tag(x_101) == 0) +{ +lean_object* x_102; +x_102 = lean_ctor_get(x_101, 0); +lean_inc(x_102); +if (lean_obj_tag(x_102) == 0) +{ +lean_object* x_103; +x_103 = lean_ctor_get(x_101, 1); +lean_inc(x_103); +lean_dec(x_101); +x_21 = x_18; +x_22 = x_103; +goto block_61; +} +else +{ +lean_object* x_104; lean_object* x_105; +lean_dec(x_18); +x_104 = lean_ctor_get(x_101, 1); +lean_inc(x_104); +lean_dec(x_101); +x_105 = lean_ctor_get(x_102, 0); +lean_inc(x_105); +lean_dec(x_102); +x_21 = x_105; +x_22 = x_104; +goto block_61; +} +} +else +{ +uint8_t x_106; +lean_dec(x_20); +lean_dec(x_18); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_106 = !lean_is_exclusive(x_101); +if (x_106 == 0) +{ +return x_101; +} +else +{ +lean_object* x_107; lean_object* x_108; lean_object* x_109; +x_107 = lean_ctor_get(x_101, 0); +x_108 = lean_ctor_get(x_101, 1); +lean_inc(x_108); +lean_inc(x_107); +lean_dec(x_101); +x_109 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_109, 0, x_107); +lean_ctor_set(x_109, 1, x_108); +return x_109; +} +} +} +block_61: +{ +lean_object* x_23; lean_object* x_24; +x_23 = l___private_Init_Lean_WHNF_3__toCtorIfLit(x_21); +lean_dec(x_21); +lean_inc(x_4); +x_24 = l___private_Init_Lean_WHNF_4__getRecRuleFor(x_4, x_23); +if (lean_obj_tag(x_24) == 0) +{ +uint8_t x_25; +lean_dec(x_23); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_25 = lean_expr_eqv(x_2, x_3); +if (x_25 == 0) +{ +lean_object* x_26; lean_object* x_27; +x_26 = l_Lean_Expr_updateFn___main(x_1, x_3); +if (lean_is_scalar(x_20)) { + x_27 = lean_alloc_ctor(0, 2, 0); +} else { + x_27 = x_20; +} +lean_ctor_set(x_27, 0, x_26); +lean_ctor_set(x_27, 1, x_22); +return x_27; +} +else +{ +lean_object* x_28; +if (lean_is_scalar(x_20)) { + x_28 = lean_alloc_ctor(0, 2, 0); +} else { + x_28 = x_20; +} +lean_ctor_set(x_28, 0, x_1); +lean_ctor_set(x_28, 1, x_22); +return x_28; +} +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; uint8_t x_41; +x_29 = lean_ctor_get(x_24, 0); +lean_inc(x_29); +lean_dec(x_24); +x_30 = lean_unsigned_to_nat(0u); +x_31 = l_Lean_Expr_getAppNumArgsAux___main(x_23, x_30); +x_32 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_31); +x_33 = lean_mk_array(x_31, x_32); +x_34 = lean_unsigned_to_nat(1u); +x_35 = lean_nat_sub(x_31, x_34); +lean_dec(x_31); +x_36 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_23, x_33, x_35); +x_37 = l_List_lengthAux___main___rarg(x_5, x_30); +x_38 = lean_ctor_get(x_4, 0); +lean_inc(x_38); +x_39 = lean_ctor_get(x_38, 1); +lean_inc(x_39); +lean_dec(x_38); +x_40 = l_List_lengthAux___main___rarg(x_39, x_30); +x_41 = lean_nat_dec_eq(x_37, x_40); +lean_dec(x_40); +lean_dec(x_37); +if (x_41 == 0) +{ +uint8_t x_42; +lean_dec(x_39); +lean_dec(x_36); +lean_dec(x_29); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +x_42 = lean_expr_eqv(x_2, x_3); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = l_Lean_Expr_updateFn___main(x_1, x_3); +if (lean_is_scalar(x_20)) { + x_44 = lean_alloc_ctor(0, 2, 0); +} else { + x_44 = x_20; +} +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_22); +return x_44; +} +else +{ +lean_object* x_45; +if (lean_is_scalar(x_20)) { + x_45 = lean_alloc_ctor(0, 2, 0); +} else { + x_45 = x_20; +} +lean_ctor_set(x_45, 0, x_1); +lean_ctor_set(x_45, 1, x_22); +return x_45; +} +} +else +{ +lean_object* x_46; lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; lean_object* x_60; +lean_dec(x_20); +lean_dec(x_1); +x_46 = lean_ctor_get(x_29, 2); +lean_inc(x_46); +x_47 = lean_instantiate_lparams(x_46, x_39, x_5); +x_48 = lean_ctor_get(x_4, 2); +lean_inc(x_48); +x_49 = lean_ctor_get(x_4, 4); +lean_inc(x_49); +x_50 = lean_nat_add(x_48, x_49); +lean_dec(x_49); +lean_dec(x_48); +x_51 = lean_ctor_get(x_4, 5); +lean_inc(x_51); +lean_dec(x_4); +x_52 = lean_nat_add(x_50, x_51); +lean_dec(x_51); +lean_dec(x_50); +x_53 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_52, x_6, x_30, x_47); +lean_dec(x_52); +x_54 = lean_array_get_size(x_36); +x_55 = lean_ctor_get(x_29, 1); +lean_inc(x_55); +lean_dec(x_29); +x_56 = lean_nat_sub(x_54, x_55); +lean_dec(x_55); +x_57 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_54, x_36, x_56, x_53); +lean_dec(x_36); +lean_dec(x_54); +x_58 = lean_nat_add(x_9, x_34); +lean_dec(x_9); +x_59 = l___private_Init_Lean_Expr_2__mkAppRangeAux___main(x_10, x_6, x_58, x_57); +lean_dec(x_10); +x_60 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_59, x_7, x_22); +return x_60; +} +} +} +} +else +{ +uint8_t x_110; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_110 = !lean_is_exclusive(x_17); +if (x_110 == 0) +{ +return x_17; +} +else +{ +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_17, 0); +x_112 = lean_ctor_get(x_17, 1); +lean_inc(x_112); +lean_inc(x_111); +lean_dec(x_17); +x_113 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_113, 0, x_111); +lean_ctor_set(x_113, 1, x_112); +return x_113; +} +} +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__1(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_LocalDecl_value_x3f(x_3); +if (lean_obj_tag(x_6) == 0) +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; +x_7 = lean_ctor_get(x_1, 0); +lean_inc(x_7); +lean_dec(x_1); +x_8 = lean_ctor_get(x_7, 1); +lean_inc(x_8); +lean_dec(x_7); +x_9 = lean_apply_4(x_8, lean_box(0), x_2, x_4, x_5); +return x_9; +} +else +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_2); +x_10 = lean_ctor_get(x_6, 0); +lean_inc(x_10); +lean_dec(x_6); +x_11 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23(x_1, x_10, x_4, x_5); +return x_11; +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__2(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +if (lean_obj_tag(x_3) == 0) +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +lean_dec(x_1); +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_4, x_5); +return x_8; +} +else +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_2); +x_9 = lean_ctor_get(x_3, 0); +lean_inc(x_9); +lean_dec(x_3); +x_10 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23(x_1, x_9, x_4, x_5); +return x_10; +} +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +lean_object* x_5; +switch (lean_obj_tag(x_2)) { +case 0: +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; +lean_dec(x_2); +x_10 = l_Lean_Expr_Inhabited; +x_11 = l_monadInhabited___rarg(x_1, x_10); +x_12 = l_unreachable_x21___rarg(x_11); +x_13 = lean_apply_2(x_12, x_3, x_4); +return x_13; +} +case 1: +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_17; lean_object* x_18; +x_14 = lean_ctor_get(x_2, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_1, 1); +lean_inc(x_15); +x_16 = lean_alloc_closure((void*)(l_Lean_Meta_getLocalDecl), 3, 1); +lean_closure_set(x_16, 0, x_14); +x_17 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__1___boxed), 5, 2); +lean_closure_set(x_17, 0, x_1); +lean_closure_set(x_17, 1, x_2); +x_18 = lean_apply_6(x_15, lean_box(0), lean_box(0), x_16, x_17, x_3, x_4); +return x_18; +} +case 2: +{ +lean_object* x_19; lean_object* x_20; lean_object* x_21; lean_object* x_22; lean_object* x_23; +x_19 = lean_ctor_get(x_2, 0); +lean_inc(x_19); +x_20 = lean_ctor_get(x_1, 1); +lean_inc(x_20); +x_21 = lean_alloc_closure((void*)(l_Lean_Meta_getExprMVarAssignment___boxed), 3, 1); +lean_closure_set(x_21, 0, x_19); +x_22 = lean_alloc_closure((void*)(l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__2), 5, 2); +lean_closure_set(x_22, 0, x_1); +lean_closure_set(x_22, 1, x_2); +x_23 = lean_apply_6(x_20, lean_box(0), lean_box(0), x_21, x_22, x_3, x_4); +return x_23; +} +case 4: +{ +lean_object* x_24; +lean_dec(x_3); +lean_dec(x_1); +x_24 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_24, 0, x_2); +lean_ctor_set(x_24, 1, x_4); +return x_24; +} +case 5: +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +lean_dec(x_1); +x_25 = lean_ctor_get(x_2, 0); +lean_inc(x_25); +x_26 = l_Lean_Expr_getAppFn___main(x_25); +lean_dec(x_25); +lean_inc(x_3); +lean_inc(x_26); +x_27 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_26, x_3, x_4); +if (lean_obj_tag(x_27) == 0) +{ +uint8_t x_28; +x_28 = !lean_is_exclusive(x_27); +if (x_28 == 0) +{ +lean_object* x_29; lean_object* x_30; uint8_t x_31; +x_29 = lean_ctor_get(x_27, 0); +x_30 = lean_ctor_get(x_27, 1); +x_31 = l_Lean_Expr_isLambda(x_29); +if (x_31 == 0) +{ +if (lean_obj_tag(x_29) == 4) +{ +lean_object* x_32; lean_object* x_33; uint8_t x_34; lean_object* x_35; +lean_free_object(x_27); +x_32 = lean_ctor_get(x_29, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_29, 1); +lean_inc(x_33); +x_34 = 0; +x_35 = l_Lean_Meta_getConstAux(x_32, x_34, x_3, x_30); +if (lean_obj_tag(x_35) == 0) +{ +lean_object* x_36; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +if (lean_obj_tag(x_36) == 0) +{ +uint8_t x_37; +lean_dec(x_33); +lean_dec(x_3); +x_37 = !lean_is_exclusive(x_35); +if (x_37 == 0) +{ +lean_object* x_38; uint8_t x_39; +x_38 = lean_ctor_get(x_35, 0); +lean_dec(x_38); +x_39 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_39 == 0) +{ +lean_object* x_40; +x_40 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_40); +return x_35; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_2); +return x_35; +} +} +else +{ +lean_object* x_41; uint8_t x_42; +x_41 = lean_ctor_get(x_35, 1); +lean_inc(x_41); +lean_dec(x_35); +x_42 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_43); +lean_ctor_set(x_44, 1, x_41); +return x_44; +} +else +{ +lean_object* x_45; +lean_dec(x_29); +x_45 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_45, 0, x_2); +lean_ctor_set(x_45, 1, x_41); +return x_45; +} +} +} +else +{ +lean_object* x_46; +x_46 = lean_ctor_get(x_36, 0); +lean_inc(x_46); +lean_dec(x_36); +switch (lean_obj_tag(x_46)) { +case 1: +{ +lean_object* x_47; lean_object* x_48; lean_object* x_49; lean_object* x_50; uint8_t x_51; +x_47 = lean_ctor_get(x_35, 1); +lean_inc(x_47); +lean_dec(x_35); +x_48 = l_Lean_ConstantInfo_name(x_46); +x_49 = l_Lean_Meta_isAuxDef_x3f(x_48, x_3, x_47); +lean_dec(x_48); +x_50 = lean_ctor_get(x_49, 0); +lean_inc(x_50); +x_51 = lean_unbox(x_50); +lean_dec(x_50); +if (x_51 == 0) +{ +uint8_t x_52; +lean_dec(x_46); +lean_dec(x_33); +lean_dec(x_3); +x_52 = !lean_is_exclusive(x_49); +if (x_52 == 0) +{ +lean_object* x_53; uint8_t x_54; +x_53 = lean_ctor_get(x_49, 0); +lean_dec(x_53); +x_54 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_54 == 0) +{ +lean_object* x_55; +x_55 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_49, 0, x_55); +return x_49; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_49, 0, x_2); +return x_49; +} +} +else +{ +lean_object* x_56; uint8_t x_57; +x_56 = lean_ctor_get(x_49, 1); +lean_inc(x_56); +lean_dec(x_49); +x_57 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_57 == 0) +{ +lean_object* x_58; lean_object* x_59; +x_58 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_59 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_59, 0, x_58); +lean_ctor_set(x_59, 1, x_56); +return x_59; +} +else +{ +lean_object* x_60; +lean_dec(x_29); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_2); +lean_ctor_set(x_60, 1, x_56); +return x_60; +} +} +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_65; lean_object* x_66; +x_61 = lean_ctor_get(x_49, 1); +lean_inc(x_61); +lean_dec(x_49); +x_62 = lean_unsigned_to_nat(0u); +x_63 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_62); +x_64 = lean_mk_empty_array_with_capacity(x_63); +lean_dec(x_63); +lean_inc(x_2); +x_65 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_64); +x_66 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__17(x_2, x_26, x_29, x_46, x_33, x_65, x_3, x_61); +lean_dec(x_29); +lean_dec(x_26); +return x_66; +} +} +case 4: +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; +x_67 = lean_ctor_get(x_35, 1); +lean_inc(x_67); +lean_dec(x_35); +x_68 = lean_ctor_get(x_46, 0); +lean_inc(x_68); +lean_dec(x_46); +x_69 = lean_unsigned_to_nat(0u); +x_70 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_69); +x_71 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_70); +x_72 = lean_mk_array(x_70, x_71); +x_73 = lean_unsigned_to_nat(1u); +x_74 = lean_nat_sub(x_70, x_73); +lean_dec(x_70); +lean_inc(x_2); +x_75 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_72, x_74); +x_76 = l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__18(x_2, x_26, x_29, x_68, x_33, x_75, x_3, x_67); +lean_dec(x_75); +lean_dec(x_33); +lean_dec(x_68); +lean_dec(x_29); +lean_dec(x_26); +return x_76; +} +case 7: +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +x_77 = lean_ctor_get(x_35, 1); +lean_inc(x_77); +lean_dec(x_35); +x_78 = lean_ctor_get(x_46, 0); +lean_inc(x_78); +lean_dec(x_46); +x_79 = lean_unsigned_to_nat(0u); +x_80 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_79); +x_81 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_80); +x_82 = lean_mk_array(x_80, x_81); +x_83 = lean_unsigned_to_nat(1u); +x_84 = lean_nat_sub(x_80, x_83); +lean_dec(x_80); +lean_inc(x_2); +x_85 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_82, x_84); +x_86 = l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__19(x_2, x_26, x_29, x_78, x_33, x_85, x_3, x_77); +lean_dec(x_85); +lean_dec(x_29); +lean_dec(x_26); +return x_86; +} +default: +{ +uint8_t x_87; +lean_dec(x_46); +lean_dec(x_33); +lean_dec(x_3); +x_87 = !lean_is_exclusive(x_35); +if (x_87 == 0) +{ +lean_object* x_88; uint8_t x_89; +x_88 = lean_ctor_get(x_35, 0); +lean_dec(x_88); +x_89 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_89 == 0) +{ +lean_object* x_90; +x_90 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_90); +return x_35; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_35, 0, x_2); +return x_35; +} +} +else +{ +lean_object* x_91; uint8_t x_92; +x_91 = lean_ctor_get(x_35, 1); +lean_inc(x_91); +lean_dec(x_35); +x_92 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_92 == 0) +{ +lean_object* x_93; lean_object* x_94; +x_93 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +x_94 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_94, 0, x_93); +lean_ctor_set(x_94, 1, x_91); +return x_94; +} +else +{ +lean_object* x_95; +lean_dec(x_29); +x_95 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_95, 0, x_2); +lean_ctor_set(x_95, 1, x_91); +return x_95; +} +} +} +} +} +} +else +{ +uint8_t x_96; +lean_dec(x_33); +lean_dec(x_29); +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_96 = !lean_is_exclusive(x_35); +if (x_96 == 0) +{ +return x_35; +} +else +{ +lean_object* x_97; lean_object* x_98; lean_object* x_99; +x_97 = lean_ctor_get(x_35, 0); +x_98 = lean_ctor_get(x_35, 1); +lean_inc(x_98); +lean_inc(x_97); +lean_dec(x_35); +x_99 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_99, 0, x_97); +lean_ctor_set(x_99, 1, x_98); +return x_99; +} +} +} +else +{ +uint8_t x_100; +lean_dec(x_3); +x_100 = lean_expr_eqv(x_26, x_29); +lean_dec(x_26); +if (x_100 == 0) +{ +lean_object* x_101; +x_101 = l_Lean_Expr_updateFn___main(x_2, x_29); +lean_dec(x_29); +lean_ctor_set(x_27, 0, x_101); +return x_27; +} +else +{ +lean_dec(x_29); +lean_ctor_set(x_27, 0, x_2); +return x_27; +} +} +} +else +{ +lean_object* x_102; lean_object* x_103; lean_object* x_104; lean_object* x_105; lean_object* x_106; lean_object* x_107; +lean_free_object(x_27); +lean_dec(x_29); +x_102 = lean_unsigned_to_nat(0u); +x_103 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_102); +x_104 = lean_mk_empty_array_with_capacity(x_103); +lean_dec(x_103); +x_105 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_104); +x_106 = l_Lean_Expr_betaRev(x_26, x_105); +lean_dec(x_26); +x_107 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_106, x_3, x_30); +return x_107; +} +} +else +{ +lean_object* x_108; lean_object* x_109; uint8_t x_110; +x_108 = lean_ctor_get(x_27, 0); +x_109 = lean_ctor_get(x_27, 1); +lean_inc(x_109); +lean_inc(x_108); +lean_dec(x_27); +x_110 = l_Lean_Expr_isLambda(x_108); +if (x_110 == 0) +{ +if (lean_obj_tag(x_108) == 4) +{ +lean_object* x_111; lean_object* x_112; uint8_t x_113; lean_object* x_114; +x_111 = lean_ctor_get(x_108, 0); +lean_inc(x_111); +x_112 = lean_ctor_get(x_108, 1); +lean_inc(x_112); +x_113 = 0; +x_114 = l_Lean_Meta_getConstAux(x_111, x_113, x_3, x_109); +if (lean_obj_tag(x_114) == 0) +{ +lean_object* x_115; +x_115 = lean_ctor_get(x_114, 0); +lean_inc(x_115); +if (lean_obj_tag(x_115) == 0) +{ +lean_object* x_116; lean_object* x_117; uint8_t x_118; +lean_dec(x_112); +lean_dec(x_3); +x_116 = lean_ctor_get(x_114, 1); +lean_inc(x_116); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_117 = x_114; +} else { + lean_dec_ref(x_114); + x_117 = lean_box(0); +} +x_118 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_118 == 0) +{ +lean_object* x_119; lean_object* x_120; +x_119 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_117)) { + x_120 = lean_alloc_ctor(0, 2, 0); +} else { + x_120 = x_117; +} +lean_ctor_set(x_120, 0, x_119); +lean_ctor_set(x_120, 1, x_116); +return x_120; +} +else +{ +lean_object* x_121; +lean_dec(x_108); +if (lean_is_scalar(x_117)) { + x_121 = lean_alloc_ctor(0, 2, 0); +} else { + x_121 = x_117; +} +lean_ctor_set(x_121, 0, x_2); +lean_ctor_set(x_121, 1, x_116); +return x_121; +} +} +else +{ +lean_object* x_122; +x_122 = lean_ctor_get(x_115, 0); +lean_inc(x_122); +lean_dec(x_115); +switch (lean_obj_tag(x_122)) { +case 1: +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; uint8_t x_127; +x_123 = lean_ctor_get(x_114, 1); +lean_inc(x_123); +lean_dec(x_114); +x_124 = l_Lean_ConstantInfo_name(x_122); +x_125 = l_Lean_Meta_isAuxDef_x3f(x_124, x_3, x_123); +lean_dec(x_124); +x_126 = lean_ctor_get(x_125, 0); +lean_inc(x_126); +x_127 = lean_unbox(x_126); +lean_dec(x_126); +if (x_127 == 0) +{ +lean_object* x_128; lean_object* x_129; uint8_t x_130; +lean_dec(x_122); +lean_dec(x_112); +lean_dec(x_3); +x_128 = lean_ctor_get(x_125, 1); +lean_inc(x_128); +if (lean_is_exclusive(x_125)) { + lean_ctor_release(x_125, 0); + lean_ctor_release(x_125, 1); + x_129 = x_125; +} else { + lean_dec_ref(x_125); + x_129 = lean_box(0); +} +x_130 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_130 == 0) +{ +lean_object* x_131; lean_object* x_132; +x_131 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_129)) { + x_132 = lean_alloc_ctor(0, 2, 0); +} else { + x_132 = x_129; +} +lean_ctor_set(x_132, 0, x_131); +lean_ctor_set(x_132, 1, x_128); +return x_132; +} +else +{ +lean_object* x_133; +lean_dec(x_108); +if (lean_is_scalar(x_129)) { + x_133 = lean_alloc_ctor(0, 2, 0); +} else { + x_133 = x_129; +} +lean_ctor_set(x_133, 0, x_2); +lean_ctor_set(x_133, 1, x_128); +return x_133; +} +} +else +{ +lean_object* x_134; lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; lean_object* x_139; +x_134 = lean_ctor_get(x_125, 1); +lean_inc(x_134); +lean_dec(x_125); +x_135 = lean_unsigned_to_nat(0u); +x_136 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_135); +x_137 = lean_mk_empty_array_with_capacity(x_136); +lean_dec(x_136); +lean_inc(x_2); +x_138 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_137); +x_139 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__17(x_2, x_26, x_108, x_122, x_112, x_138, x_3, x_134); +lean_dec(x_108); +lean_dec(x_26); +return x_139; +} +} +case 4: +{ +lean_object* x_140; lean_object* x_141; lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; lean_object* x_147; lean_object* x_148; lean_object* x_149; +x_140 = lean_ctor_get(x_114, 1); +lean_inc(x_140); +lean_dec(x_114); +x_141 = lean_ctor_get(x_122, 0); +lean_inc(x_141); +lean_dec(x_122); +x_142 = lean_unsigned_to_nat(0u); +x_143 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_142); +x_144 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_143); +x_145 = lean_mk_array(x_143, x_144); +x_146 = lean_unsigned_to_nat(1u); +x_147 = lean_nat_sub(x_143, x_146); +lean_dec(x_143); +lean_inc(x_2); +x_148 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_145, x_147); +x_149 = l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__18(x_2, x_26, x_108, x_141, x_112, x_148, x_3, x_140); +lean_dec(x_148); +lean_dec(x_112); +lean_dec(x_141); +lean_dec(x_108); +lean_dec(x_26); +return x_149; +} +case 7: +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; lean_object* x_154; lean_object* x_155; lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; +x_150 = lean_ctor_get(x_114, 1); +lean_inc(x_150); +lean_dec(x_114); +x_151 = lean_ctor_get(x_122, 0); +lean_inc(x_151); +lean_dec(x_122); +x_152 = lean_unsigned_to_nat(0u); +x_153 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_152); +x_154 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_153); +x_155 = lean_mk_array(x_153, x_154); +x_156 = lean_unsigned_to_nat(1u); +x_157 = lean_nat_sub(x_153, x_156); +lean_dec(x_153); +lean_inc(x_2); +x_158 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_2, x_155, x_157); +x_159 = l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__19(x_2, x_26, x_108, x_151, x_112, x_158, x_3, x_150); +lean_dec(x_158); +lean_dec(x_108); +lean_dec(x_26); +return x_159; +} +default: +{ +lean_object* x_160; lean_object* x_161; uint8_t x_162; +lean_dec(x_122); +lean_dec(x_112); +lean_dec(x_3); +x_160 = lean_ctor_get(x_114, 1); +lean_inc(x_160); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_161 = x_114; +} else { + lean_dec_ref(x_114); + x_161 = lean_box(0); +} +x_162 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_162 == 0) +{ +lean_object* x_163; lean_object* x_164; +x_163 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +if (lean_is_scalar(x_161)) { + x_164 = lean_alloc_ctor(0, 2, 0); +} else { + x_164 = x_161; +} +lean_ctor_set(x_164, 0, x_163); +lean_ctor_set(x_164, 1, x_160); +return x_164; +} +else +{ +lean_object* x_165; +lean_dec(x_108); +if (lean_is_scalar(x_161)) { + x_165 = lean_alloc_ctor(0, 2, 0); +} else { + x_165 = x_161; +} +lean_ctor_set(x_165, 0, x_2); +lean_ctor_set(x_165, 1, x_160); +return x_165; +} +} +} +} +} +else +{ +lean_object* x_166; lean_object* x_167; lean_object* x_168; lean_object* x_169; +lean_dec(x_112); +lean_dec(x_108); +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_166 = lean_ctor_get(x_114, 0); +lean_inc(x_166); +x_167 = lean_ctor_get(x_114, 1); +lean_inc(x_167); +if (lean_is_exclusive(x_114)) { + lean_ctor_release(x_114, 0); + lean_ctor_release(x_114, 1); + x_168 = x_114; +} else { + lean_dec_ref(x_114); + x_168 = lean_box(0); +} +if (lean_is_scalar(x_168)) { + x_169 = lean_alloc_ctor(1, 2, 0); +} else { + x_169 = x_168; +} +lean_ctor_set(x_169, 0, x_166); +lean_ctor_set(x_169, 1, x_167); +return x_169; +} +} +else +{ +uint8_t x_170; +lean_dec(x_3); +x_170 = lean_expr_eqv(x_26, x_108); +lean_dec(x_26); +if (x_170 == 0) +{ +lean_object* x_171; lean_object* x_172; +x_171 = l_Lean_Expr_updateFn___main(x_2, x_108); +lean_dec(x_108); +x_172 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_172, 0, x_171); +lean_ctor_set(x_172, 1, x_109); +return x_172; +} +else +{ +lean_object* x_173; +lean_dec(x_108); +x_173 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_173, 0, x_2); +lean_ctor_set(x_173, 1, x_109); +return x_173; +} +} +} +else +{ +lean_object* x_174; lean_object* x_175; lean_object* x_176; lean_object* x_177; lean_object* x_178; lean_object* x_179; +lean_dec(x_108); +x_174 = lean_unsigned_to_nat(0u); +x_175 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_174); +x_176 = lean_mk_empty_array_with_capacity(x_175); +lean_dec(x_175); +x_177 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_176); +x_178 = l_Lean_Expr_betaRev(x_26, x_177); +lean_dec(x_26); +x_179 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_178, x_3, x_109); +return x_179; +} +} +} +else +{ +uint8_t x_180; +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_180 = !lean_is_exclusive(x_27); +if (x_180 == 0) +{ +return x_27; +} +else +{ +lean_object* x_181; lean_object* x_182; lean_object* x_183; +x_181 = lean_ctor_get(x_27, 0); +x_182 = lean_ctor_get(x_27, 1); +lean_inc(x_182); +lean_inc(x_181); +lean_dec(x_27); +x_183 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_183, 0, x_181); +lean_ctor_set(x_183, 1, x_182); +return x_183; +} +} +} +case 8: +{ +lean_object* x_184; lean_object* x_185; lean_object* x_186; lean_object* x_187; +lean_dec(x_1); +x_184 = lean_ctor_get(x_2, 2); +lean_inc(x_184); +x_185 = lean_ctor_get(x_2, 3); +lean_inc(x_185); +lean_dec(x_2); +x_186 = lean_expr_instantiate1(x_185, x_184); +lean_dec(x_184); +lean_dec(x_185); +x_187 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_186, x_3, x_4); +return x_187; +} +case 10: +{ +lean_object* x_188; +x_188 = lean_ctor_get(x_2, 1); +lean_inc(x_188); +lean_dec(x_2); +x_2 = x_188; +goto _start; +} +case 11: +{ +lean_object* x_190; lean_object* x_191; lean_object* x_192; +lean_dec(x_1); +x_190 = lean_ctor_get(x_2, 1); +lean_inc(x_190); +x_191 = lean_ctor_get(x_2, 2); +lean_inc(x_191); +lean_inc(x_3); +x_192 = l_Lean_Meta_whnf(x_191, x_3, x_4); +if (lean_obj_tag(x_192) == 0) +{ +uint8_t x_193; +x_193 = !lean_is_exclusive(x_192); +if (x_193 == 0) +{ +lean_object* x_194; lean_object* x_195; lean_object* x_196; +x_194 = lean_ctor_get(x_192, 0); +x_195 = lean_ctor_get(x_192, 1); +x_196 = l_Lean_Expr_getAppFn___main(x_194); +if (lean_obj_tag(x_196) == 4) +{ +lean_object* x_197; uint8_t x_198; lean_object* x_199; +lean_free_object(x_192); +x_197 = lean_ctor_get(x_196, 0); +lean_inc(x_197); +lean_dec(x_196); +x_198 = 0; +x_199 = l_Lean_Meta_getConstAux(x_197, x_198, x_3, x_195); +lean_dec(x_3); +if (lean_obj_tag(x_199) == 0) +{ +lean_object* x_200; +x_200 = lean_ctor_get(x_199, 0); +lean_inc(x_200); +if (lean_obj_tag(x_200) == 0) +{ +uint8_t x_201; +lean_dec(x_194); +lean_dec(x_190); +x_201 = !lean_is_exclusive(x_199); +if (x_201 == 0) +{ +lean_object* x_202; +x_202 = lean_ctor_get(x_199, 0); +lean_dec(x_202); +lean_ctor_set(x_199, 0, x_2); +return x_199; +} +else +{ +lean_object* x_203; lean_object* x_204; +x_203 = lean_ctor_get(x_199, 1); +lean_inc(x_203); +lean_dec(x_199); +x_204 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_204, 0, x_2); +lean_ctor_set(x_204, 1, x_203); +return x_204; +} +} +else +{ +lean_object* x_205; +x_205 = lean_ctor_get(x_200, 0); +lean_inc(x_205); +lean_dec(x_200); +if (lean_obj_tag(x_205) == 6) +{ +uint8_t x_206; +x_206 = !lean_is_exclusive(x_199); +if (x_206 == 0) +{ +lean_object* x_207; lean_object* x_208; lean_object* x_209; lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; lean_object* x_215; lean_object* x_216; +x_207 = lean_ctor_get(x_199, 0); +lean_dec(x_207); +x_208 = lean_ctor_get(x_205, 0); +lean_inc(x_208); +lean_dec(x_205); +x_209 = lean_ctor_get(x_208, 3); +lean_inc(x_209); +lean_dec(x_208); +x_210 = lean_nat_add(x_209, x_190); +lean_dec(x_190); +lean_dec(x_209); +x_211 = lean_unsigned_to_nat(0u); +x_212 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_211); +x_213 = lean_nat_sub(x_212, x_210); +lean_dec(x_210); +lean_dec(x_212); +x_214 = lean_unsigned_to_nat(1u); +x_215 = lean_nat_sub(x_213, x_214); +lean_dec(x_213); +x_216 = l_Lean_Expr_getRevArgD___main(x_194, x_215, x_2); +lean_dec(x_2); +lean_dec(x_194); +lean_ctor_set(x_199, 0, x_216); +return x_199; +} +else +{ +lean_object* x_217; lean_object* x_218; lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; lean_object* x_223; lean_object* x_224; lean_object* x_225; lean_object* x_226; lean_object* x_227; +x_217 = lean_ctor_get(x_199, 1); +lean_inc(x_217); +lean_dec(x_199); +x_218 = lean_ctor_get(x_205, 0); +lean_inc(x_218); +lean_dec(x_205); +x_219 = lean_ctor_get(x_218, 3); +lean_inc(x_219); +lean_dec(x_218); +x_220 = lean_nat_add(x_219, x_190); +lean_dec(x_190); +lean_dec(x_219); +x_221 = lean_unsigned_to_nat(0u); +x_222 = l_Lean_Expr_getAppNumArgsAux___main(x_194, x_221); +x_223 = lean_nat_sub(x_222, x_220); +lean_dec(x_220); +lean_dec(x_222); +x_224 = lean_unsigned_to_nat(1u); +x_225 = lean_nat_sub(x_223, x_224); +lean_dec(x_223); +x_226 = l_Lean_Expr_getRevArgD___main(x_194, x_225, x_2); +lean_dec(x_2); +lean_dec(x_194); +x_227 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_227, 0, x_226); +lean_ctor_set(x_227, 1, x_217); +return x_227; +} +} +else +{ +uint8_t x_228; +lean_dec(x_205); +lean_dec(x_194); +lean_dec(x_190); +x_228 = !lean_is_exclusive(x_199); +if (x_228 == 0) +{ +lean_object* x_229; +x_229 = lean_ctor_get(x_199, 0); +lean_dec(x_229); +lean_ctor_set(x_199, 0, x_2); +return x_199; +} +else +{ +lean_object* x_230; lean_object* x_231; +x_230 = lean_ctor_get(x_199, 1); +lean_inc(x_230); +lean_dec(x_199); +x_231 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_231, 0, x_2); +lean_ctor_set(x_231, 1, x_230); +return x_231; +} +} +} +} +else +{ +uint8_t x_232; +lean_dec(x_194); +lean_dec(x_190); +lean_dec(x_2); +x_232 = !lean_is_exclusive(x_199); +if (x_232 == 0) +{ +return x_199; +} +else +{ +lean_object* x_233; lean_object* x_234; lean_object* x_235; +x_233 = lean_ctor_get(x_199, 0); +x_234 = lean_ctor_get(x_199, 1); +lean_inc(x_234); +lean_inc(x_233); +lean_dec(x_199); +x_235 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_235, 0, x_233); +lean_ctor_set(x_235, 1, x_234); +return x_235; +} +} +} +else +{ +lean_dec(x_196); +lean_dec(x_194); +lean_dec(x_190); +lean_dec(x_3); +lean_ctor_set(x_192, 0, x_2); +return x_192; +} +} +else +{ +lean_object* x_236; lean_object* x_237; lean_object* x_238; +x_236 = lean_ctor_get(x_192, 0); +x_237 = lean_ctor_get(x_192, 1); +lean_inc(x_237); +lean_inc(x_236); +lean_dec(x_192); +x_238 = l_Lean_Expr_getAppFn___main(x_236); +if (lean_obj_tag(x_238) == 4) +{ +lean_object* x_239; uint8_t x_240; lean_object* x_241; +x_239 = lean_ctor_get(x_238, 0); +lean_inc(x_239); +lean_dec(x_238); +x_240 = 0; +x_241 = l_Lean_Meta_getConstAux(x_239, x_240, x_3, x_237); +lean_dec(x_3); +if (lean_obj_tag(x_241) == 0) +{ +lean_object* x_242; +x_242 = lean_ctor_get(x_241, 0); +lean_inc(x_242); +if (lean_obj_tag(x_242) == 0) +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; +lean_dec(x_236); +lean_dec(x_190); +x_243 = lean_ctor_get(x_241, 1); +lean_inc(x_243); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_244 = x_241; +} else { + lean_dec_ref(x_241); + x_244 = lean_box(0); +} +if (lean_is_scalar(x_244)) { + x_245 = lean_alloc_ctor(0, 2, 0); +} else { + x_245 = x_244; +} +lean_ctor_set(x_245, 0, x_2); +lean_ctor_set(x_245, 1, x_243); +return x_245; +} +else +{ +lean_object* x_246; +x_246 = lean_ctor_get(x_242, 0); +lean_inc(x_246); +lean_dec(x_242); +if (lean_obj_tag(x_246) == 6) +{ +lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; lean_object* x_255; lean_object* x_256; lean_object* x_257; lean_object* x_258; +x_247 = lean_ctor_get(x_241, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_248 = x_241; +} else { + lean_dec_ref(x_241); + x_248 = lean_box(0); +} +x_249 = lean_ctor_get(x_246, 0); +lean_inc(x_249); +lean_dec(x_246); +x_250 = lean_ctor_get(x_249, 3); +lean_inc(x_250); +lean_dec(x_249); +x_251 = lean_nat_add(x_250, x_190); +lean_dec(x_190); +lean_dec(x_250); +x_252 = lean_unsigned_to_nat(0u); +x_253 = l_Lean_Expr_getAppNumArgsAux___main(x_236, x_252); +x_254 = lean_nat_sub(x_253, x_251); +lean_dec(x_251); +lean_dec(x_253); +x_255 = lean_unsigned_to_nat(1u); +x_256 = lean_nat_sub(x_254, x_255); +lean_dec(x_254); +x_257 = l_Lean_Expr_getRevArgD___main(x_236, x_256, x_2); +lean_dec(x_2); +lean_dec(x_236); +if (lean_is_scalar(x_248)) { + x_258 = lean_alloc_ctor(0, 2, 0); +} else { + x_258 = x_248; +} +lean_ctor_set(x_258, 0, x_257); +lean_ctor_set(x_258, 1, x_247); +return x_258; +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; +lean_dec(x_246); +lean_dec(x_236); +lean_dec(x_190); +x_259 = lean_ctor_get(x_241, 1); +lean_inc(x_259); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_260 = x_241; +} else { + lean_dec_ref(x_241); + x_260 = lean_box(0); +} +if (lean_is_scalar(x_260)) { + x_261 = lean_alloc_ctor(0, 2, 0); +} else { + x_261 = x_260; +} +lean_ctor_set(x_261, 0, x_2); +lean_ctor_set(x_261, 1, x_259); +return x_261; +} +} +} +else +{ +lean_object* x_262; lean_object* x_263; lean_object* x_264; lean_object* x_265; +lean_dec(x_236); +lean_dec(x_190); +lean_dec(x_2); +x_262 = lean_ctor_get(x_241, 0); +lean_inc(x_262); +x_263 = lean_ctor_get(x_241, 1); +lean_inc(x_263); +if (lean_is_exclusive(x_241)) { + lean_ctor_release(x_241, 0); + lean_ctor_release(x_241, 1); + x_264 = x_241; +} else { + lean_dec_ref(x_241); + x_264 = lean_box(0); +} +if (lean_is_scalar(x_264)) { + x_265 = lean_alloc_ctor(1, 2, 0); +} else { + x_265 = x_264; +} +lean_ctor_set(x_265, 0, x_262); +lean_ctor_set(x_265, 1, x_263); +return x_265; +} +} +else +{ +lean_object* x_266; +lean_dec(x_238); +lean_dec(x_236); +lean_dec(x_190); +lean_dec(x_3); +x_266 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_266, 0, x_2); +lean_ctor_set(x_266, 1, x_237); +return x_266; +} +} +} +else +{ +uint8_t x_267; +lean_dec(x_190); +lean_dec(x_3); +lean_dec(x_2); +x_267 = !lean_is_exclusive(x_192); +if (x_267 == 0) +{ +return x_192; +} +else +{ +lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_268 = lean_ctor_get(x_192, 0); +x_269 = lean_ctor_get(x_192, 1); +lean_inc(x_269); +lean_inc(x_268); +lean_dec(x_192); +x_270 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_270, 0, x_268); +lean_ctor_set(x_270, 1, x_269); +return x_270; +} +} +} +case 12: +{ +lean_object* x_271; lean_object* x_272; lean_object* x_273; lean_object* x_274; +lean_dec(x_2); +x_271 = l_Lean_Expr_Inhabited; +x_272 = l_monadInhabited___rarg(x_1, x_271); +x_273 = l_unreachable_x21___rarg(x_272); +x_274 = lean_apply_2(x_273, x_3, x_4); +return x_274; +} +default: +{ +lean_object* x_275; +x_275 = lean_box(0); +x_5 = x_275; +goto block_9; +} +} +block_9: +{ +lean_object* x_6; lean_object* x_7; lean_object* x_8; +lean_dec(x_5); +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +lean_dec(x_1); +x_7 = lean_ctor_get(x_6, 1); +lean_inc(x_7); +lean_dec(x_6); +x_8 = lean_apply_4(x_7, lean_box(0), x_2, x_3, x_4); +return x_8; +} +} +} +lean_object* l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; lean_object* x_5; +x_4 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1; +x_5 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23(x_4, x_1, x_2, x_3); +return x_5; +} +} +lean_object* l_Lean_isQuotRecStuck___at_Lean_Meta_whnfImpl___main___spec__25(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; uint8_t x_21; lean_object* x_22; +x_21 = lean_ctor_get_uint8(x_1, sizeof(void*)*1); +x_22 = lean_box(x_21); +switch (lean_obj_tag(x_22)) { +case 2: +{ +lean_object* x_23; +x_23 = lean_unsigned_to_nat(5u); +x_6 = x_23; +goto block_20; +} +case 3: +{ +lean_object* x_24; +x_24 = lean_unsigned_to_nat(4u); +x_6 = x_24; +goto block_20; +} +default: +{ +lean_object* x_25; lean_object* x_26; +lean_dec(x_22); +lean_dec(x_4); +x_25 = lean_box(0); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_25); +lean_ctor_set(x_26, 1, x_5); +return x_26; +} +} +block_20: +{ +lean_object* x_7; uint8_t x_8; +x_7 = lean_array_get_size(x_3); +x_8 = lean_nat_dec_lt(x_6, x_7); +lean_dec(x_7); +if (x_8 == 0) +{ +lean_object* x_9; lean_object* x_10; +lean_dec(x_4); +x_9 = lean_box(0); +x_10 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_10, 0, x_9); +lean_ctor_set(x_10, 1, x_5); +return x_10; +} +else +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_array_fget(x_3, x_6); +lean_inc(x_4); +x_12 = l_Lean_Meta_whnf(x_11, x_4, x_5); +if (lean_obj_tag(x_12) == 0) +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +x_14 = lean_ctor_get(x_12, 1); +lean_inc(x_14); +lean_dec(x_12); +x_15 = l_Lean_getStuckMVar___main___at_Lean_Meta_whnfImpl___main___spec__24(x_13, x_4, x_14); +return x_15; +} +else +{ +uint8_t x_16; +lean_dec(x_4); +x_16 = !lean_is_exclusive(x_12); +if (x_16 == 0) +{ +return x_12; +} +else +{ +lean_object* x_17; lean_object* x_18; lean_object* x_19; +x_17 = lean_ctor_get(x_12, 0); +x_18 = lean_ctor_get(x_12, 1); +lean_inc(x_18); +lean_inc(x_17); +lean_dec(x_12); +x_19 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_19, 0, x_17); +lean_ctor_set(x_19, 1, x_18); +return x_19; +} +} +} +} +} +} +lean_object* l_Lean_isRecStuck___at_Lean_Meta_whnfImpl___main___spec__26(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; +x_6 = lean_ctor_get_uint8(x_1, sizeof(void*)*7); +if (x_6 == 0) +{ +lean_object* x_7; lean_object* x_8; uint8_t x_9; +x_7 = l_Lean_RecursorVal_getMajorIdx(x_1); +x_8 = lean_array_get_size(x_3); +x_9 = lean_nat_dec_lt(x_7, x_8); +lean_dec(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; +lean_dec(x_7); +lean_dec(x_4); +x_10 = lean_box(0); +x_11 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_11, 0, x_10); +lean_ctor_set(x_11, 1, x_5); +return x_11; +} +else +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_array_fget(x_3, x_7); +lean_dec(x_7); +lean_inc(x_4); +x_13 = l_Lean_Meta_whnf(x_12, x_4, x_5); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +x_15 = lean_ctor_get(x_13, 1); +lean_inc(x_15); +lean_dec(x_13); +x_16 = l_Lean_getStuckMVar___main___at_Lean_Meta_whnfImpl___main___spec__24(x_14, x_4, x_15); +return x_16; +} +else +{ +uint8_t x_17; +lean_dec(x_4); +x_17 = !lean_is_exclusive(x_13); +if (x_17 == 0) +{ +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_13, 0); +x_19 = lean_ctor_get(x_13, 1); +lean_inc(x_19); +lean_inc(x_18); +lean_dec(x_13); +x_20 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_20, 0, x_18); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +} +else +{ +lean_object* x_21; lean_object* x_22; +lean_dec(x_4); +x_21 = lean_box(0); +x_22 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_22, 0, x_21); +lean_ctor_set(x_22, 1, x_5); +return x_22; +} +} +} +lean_object* l_Lean_getStuckMVar___main___at_Lean_Meta_whnfImpl___main___spec__24(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +switch (lean_obj_tag(x_1)) { +case 2: +{ +lean_object* x_4; lean_object* x_5; +lean_dec(x_2); +x_4 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_4, 0, x_1); +x_5 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_5, 0, x_4); +lean_ctor_set(x_5, 1, x_3); +return x_5; +} +case 5: +{ +lean_object* x_6; lean_object* x_7; +x_6 = lean_ctor_get(x_1, 0); +lean_inc(x_6); +x_7 = l_Lean_Expr_getAppFn___main(x_6); +lean_dec(x_6); +switch (lean_obj_tag(x_7)) { +case 2: +{ +lean_object* x_8; lean_object* x_9; +lean_dec(x_2); +lean_dec(x_1); +x_8 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_8, 0, x_7); +x_9 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_9, 0, x_8); +lean_ctor_set(x_9, 1, x_3); +return x_9; +} +case 4: +{ +lean_object* x_10; lean_object* x_11; uint8_t x_12; lean_object* x_13; +x_10 = lean_ctor_get(x_7, 0); +lean_inc(x_10); +x_11 = lean_ctor_get(x_7, 1); +lean_inc(x_11); +lean_dec(x_7); +x_12 = 0; +x_13 = l_Lean_Meta_getConstAux(x_10, x_12, x_2, x_3); +if (lean_obj_tag(x_13) == 0) +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_13, 0); +lean_inc(x_14); +if (lean_obj_tag(x_14) == 0) +{ +uint8_t x_15; +lean_dec(x_11); +lean_dec(x_2); +lean_dec(x_1); +x_15 = !lean_is_exclusive(x_13); +if (x_15 == 0) +{ +lean_object* x_16; lean_object* x_17; +x_16 = lean_ctor_get(x_13, 0); +lean_dec(x_16); +x_17 = lean_box(0); +lean_ctor_set(x_13, 0, x_17); +return x_13; +} +else +{ +lean_object* x_18; lean_object* x_19; lean_object* x_20; +x_18 = lean_ctor_get(x_13, 1); +lean_inc(x_18); +lean_dec(x_13); +x_19 = lean_box(0); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_19); +lean_ctor_set(x_20, 1, x_18); +return x_20; +} +} +else +{ +lean_object* x_21; +x_21 = lean_ctor_get(x_14, 0); +lean_inc(x_21); +lean_dec(x_14); +switch (lean_obj_tag(x_21)) { +case 4: +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_22 = lean_ctor_get(x_13, 1); +lean_inc(x_22); +lean_dec(x_13); +x_23 = lean_ctor_get(x_21, 0); +lean_inc(x_23); +lean_dec(x_21); +x_24 = lean_unsigned_to_nat(0u); +x_25 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_24); +x_26 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_25); +x_27 = lean_mk_array(x_25, x_26); +x_28 = lean_unsigned_to_nat(1u); +x_29 = lean_nat_sub(x_25, x_28); +lean_dec(x_25); +x_30 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_27, x_29); +x_31 = l_Lean_isQuotRecStuck___at_Lean_Meta_whnfImpl___main___spec__25(x_23, x_11, x_30, x_2, x_22); +lean_dec(x_30); +lean_dec(x_11); +lean_dec(x_23); +return x_31; +} +case 7: +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_32 = lean_ctor_get(x_13, 1); +lean_inc(x_32); +lean_dec(x_13); +x_33 = lean_ctor_get(x_21, 0); +lean_inc(x_33); +lean_dec(x_21); +x_34 = lean_unsigned_to_nat(0u); +x_35 = l_Lean_Expr_getAppNumArgsAux___main(x_1, x_34); +x_36 = l_Lean_Expr_getAppArgs___closed__1; +lean_inc(x_35); +x_37 = lean_mk_array(x_35, x_36); +x_38 = lean_unsigned_to_nat(1u); +x_39 = lean_nat_sub(x_35, x_38); +lean_dec(x_35); +x_40 = l___private_Init_Lean_Expr_3__getAppArgsAux___main(x_1, x_37, x_39); +x_41 = l_Lean_isRecStuck___at_Lean_Meta_whnfImpl___main___spec__26(x_33, x_11, x_40, x_2, x_32); +lean_dec(x_40); +lean_dec(x_11); +lean_dec(x_33); +return x_41; +} +default: +{ +uint8_t x_42; +lean_dec(x_21); +lean_dec(x_11); +lean_dec(x_2); +lean_dec(x_1); +x_42 = !lean_is_exclusive(x_13); +if (x_42 == 0) +{ +lean_object* x_43; lean_object* x_44; +x_43 = lean_ctor_get(x_13, 0); +lean_dec(x_43); +x_44 = lean_box(0); +lean_ctor_set(x_13, 0, x_44); +return x_13; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; +x_45 = lean_ctor_get(x_13, 1); +lean_inc(x_45); +lean_dec(x_13); +x_46 = lean_box(0); +x_47 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_47, 0, x_46); +lean_ctor_set(x_47, 1, x_45); +return x_47; +} +} +} +} +} +else +{ +uint8_t x_48; +lean_dec(x_11); +lean_dec(x_2); +lean_dec(x_1); +x_48 = !lean_is_exclusive(x_13); +if (x_48 == 0) +{ +return x_13; +} +else +{ +lean_object* x_49; lean_object* x_50; lean_object* x_51; +x_49 = lean_ctor_get(x_13, 0); +x_50 = lean_ctor_get(x_13, 1); +lean_inc(x_50); +lean_inc(x_49); +lean_dec(x_13); +x_51 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_51, 0, x_49); +lean_ctor_set(x_51, 1, x_50); +return x_51; +} +} +} +default: +{ +lean_object* x_52; lean_object* x_53; +lean_dec(x_7); +lean_dec(x_2); +lean_dec(x_1); +x_52 = lean_box(0); +x_53 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_53, 0, x_52); +lean_ctor_set(x_53, 1, x_3); +return x_53; +} +} +} +case 10: +{ +lean_object* x_54; +x_54 = lean_ctor_get(x_1, 1); +lean_inc(x_54); +lean_dec(x_1); +x_1 = x_54; +goto _start; +} +case 11: +{ +lean_object* x_56; lean_object* x_57; +x_56 = lean_ctor_get(x_1, 2); +lean_inc(x_56); +lean_dec(x_1); +lean_inc(x_2); +x_57 = l_Lean_Meta_whnf(x_56, x_2, x_3); +if (lean_obj_tag(x_57) == 0) +{ +lean_object* x_58; lean_object* x_59; +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_57, 1); +lean_inc(x_59); +lean_dec(x_57); +x_1 = x_58; +x_3 = x_59; +goto _start; +} +else +{ +uint8_t x_61; +lean_dec(x_2); +x_61 = !lean_is_exclusive(x_57); +if (x_61 == 0) +{ +return x_57; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_57, 0); +x_63 = lean_ctor_get(x_57, 1); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_57); +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +return x_64; +} +} +} +default: +{ +lean_object* x_65; lean_object* x_66; +lean_dec(x_2); +lean_dec(x_1); +x_65 = lean_box(0); +x_66 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_66, 0, x_65); +lean_ctor_set(x_66, 1, x_3); +return x_66; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at_Lean_Meta_whnfImpl___main___spec__15(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +lean_inc(x_2); +x_4 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__16(x_1, x_2, x_3); +if (lean_obj_tag(x_4) == 0) +{ +lean_object* x_5; lean_object* x_6; lean_object* x_7; +x_5 = lean_ctor_get(x_4, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_4, 1); +lean_inc(x_6); +lean_dec(x_4); +lean_inc(x_2); +lean_inc(x_5); +x_7 = l_Lean_getStuckMVar___main___at_Lean_Meta_whnfImpl___main___spec__24(x_5, x_2, x_6); +if (lean_obj_tag(x_7) == 0) +{ +lean_object* x_8; +x_8 = lean_ctor_get(x_7, 0); +lean_inc(x_8); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +lean_dec(x_2); +x_9 = !lean_is_exclusive(x_7); +if (x_9 == 0) +{ +lean_object* x_10; +x_10 = lean_ctor_get(x_7, 0); +lean_dec(x_10); +lean_ctor_set(x_7, 0, x_5); +return x_7; +} +else +{ +lean_object* x_11; lean_object* x_12; +x_11 = lean_ctor_get(x_7, 1); +lean_inc(x_11); +lean_dec(x_7); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_5); +lean_ctor_set(x_12, 1, x_11); +return x_12; +} +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; +x_13 = lean_ctor_get(x_7, 1); +lean_inc(x_13); +lean_dec(x_7); +x_14 = lean_ctor_get(x_8, 0); +lean_inc(x_14); +lean_dec(x_8); +lean_inc(x_2); +x_15 = l_Lean_Meta_synthPending(x_14, x_2, x_13); +if (lean_obj_tag(x_15) == 0) +{ +lean_object* x_16; uint8_t x_17; +x_16 = lean_ctor_get(x_15, 0); +lean_inc(x_16); +x_17 = lean_unbox(x_16); +lean_dec(x_16); +if (x_17 == 0) +{ +uint8_t x_18; +lean_dec(x_2); +x_18 = !lean_is_exclusive(x_15); +if (x_18 == 0) +{ +lean_object* x_19; +x_19 = lean_ctor_get(x_15, 0); +lean_dec(x_19); +lean_ctor_set(x_15, 0, x_5); +return x_15; +} +else +{ +lean_object* x_20; lean_object* x_21; +x_20 = lean_ctor_get(x_15, 1); +lean_inc(x_20); +lean_dec(x_15); +x_21 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_21, 0, x_5); +lean_ctor_set(x_21, 1, x_20); +return x_21; +} +} +else +{ +lean_object* x_22; +x_22 = lean_ctor_get(x_15, 1); +lean_inc(x_22); +lean_dec(x_15); +x_1 = x_5; +x_3 = x_22; +goto _start; +} +} +else +{ +uint8_t x_24; +lean_dec(x_5); +lean_dec(x_2); +x_24 = !lean_is_exclusive(x_15); +if (x_24 == 0) { return x_15; } else { -lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_21 = lean_ctor_get(x_15, 0); -x_22 = lean_ctor_get(x_15, 1); -lean_inc(x_22); -lean_inc(x_21); +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_15, 0); +x_26 = lean_ctor_get(x_15, 1); +lean_inc(x_26); +lean_inc(x_25); lean_dec(x_15); -x_23 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_23, 0, x_21); -lean_ctor_set(x_23, 1, x_22); -return x_23; +x_27 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_27, 0, x_25); +lean_ctor_set(x_27, 1, x_26); +return x_27; } } } } -lean_object* l_Lean_Meta_whnfAux___main(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +else +{ +uint8_t x_28; +lean_dec(x_5); +lean_dec(x_2); +x_28 = !lean_is_exclusive(x_7); +if (x_28 == 0) +{ +return x_7; +} +else +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; +x_29 = lean_ctor_get(x_7, 0); +x_30 = lean_ctor_get(x_7, 1); +lean_inc(x_30); +lean_inc(x_29); +lean_dec(x_7); +x_31 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_30); +return x_31; +} +} +} +else +{ +uint8_t x_32; +lean_dec(x_2); +x_32 = !lean_is_exclusive(x_4); +if (x_32 == 0) +{ +return x_4; +} +else +{ +lean_object* x_33; lean_object* x_34; lean_object* x_35; +x_33 = lean_ctor_get(x_4, 0); +x_34 = lean_ctor_get(x_4, 1); +lean_inc(x_34); +lean_inc(x_33); +lean_dec(x_4); +x_35 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_35, 0, x_33); +lean_ctor_set(x_35, 1, x_34); +return x_35; +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__27(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { _start: { -lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; lean_object* x_11; lean_object* x_12; lean_object* x_13; -x_7 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1; -x_8 = l_EIO_Monad___closed__1; -x_9 = lean_alloc_closure((void*)(l_Lean_Meta_whnfAux___main___lambda__1), 8, 5); -lean_closure_set(x_9, 0, x_1); -lean_closure_set(x_9, 1, x_2); -lean_closure_set(x_9, 2, x_3); -lean_closure_set(x_9, 3, x_7); -lean_closure_set(x_9, 4, x_8); -x_10 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4; -x_11 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5; -x_12 = l_Lean_whnfEasyCases___main___rarg(x_7, x_10, x_11, x_4, x_9); -x_13 = lean_apply_2(x_12, x_5, x_6); +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +lean_inc(x_5); +x_16 = l___private_Init_Lean_WHNF_10__whnfCoreUnstuck___main___at_Lean_Meta_whnfImpl___main___spec__15(x_15, x_5, x_6); +if (lean_obj_tag(x_16) == 0) +{ +uint8_t x_17; +x_17 = !lean_is_exclusive(x_16); +if (x_17 == 0) +{ +lean_object* x_18; lean_object* x_19; uint8_t x_20; +x_18 = lean_ctor_get(x_16, 0); +x_19 = lean_ctor_get(x_16, 1); +x_20 = l___private_Init_Lean_WHNF_6__isIdRhsApp(x_18); +if (x_20 == 0) +{ +lean_dec(x_18); +lean_dec(x_5); +lean_ctor_set(x_16, 0, x_1); +return x_16; +} +else +{ +lean_object* x_21; lean_object* x_22; +lean_free_object(x_16); +lean_dec(x_1); +x_21 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_18); +x_22 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_21, x_5, x_19); +return x_22; +} +} +else +{ +lean_object* x_23; lean_object* x_24; uint8_t x_25; +x_23 = lean_ctor_get(x_16, 0); +x_24 = lean_ctor_get(x_16, 1); +lean_inc(x_24); +lean_inc(x_23); +lean_dec(x_16); +x_25 = l___private_Init_Lean_WHNF_6__isIdRhsApp(x_23); +if (x_25 == 0) +{ +lean_object* x_26; +lean_dec(x_23); +lean_dec(x_5); +x_26 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_26, 0, x_1); +lean_ctor_set(x_26, 1, x_24); +return x_26; +} +else +{ +lean_object* x_27; lean_object* x_28; +lean_dec(x_1); +x_27 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_23); +x_28 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_27, x_5, x_24); +return x_28; +} +} +} +else +{ +uint8_t x_29; +lean_dec(x_5); +lean_dec(x_1); +x_29 = !lean_is_exclusive(x_16); +if (x_29 == 0) +{ +return x_16; +} +else +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_30 = lean_ctor_get(x_16, 0); +x_31 = lean_ctor_get(x_16, 1); +lean_inc(x_31); +lean_inc(x_30); +lean_dec(x_16); +x_32 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_32, 0, x_30); +lean_ctor_set(x_32, 1, x_31); +return x_32; +} +} +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__28(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__29(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__30(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__31(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__32(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__33(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +_start: +{ +lean_object* x_7; lean_object* x_8; lean_object* x_9; lean_object* x_10; uint8_t x_11; +x_7 = l_Lean_ConstantInfo_lparams(x_2); +x_8 = lean_unsigned_to_nat(0u); +x_9 = l_List_lengthAux___main___rarg(x_7, x_8); +lean_dec(x_7); +x_10 = l_List_lengthAux___main___rarg(x_3, x_8); +x_11 = lean_nat_dec_eq(x_9, x_10); +lean_dec(x_10); +lean_dec(x_9); +if (x_11 == 0) +{ +lean_object* x_12; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_12 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_12, 0, x_1); +lean_ctor_set(x_12, 1, x_6); +return x_12; +} +else +{ +lean_object* x_13; lean_object* x_14; lean_object* x_15; lean_object* x_16; +lean_dec(x_1); +x_13 = lean_instantiate_value_lparams(x_2, x_3); +x_14 = l_Lean_Expr_betaRev(x_13, x_4); +lean_dec(x_13); +x_15 = l___private_Init_Lean_WHNF_7__extractIdRhs(x_14); +x_16 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_15, x_5, x_6); +return x_16; +} +} +} +lean_object* l_Lean_unfoldDefinitionAux___at_Lean_Meta_whnfImpl___main___spec__11(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +switch (lean_obj_tag(x_2)) { +case 4: +{ +lean_object* x_5; lean_object* x_6; uint8_t x_7; lean_object* x_8; +x_5 = lean_ctor_get(x_2, 0); +lean_inc(x_5); +x_6 = lean_ctor_get(x_2, 1); +lean_inc(x_6); +lean_dec(x_2); +x_7 = 0; +x_8 = l_Lean_Meta_getConstAux(x_5, x_7, x_3, x_4); +if (lean_obj_tag(x_8) == 0) +{ +lean_object* x_9; +x_9 = lean_ctor_get(x_8, 0); +lean_inc(x_9); +if (lean_obj_tag(x_9) == 0) +{ +uint8_t x_10; +lean_dec(x_6); +lean_dec(x_3); +x_10 = !lean_is_exclusive(x_8); +if (x_10 == 0) +{ +lean_object* x_11; +x_11 = lean_ctor_get(x_8, 0); +lean_dec(x_11); +lean_ctor_set(x_8, 0, x_1); +return x_8; +} +else +{ +lean_object* x_12; lean_object* x_13; +x_12 = lean_ctor_get(x_8, 1); +lean_inc(x_12); +lean_dec(x_8); +x_13 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_13, 0, x_1); +lean_ctor_set(x_13, 1, x_12); return x_13; } } -lean_object* l_Lean_Meta_whnfAux(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6) { +else +{ +lean_object* x_14; +x_14 = lean_ctor_get(x_9, 0); +lean_inc(x_14); +lean_dec(x_9); +if (lean_obj_tag(x_14) == 1) +{ +lean_object* x_15; lean_object* x_16; +x_15 = lean_ctor_get(x_8, 1); +lean_inc(x_15); +lean_dec(x_8); +x_16 = l___private_Init_Lean_WHNF_8__deltaDefinition___at_Lean_Meta_whnfImpl___main___spec__12(x_1, x_14, x_6, x_3, x_15); +return x_16; +} +else +{ +uint8_t x_17; +lean_dec(x_14); +lean_dec(x_6); +lean_dec(x_3); +x_17 = !lean_is_exclusive(x_8); +if (x_17 == 0) +{ +lean_object* x_18; +x_18 = lean_ctor_get(x_8, 0); +lean_dec(x_18); +lean_ctor_set(x_8, 0, x_1); +return x_8; +} +else +{ +lean_object* x_19; lean_object* x_20; +x_19 = lean_ctor_get(x_8, 1); +lean_inc(x_19); +lean_dec(x_8); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_1); +lean_ctor_set(x_20, 1, x_19); +return x_20; +} +} +} +} +else +{ +uint8_t x_21; +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_1); +x_21 = !lean_is_exclusive(x_8); +if (x_21 == 0) +{ +return x_8; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_8, 0); +x_23 = lean_ctor_get(x_8, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_8); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +case 5: +{ +lean_object* x_25; lean_object* x_26; +x_25 = lean_ctor_get(x_2, 0); +lean_inc(x_25); +x_26 = l_Lean_Expr_getAppFn___main(x_25); +lean_dec(x_25); +if (lean_obj_tag(x_26) == 4) +{ +lean_object* x_27; lean_object* x_28; uint8_t x_29; lean_object* x_30; +x_27 = lean_ctor_get(x_26, 0); +lean_inc(x_27); +x_28 = lean_ctor_get(x_26, 1); +lean_inc(x_28); +lean_dec(x_26); +x_29 = 0; +x_30 = l_Lean_Meta_getConstAux(x_27, x_29, x_3, x_4); +if (lean_obj_tag(x_30) == 0) +{ +lean_object* x_31; +x_31 = lean_ctor_get(x_30, 0); +lean_inc(x_31); +if (lean_obj_tag(x_31) == 0) +{ +uint8_t x_32; +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_32 = !lean_is_exclusive(x_30); +if (x_32 == 0) +{ +lean_object* x_33; +x_33 = lean_ctor_get(x_30, 0); +lean_dec(x_33); +lean_ctor_set(x_30, 0, x_1); +return x_30; +} +else +{ +lean_object* x_34; lean_object* x_35; +x_34 = lean_ctor_get(x_30, 1); +lean_inc(x_34); +lean_dec(x_30); +x_35 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_35, 0, x_1); +lean_ctor_set(x_35, 1, x_34); +return x_35; +} +} +else +{ +uint8_t x_36; +x_36 = !lean_is_exclusive(x_30); +if (x_36 == 0) +{ +lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; +x_37 = lean_ctor_get(x_30, 1); +x_38 = lean_ctor_get(x_30, 0); +lean_dec(x_38); +x_39 = lean_ctor_get(x_31, 0); +lean_inc(x_39); +lean_dec(x_31); +x_40 = l_Lean_ConstantInfo_lparams(x_39); +x_41 = lean_unsigned_to_nat(0u); +x_42 = l_List_lengthAux___main___rarg(x_40, x_41); +lean_dec(x_40); +x_43 = l_List_lengthAux___main___rarg(x_28, x_41); +x_44 = lean_nat_dec_eq(x_42, x_43); +lean_dec(x_43); +lean_dec(x_42); +if (x_44 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_30, 0, x_1); +return x_30; +} +else +{ +lean_object* x_45; lean_object* x_46; lean_object* x_47; lean_object* x_48; +lean_free_object(x_30); +x_45 = l_Lean_ConstantInfo_name(x_39); +x_46 = l_Lean_smartUnfoldingSuffix; +x_47 = lean_name_mk_string(x_45, x_46); +x_48 = l_Lean_Meta_getConstAux(x_47, x_29, x_3, x_37); +if (lean_obj_tag(x_48) == 0) +{ +lean_object* x_49; +x_49 = lean_ctor_get(x_48, 0); +lean_inc(x_49); +if (lean_obj_tag(x_49) == 0) +{ +uint8_t x_50; +x_50 = !lean_is_exclusive(x_48); +if (x_50 == 0) +{ +lean_object* x_51; lean_object* x_52; uint8_t x_53; +x_51 = lean_ctor_get(x_48, 1); +x_52 = lean_ctor_get(x_48, 0); +lean_dec(x_52); +x_53 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_53 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; +lean_free_object(x_48); +x_54 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_55 = lean_mk_empty_array_with_capacity(x_54); +lean_dec(x_54); +x_56 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_55); +x_57 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__13(x_1, x_39, x_28, x_56, x_3, x_51); +return x_57; +} +} +else +{ +lean_object* x_58; uint8_t x_59; +x_58 = lean_ctor_get(x_48, 1); +lean_inc(x_58); +lean_dec(x_48); +x_59 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_59 == 0) +{ +lean_object* x_60; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_60 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_60, 0, x_1); +lean_ctor_set(x_60, 1, x_58); +return x_60; +} +else +{ +lean_object* x_61; lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_61 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_62 = lean_mk_empty_array_with_capacity(x_61); +lean_dec(x_61); +x_63 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_62); +x_64 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__13(x_1, x_39, x_28, x_63, x_3, x_58); +return x_64; +} +} +} +else +{ +lean_object* x_65; +x_65 = lean_ctor_get(x_49, 0); +lean_inc(x_65); +lean_dec(x_49); +switch (lean_obj_tag(x_65)) { +case 0: +{ +uint8_t x_66; +lean_dec(x_65); +x_66 = !lean_is_exclusive(x_48); +if (x_66 == 0) +{ +lean_object* x_67; lean_object* x_68; uint8_t x_69; +x_67 = lean_ctor_get(x_48, 1); +x_68 = lean_ctor_get(x_48, 0); +lean_dec(x_68); +x_69 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_69 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; +lean_free_object(x_48); +x_70 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_71 = lean_mk_empty_array_with_capacity(x_70); +lean_dec(x_70); +x_72 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_71); +x_73 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__14(x_1, x_39, x_28, x_72, x_3, x_67); +return x_73; +} +} +else +{ +lean_object* x_74; uint8_t x_75; +x_74 = lean_ctor_get(x_48, 1); +lean_inc(x_74); +lean_dec(x_48); +x_75 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_75 == 0) +{ +lean_object* x_76; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_76 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_76, 0, x_1); +lean_ctor_set(x_76, 1, x_74); +return x_76; +} +else +{ +lean_object* x_77; lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_77 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_78 = lean_mk_empty_array_with_capacity(x_77); +lean_dec(x_77); +x_79 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_78); +x_80 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__14(x_1, x_39, x_28, x_79, x_3, x_74); +return x_80; +} +} +} +case 1: +{ +lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; +lean_dec(x_39); +x_81 = lean_ctor_get(x_48, 1); +lean_inc(x_81); +lean_dec(x_48); +x_82 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_83 = lean_mk_empty_array_with_capacity(x_82); +lean_dec(x_82); +x_84 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_83); +x_85 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__27(x_1, x_65, x_28, x_84, x_3, x_81); +return x_85; +} +case 2: +{ +uint8_t x_86; +lean_dec(x_65); +x_86 = !lean_is_exclusive(x_48); +if (x_86 == 0) +{ +lean_object* x_87; lean_object* x_88; uint8_t x_89; +x_87 = lean_ctor_get(x_48, 1); +x_88 = lean_ctor_get(x_48, 0); +lean_dec(x_88); +x_89 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_89 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_90; lean_object* x_91; lean_object* x_92; lean_object* x_93; +lean_free_object(x_48); +x_90 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_91 = lean_mk_empty_array_with_capacity(x_90); +lean_dec(x_90); +x_92 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_91); +x_93 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__28(x_1, x_39, x_28, x_92, x_3, x_87); +return x_93; +} +} +else +{ +lean_object* x_94; uint8_t x_95; +x_94 = lean_ctor_get(x_48, 1); +lean_inc(x_94); +lean_dec(x_48); +x_95 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_95 == 0) +{ +lean_object* x_96; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_96 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_96, 0, x_1); +lean_ctor_set(x_96, 1, x_94); +return x_96; +} +else +{ +lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; +x_97 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_98 = lean_mk_empty_array_with_capacity(x_97); +lean_dec(x_97); +x_99 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_98); +x_100 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__28(x_1, x_39, x_28, x_99, x_3, x_94); +return x_100; +} +} +} +case 3: +{ +uint8_t x_101; +lean_dec(x_65); +x_101 = !lean_is_exclusive(x_48); +if (x_101 == 0) +{ +lean_object* x_102; lean_object* x_103; uint8_t x_104; +x_102 = lean_ctor_get(x_48, 1); +x_103 = lean_ctor_get(x_48, 0); +lean_dec(x_103); +x_104 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_104 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_105; lean_object* x_106; lean_object* x_107; lean_object* x_108; +lean_free_object(x_48); +x_105 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_106 = lean_mk_empty_array_with_capacity(x_105); +lean_dec(x_105); +x_107 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_106); +x_108 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__29(x_1, x_39, x_28, x_107, x_3, x_102); +return x_108; +} +} +else +{ +lean_object* x_109; uint8_t x_110; +x_109 = lean_ctor_get(x_48, 1); +lean_inc(x_109); +lean_dec(x_48); +x_110 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_110 == 0) +{ +lean_object* x_111; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_111 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_111, 0, x_1); +lean_ctor_set(x_111, 1, x_109); +return x_111; +} +else +{ +lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; +x_112 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_113 = lean_mk_empty_array_with_capacity(x_112); +lean_dec(x_112); +x_114 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_113); +x_115 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__29(x_1, x_39, x_28, x_114, x_3, x_109); +return x_115; +} +} +} +case 4: +{ +uint8_t x_116; +lean_dec(x_65); +x_116 = !lean_is_exclusive(x_48); +if (x_116 == 0) +{ +lean_object* x_117; lean_object* x_118; uint8_t x_119; +x_117 = lean_ctor_get(x_48, 1); +x_118 = lean_ctor_get(x_48, 0); +lean_dec(x_118); +x_119 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_119 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_120; lean_object* x_121; lean_object* x_122; lean_object* x_123; +lean_free_object(x_48); +x_120 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_121 = lean_mk_empty_array_with_capacity(x_120); +lean_dec(x_120); +x_122 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_121); +x_123 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__30(x_1, x_39, x_28, x_122, x_3, x_117); +return x_123; +} +} +else +{ +lean_object* x_124; uint8_t x_125; +x_124 = lean_ctor_get(x_48, 1); +lean_inc(x_124); +lean_dec(x_48); +x_125 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_125 == 0) +{ +lean_object* x_126; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_126 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_126, 0, x_1); +lean_ctor_set(x_126, 1, x_124); +return x_126; +} +else +{ +lean_object* x_127; lean_object* x_128; lean_object* x_129; lean_object* x_130; +x_127 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_128 = lean_mk_empty_array_with_capacity(x_127); +lean_dec(x_127); +x_129 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_128); +x_130 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__30(x_1, x_39, x_28, x_129, x_3, x_124); +return x_130; +} +} +} +case 5: +{ +uint8_t x_131; +lean_dec(x_65); +x_131 = !lean_is_exclusive(x_48); +if (x_131 == 0) +{ +lean_object* x_132; lean_object* x_133; uint8_t x_134; +x_132 = lean_ctor_get(x_48, 1); +x_133 = lean_ctor_get(x_48, 0); +lean_dec(x_133); +x_134 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_134 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_135; lean_object* x_136; lean_object* x_137; lean_object* x_138; +lean_free_object(x_48); +x_135 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_136 = lean_mk_empty_array_with_capacity(x_135); +lean_dec(x_135); +x_137 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_136); +x_138 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__31(x_1, x_39, x_28, x_137, x_3, x_132); +return x_138; +} +} +else +{ +lean_object* x_139; uint8_t x_140; +x_139 = lean_ctor_get(x_48, 1); +lean_inc(x_139); +lean_dec(x_48); +x_140 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_140 == 0) +{ +lean_object* x_141; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_141 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_141, 0, x_1); +lean_ctor_set(x_141, 1, x_139); +return x_141; +} +else +{ +lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; +x_142 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_143 = lean_mk_empty_array_with_capacity(x_142); +lean_dec(x_142); +x_144 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_143); +x_145 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__31(x_1, x_39, x_28, x_144, x_3, x_139); +return x_145; +} +} +} +case 6: +{ +uint8_t x_146; +lean_dec(x_65); +x_146 = !lean_is_exclusive(x_48); +if (x_146 == 0) +{ +lean_object* x_147; lean_object* x_148; uint8_t x_149; +x_147 = lean_ctor_get(x_48, 1); +x_148 = lean_ctor_get(x_48, 0); +lean_dec(x_148); +x_149 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_149 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; +lean_free_object(x_48); +x_150 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_151 = lean_mk_empty_array_with_capacity(x_150); +lean_dec(x_150); +x_152 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_151); +x_153 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__32(x_1, x_39, x_28, x_152, x_3, x_147); +return x_153; +} +} +else +{ +lean_object* x_154; uint8_t x_155; +x_154 = lean_ctor_get(x_48, 1); +lean_inc(x_154); +lean_dec(x_48); +x_155 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_155 == 0) +{ +lean_object* x_156; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_156 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_156, 0, x_1); +lean_ctor_set(x_156, 1, x_154); +return x_156; +} +else +{ +lean_object* x_157; lean_object* x_158; lean_object* x_159; lean_object* x_160; +x_157 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_158 = lean_mk_empty_array_with_capacity(x_157); +lean_dec(x_157); +x_159 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_158); +x_160 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__32(x_1, x_39, x_28, x_159, x_3, x_154); +return x_160; +} +} +} +default: +{ +uint8_t x_161; +lean_dec(x_65); +x_161 = !lean_is_exclusive(x_48); +if (x_161 == 0) +{ +lean_object* x_162; lean_object* x_163; uint8_t x_164; +x_162 = lean_ctor_get(x_48, 1); +x_163 = lean_ctor_get(x_48, 0); +lean_dec(x_163); +x_164 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_164 == 0) +{ +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_ctor_set(x_48, 0, x_1); +return x_48; +} +else +{ +lean_object* x_165; lean_object* x_166; lean_object* x_167; lean_object* x_168; +lean_free_object(x_48); +x_165 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_166 = lean_mk_empty_array_with_capacity(x_165); +lean_dec(x_165); +x_167 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_166); +x_168 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__33(x_1, x_39, x_28, x_167, x_3, x_162); +return x_168; +} +} +else +{ +lean_object* x_169; uint8_t x_170; +x_169 = lean_ctor_get(x_48, 1); +lean_inc(x_169); +lean_dec(x_48); +x_170 = l_Lean_ConstantInfo_hasValue(x_39); +if (x_170 == 0) +{ +lean_object* x_171; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_171 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_171, 0, x_1); +lean_ctor_set(x_171, 1, x_169); +return x_171; +} +else +{ +lean_object* x_172; lean_object* x_173; lean_object* x_174; lean_object* x_175; +x_172 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_41); +x_173 = lean_mk_empty_array_with_capacity(x_172); +lean_dec(x_172); +x_174 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_173); +x_175 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__33(x_1, x_39, x_28, x_174, x_3, x_169); +return x_175; +} +} +} +} +} +} +else +{ +uint8_t x_176; +lean_dec(x_39); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_176 = !lean_is_exclusive(x_48); +if (x_176 == 0) +{ +return x_48; +} +else +{ +lean_object* x_177; lean_object* x_178; lean_object* x_179; +x_177 = lean_ctor_get(x_48, 0); +x_178 = lean_ctor_get(x_48, 1); +lean_inc(x_178); +lean_inc(x_177); +lean_dec(x_48); +x_179 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_179, 0, x_177); +lean_ctor_set(x_179, 1, x_178); +return x_179; +} +} +} +} +else +{ +lean_object* x_180; lean_object* x_181; lean_object* x_182; lean_object* x_183; lean_object* x_184; lean_object* x_185; uint8_t x_186; +x_180 = lean_ctor_get(x_30, 1); +lean_inc(x_180); +lean_dec(x_30); +x_181 = lean_ctor_get(x_31, 0); +lean_inc(x_181); +lean_dec(x_31); +x_182 = l_Lean_ConstantInfo_lparams(x_181); +x_183 = lean_unsigned_to_nat(0u); +x_184 = l_List_lengthAux___main___rarg(x_182, x_183); +lean_dec(x_182); +x_185 = l_List_lengthAux___main___rarg(x_28, x_183); +x_186 = lean_nat_dec_eq(x_184, x_185); +lean_dec(x_185); +lean_dec(x_184); +if (x_186 == 0) +{ +lean_object* x_187; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +x_187 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_187, 0, x_1); +lean_ctor_set(x_187, 1, x_180); +return x_187; +} +else +{ +lean_object* x_188; lean_object* x_189; lean_object* x_190; lean_object* x_191; +x_188 = l_Lean_ConstantInfo_name(x_181); +x_189 = l_Lean_smartUnfoldingSuffix; +x_190 = lean_name_mk_string(x_188, x_189); +x_191 = l_Lean_Meta_getConstAux(x_190, x_29, x_3, x_180); +if (lean_obj_tag(x_191) == 0) +{ +lean_object* x_192; +x_192 = lean_ctor_get(x_191, 0); +lean_inc(x_192); +if (lean_obj_tag(x_192) == 0) +{ +lean_object* x_193; lean_object* x_194; uint8_t x_195; +x_193 = lean_ctor_get(x_191, 1); +lean_inc(x_193); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_194 = x_191; +} else { + lean_dec_ref(x_191); + x_194 = lean_box(0); +} +x_195 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_195 == 0) +{ +lean_object* x_196; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_194)) { + x_196 = lean_alloc_ctor(0, 2, 0); +} else { + x_196 = x_194; +} +lean_ctor_set(x_196, 0, x_1); +lean_ctor_set(x_196, 1, x_193); +return x_196; +} +else +{ +lean_object* x_197; lean_object* x_198; lean_object* x_199; lean_object* x_200; +lean_dec(x_194); +x_197 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_198 = lean_mk_empty_array_with_capacity(x_197); +lean_dec(x_197); +x_199 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_198); +x_200 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__13(x_1, x_181, x_28, x_199, x_3, x_193); +return x_200; +} +} +else +{ +lean_object* x_201; +x_201 = lean_ctor_get(x_192, 0); +lean_inc(x_201); +lean_dec(x_192); +switch (lean_obj_tag(x_201)) { +case 0: +{ +lean_object* x_202; lean_object* x_203; uint8_t x_204; +lean_dec(x_201); +x_202 = lean_ctor_get(x_191, 1); +lean_inc(x_202); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_203 = x_191; +} else { + lean_dec_ref(x_191); + x_203 = lean_box(0); +} +x_204 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_204 == 0) +{ +lean_object* x_205; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_203)) { + x_205 = lean_alloc_ctor(0, 2, 0); +} else { + x_205 = x_203; +} +lean_ctor_set(x_205, 0, x_1); +lean_ctor_set(x_205, 1, x_202); +return x_205; +} +else +{ +lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +lean_dec(x_203); +x_206 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_207 = lean_mk_empty_array_with_capacity(x_206); +lean_dec(x_206); +x_208 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_207); +x_209 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__14(x_1, x_181, x_28, x_208, x_3, x_202); +return x_209; +} +} +case 1: +{ +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; +lean_dec(x_181); +x_210 = lean_ctor_get(x_191, 1); +lean_inc(x_210); +lean_dec(x_191); +x_211 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_212 = lean_mk_empty_array_with_capacity(x_211); +lean_dec(x_211); +x_213 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_212); +x_214 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__27(x_1, x_201, x_28, x_213, x_3, x_210); +return x_214; +} +case 2: +{ +lean_object* x_215; lean_object* x_216; uint8_t x_217; +lean_dec(x_201); +x_215 = lean_ctor_get(x_191, 1); +lean_inc(x_215); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_216 = x_191; +} else { + lean_dec_ref(x_191); + x_216 = lean_box(0); +} +x_217 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_217 == 0) +{ +lean_object* x_218; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_216)) { + x_218 = lean_alloc_ctor(0, 2, 0); +} else { + x_218 = x_216; +} +lean_ctor_set(x_218, 0, x_1); +lean_ctor_set(x_218, 1, x_215); +return x_218; +} +else +{ +lean_object* x_219; lean_object* x_220; lean_object* x_221; lean_object* x_222; +lean_dec(x_216); +x_219 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_220 = lean_mk_empty_array_with_capacity(x_219); +lean_dec(x_219); +x_221 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_220); +x_222 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__28(x_1, x_181, x_28, x_221, x_3, x_215); +return x_222; +} +} +case 3: +{ +lean_object* x_223; lean_object* x_224; uint8_t x_225; +lean_dec(x_201); +x_223 = lean_ctor_get(x_191, 1); +lean_inc(x_223); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_224 = x_191; +} else { + lean_dec_ref(x_191); + x_224 = lean_box(0); +} +x_225 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_225 == 0) +{ +lean_object* x_226; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_224)) { + x_226 = lean_alloc_ctor(0, 2, 0); +} else { + x_226 = x_224; +} +lean_ctor_set(x_226, 0, x_1); +lean_ctor_set(x_226, 1, x_223); +return x_226; +} +else +{ +lean_object* x_227; lean_object* x_228; lean_object* x_229; lean_object* x_230; +lean_dec(x_224); +x_227 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_228 = lean_mk_empty_array_with_capacity(x_227); +lean_dec(x_227); +x_229 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_228); +x_230 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__29(x_1, x_181, x_28, x_229, x_3, x_223); +return x_230; +} +} +case 4: +{ +lean_object* x_231; lean_object* x_232; uint8_t x_233; +lean_dec(x_201); +x_231 = lean_ctor_get(x_191, 1); +lean_inc(x_231); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_232 = x_191; +} else { + lean_dec_ref(x_191); + x_232 = lean_box(0); +} +x_233 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_233 == 0) +{ +lean_object* x_234; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_232)) { + x_234 = lean_alloc_ctor(0, 2, 0); +} else { + x_234 = x_232; +} +lean_ctor_set(x_234, 0, x_1); +lean_ctor_set(x_234, 1, x_231); +return x_234; +} +else +{ +lean_object* x_235; lean_object* x_236; lean_object* x_237; lean_object* x_238; +lean_dec(x_232); +x_235 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_236 = lean_mk_empty_array_with_capacity(x_235); +lean_dec(x_235); +x_237 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_236); +x_238 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__30(x_1, x_181, x_28, x_237, x_3, x_231); +return x_238; +} +} +case 5: +{ +lean_object* x_239; lean_object* x_240; uint8_t x_241; +lean_dec(x_201); +x_239 = lean_ctor_get(x_191, 1); +lean_inc(x_239); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_240 = x_191; +} else { + lean_dec_ref(x_191); + x_240 = lean_box(0); +} +x_241 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_241 == 0) +{ +lean_object* x_242; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_240)) { + x_242 = lean_alloc_ctor(0, 2, 0); +} else { + x_242 = x_240; +} +lean_ctor_set(x_242, 0, x_1); +lean_ctor_set(x_242, 1, x_239); +return x_242; +} +else +{ +lean_object* x_243; lean_object* x_244; lean_object* x_245; lean_object* x_246; +lean_dec(x_240); +x_243 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_244 = lean_mk_empty_array_with_capacity(x_243); +lean_dec(x_243); +x_245 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_244); +x_246 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__31(x_1, x_181, x_28, x_245, x_3, x_239); +return x_246; +} +} +case 6: +{ +lean_object* x_247; lean_object* x_248; uint8_t x_249; +lean_dec(x_201); +x_247 = lean_ctor_get(x_191, 1); +lean_inc(x_247); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_248 = x_191; +} else { + lean_dec_ref(x_191); + x_248 = lean_box(0); +} +x_249 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_249 == 0) +{ +lean_object* x_250; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_248)) { + x_250 = lean_alloc_ctor(0, 2, 0); +} else { + x_250 = x_248; +} +lean_ctor_set(x_250, 0, x_1); +lean_ctor_set(x_250, 1, x_247); +return x_250; +} +else +{ +lean_object* x_251; lean_object* x_252; lean_object* x_253; lean_object* x_254; +lean_dec(x_248); +x_251 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_252 = lean_mk_empty_array_with_capacity(x_251); +lean_dec(x_251); +x_253 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_252); +x_254 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__32(x_1, x_181, x_28, x_253, x_3, x_247); +return x_254; +} +} +default: +{ +lean_object* x_255; lean_object* x_256; uint8_t x_257; +lean_dec(x_201); +x_255 = lean_ctor_get(x_191, 1); +lean_inc(x_255); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_256 = x_191; +} else { + lean_dec_ref(x_191); + x_256 = lean_box(0); +} +x_257 = l_Lean_ConstantInfo_hasValue(x_181); +if (x_257 == 0) +{ +lean_object* x_258; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +if (lean_is_scalar(x_256)) { + x_258 = lean_alloc_ctor(0, 2, 0); +} else { + x_258 = x_256; +} +lean_ctor_set(x_258, 0, x_1); +lean_ctor_set(x_258, 1, x_255); +return x_258; +} +else +{ +lean_object* x_259; lean_object* x_260; lean_object* x_261; lean_object* x_262; +lean_dec(x_256); +x_259 = l_Lean_Expr_getAppNumArgsAux___main(x_2, x_183); +x_260 = lean_mk_empty_array_with_capacity(x_259); +lean_dec(x_259); +x_261 = l___private_Init_Lean_Expr_4__getAppRevArgsAux___main(x_2, x_260); +x_262 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__33(x_1, x_181, x_28, x_261, x_3, x_255); +return x_262; +} +} +} +} +} +else +{ +lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; +lean_dec(x_181); +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_263 = lean_ctor_get(x_191, 0); +lean_inc(x_263); +x_264 = lean_ctor_get(x_191, 1); +lean_inc(x_264); +if (lean_is_exclusive(x_191)) { + lean_ctor_release(x_191, 0); + lean_ctor_release(x_191, 1); + x_265 = x_191; +} else { + lean_dec_ref(x_191); + x_265 = lean_box(0); +} +if (lean_is_scalar(x_265)) { + x_266 = lean_alloc_ctor(1, 2, 0); +} else { + x_266 = x_265; +} +lean_ctor_set(x_266, 0, x_263); +lean_ctor_set(x_266, 1, x_264); +return x_266; +} +} +} +} +} +else +{ +uint8_t x_267; +lean_dec(x_28); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_267 = !lean_is_exclusive(x_30); +if (x_267 == 0) +{ +return x_30; +} +else +{ +lean_object* x_268; lean_object* x_269; lean_object* x_270; +x_268 = lean_ctor_get(x_30, 0); +x_269 = lean_ctor_get(x_30, 1); +lean_inc(x_269); +lean_inc(x_268); +lean_dec(x_30); +x_270 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_270, 0, x_268); +lean_ctor_set(x_270, 1, x_269); +return x_270; +} +} +} +else +{ +lean_object* x_271; +lean_dec(x_26); +lean_dec(x_3); +lean_dec(x_2); +x_271 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_271, 0, x_1); +lean_ctor_set(x_271, 1, x_4); +return x_271; +} +} +default: +{ +lean_object* x_272; +lean_dec(x_3); +lean_dec(x_2); +x_272 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_272, 0, x_1); +lean_ctor_set(x_272, 1, x_4); +return x_272; +} +} +} +} +lean_object* _init_l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34___closed__1() { _start: { -lean_object* x_7; -x_7 = l_Lean_Meta_whnfAux___main(x_1, x_2, x_3, x_4, x_5, x_6); +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1; +x_2 = l_Lean_Expr_Inhabited; +x_3 = l_monadInhabited___rarg(x_1, x_2); +return x_3; +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +switch (lean_obj_tag(x_1)) { +case 0: +{ +lean_object* x_4; lean_object* x_5; lean_object* x_6; +lean_dec(x_1); +x_4 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34___closed__1; +x_5 = l_unreachable_x21___rarg(x_4); +x_6 = lean_apply_2(x_5, x_2, x_3); +return x_6; +} +case 1: +{ +lean_object* x_7; lean_object* x_8; +x_7 = lean_ctor_get(x_1, 0); +lean_inc(x_7); +lean_inc(x_2); +x_8 = l_Lean_Meta_getLocalDecl(x_7, x_2, x_3); +if (lean_obj_tag(x_8) == 0) +{ +uint8_t x_9; +x_9 = !lean_is_exclusive(x_8); +if (x_9 == 0) +{ +lean_object* x_10; lean_object* x_11; lean_object* x_12; +x_10 = lean_ctor_get(x_8, 0); +x_11 = lean_ctor_get(x_8, 1); +x_12 = l_Lean_LocalDecl_value_x3f(x_10); +lean_dec(x_10); +if (lean_obj_tag(x_12) == 0) +{ +lean_dec(x_2); +lean_ctor_set(x_8, 0, x_1); +return x_8; +} +else +{ +lean_object* x_13; +lean_free_object(x_8); +lean_dec(x_1); +x_13 = lean_ctor_get(x_12, 0); +lean_inc(x_13); +lean_dec(x_12); +x_1 = x_13; +x_3 = x_11; +goto _start; +} +} +else +{ +lean_object* x_15; lean_object* x_16; lean_object* x_17; +x_15 = lean_ctor_get(x_8, 0); +x_16 = lean_ctor_get(x_8, 1); +lean_inc(x_16); +lean_inc(x_15); +lean_dec(x_8); +x_17 = l_Lean_LocalDecl_value_x3f(x_15); +lean_dec(x_15); +if (lean_obj_tag(x_17) == 0) +{ +lean_object* x_18; +lean_dec(x_2); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_1); +lean_ctor_set(x_18, 1, x_16); +return x_18; +} +else +{ +lean_object* x_19; +lean_dec(x_1); +x_19 = lean_ctor_get(x_17, 0); +lean_inc(x_19); +lean_dec(x_17); +x_1 = x_19; +x_3 = x_16; +goto _start; +} +} +} +else +{ +uint8_t x_21; +lean_dec(x_2); +lean_dec(x_1); +x_21 = !lean_is_exclusive(x_8); +if (x_21 == 0) +{ +return x_8; +} +else +{ +lean_object* x_22; lean_object* x_23; lean_object* x_24; +x_22 = lean_ctor_get(x_8, 0); +x_23 = lean_ctor_get(x_8, 1); +lean_inc(x_23); +lean_inc(x_22); +lean_dec(x_8); +x_24 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_24, 0, x_22); +lean_ctor_set(x_24, 1, x_23); +return x_24; +} +} +} +case 2: +{ +lean_object* x_25; lean_object* x_26; lean_object* x_27; +x_25 = lean_ctor_get(x_1, 0); +lean_inc(x_25); +x_26 = lean_ctor_get(x_3, 1); +lean_inc(x_26); +x_27 = lean_metavar_ctx_get_expr_assignment(x_26, x_25); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; +lean_dec(x_2); +x_28 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_28, 0, x_1); +lean_ctor_set(x_28, 1, x_3); +return x_28; +} +else +{ +lean_object* x_29; +lean_dec(x_1); +x_29 = lean_ctor_get(x_27, 0); +lean_inc(x_29); +lean_dec(x_27); +x_1 = x_29; +goto _start; +} +} +case 4: +{ +lean_object* x_31; +lean_inc(x_2); +x_31 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_1, x_2, x_3); +if (lean_obj_tag(x_31) == 0) +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_31, 0); +lean_inc(x_32); +x_33 = lean_ctor_get(x_31, 1); +lean_inc(x_33); +lean_dec(x_31); +lean_inc(x_32); +x_34 = l_Lean_unfoldDefinitionAux___at_Lean_Meta_whnfImpl___main___spec__11(x_32, x_32, x_2, x_33); +return x_34; +} +else +{ +uint8_t x_35; +lean_dec(x_2); +x_35 = !lean_is_exclusive(x_31); +if (x_35 == 0) +{ +return x_31; +} +else +{ +lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_36 = lean_ctor_get(x_31, 0); +x_37 = lean_ctor_get(x_31, 1); +lean_inc(x_37); +lean_inc(x_36); +lean_dec(x_31); +x_38 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_38, 0, x_36); +lean_ctor_set(x_38, 1, x_37); +return x_38; +} +} +} +case 5: +{ +lean_object* x_39; +lean_inc(x_2); +x_39 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_1, x_2, x_3); +if (lean_obj_tag(x_39) == 0) +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_40 = lean_ctor_get(x_39, 0); +lean_inc(x_40); +x_41 = lean_ctor_get(x_39, 1); +lean_inc(x_41); +lean_dec(x_39); +lean_inc(x_40); +x_42 = l_Lean_unfoldDefinitionAux___at_Lean_Meta_whnfImpl___main___spec__11(x_40, x_40, x_2, x_41); +return x_42; +} +else +{ +uint8_t x_43; +lean_dec(x_2); +x_43 = !lean_is_exclusive(x_39); +if (x_43 == 0) +{ +return x_39; +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_44 = lean_ctor_get(x_39, 0); +x_45 = lean_ctor_get(x_39, 1); +lean_inc(x_45); +lean_inc(x_44); +lean_dec(x_39); +x_46 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_46, 0, x_44); +lean_ctor_set(x_46, 1, x_45); +return x_46; +} +} +} +case 8: +{ +lean_object* x_47; +lean_inc(x_2); +x_47 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_1, x_2, x_3); +if (lean_obj_tag(x_47) == 0) +{ +lean_object* x_48; lean_object* x_49; lean_object* x_50; +x_48 = lean_ctor_get(x_47, 0); +lean_inc(x_48); +x_49 = lean_ctor_get(x_47, 1); +lean_inc(x_49); +lean_dec(x_47); +lean_inc(x_48); +x_50 = l_Lean_unfoldDefinitionAux___at_Lean_Meta_whnfImpl___main___spec__11(x_48, x_48, x_2, x_49); +return x_50; +} +else +{ +uint8_t x_51; +lean_dec(x_2); +x_51 = !lean_is_exclusive(x_47); +if (x_51 == 0) +{ +return x_47; +} +else +{ +lean_object* x_52; lean_object* x_53; lean_object* x_54; +x_52 = lean_ctor_get(x_47, 0); +x_53 = lean_ctor_get(x_47, 1); +lean_inc(x_53); +lean_inc(x_52); +lean_dec(x_47); +x_54 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_54, 0, x_52); +lean_ctor_set(x_54, 1, x_53); +return x_54; +} +} +} +case 10: +{ +lean_object* x_55; +x_55 = lean_ctor_get(x_1, 1); +lean_inc(x_55); +lean_dec(x_1); +x_1 = x_55; +goto _start; +} +case 11: +{ +lean_object* x_57; +lean_inc(x_2); +x_57 = l_Lean_whnfCore___main___at_Lean_Meta_whnfImpl___main___spec__1(x_1, x_2, x_3); +if (lean_obj_tag(x_57) == 0) +{ +lean_object* x_58; lean_object* x_59; lean_object* x_60; +x_58 = lean_ctor_get(x_57, 0); +lean_inc(x_58); +x_59 = lean_ctor_get(x_57, 1); +lean_inc(x_59); +lean_dec(x_57); +lean_inc(x_58); +x_60 = l_Lean_unfoldDefinitionAux___at_Lean_Meta_whnfImpl___main___spec__11(x_58, x_58, x_2, x_59); +return x_60; +} +else +{ +uint8_t x_61; +lean_dec(x_2); +x_61 = !lean_is_exclusive(x_57); +if (x_61 == 0) +{ +return x_57; +} +else +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; +x_62 = lean_ctor_get(x_57, 0); +x_63 = lean_ctor_get(x_57, 1); +lean_inc(x_63); +lean_inc(x_62); +lean_dec(x_57); +x_64 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_64, 0, x_62); +lean_ctor_set(x_64, 1, x_63); +return x_64; +} +} +} +case 12: +{ +lean_object* x_65; lean_object* x_66; lean_object* x_67; +lean_dec(x_1); +x_65 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34___closed__1; +x_66 = l_unreachable_x21___rarg(x_65); +x_67 = lean_apply_2(x_66, x_2, x_3); +return x_67; +} +default: +{ +lean_object* x_68; +lean_dec(x_2); +x_68 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_68, 0, x_1); +lean_ctor_set(x_68, 1, x_3); +return x_68; +} +} +} +} +lean_object* l_Lean_Meta_whnfImpl___main(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_1, x_2, x_3); +return x_4; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__2___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__3___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__3(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l___private_Init_Lean_WHNF_2__mkNullaryCtor___at_Lean_Meta_whnfImpl___main___spec__6(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +return x_6; +} +} +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__8___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; lean_object* x_6; +x_5 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__8(x_1, x_2, x_3, x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_6 = lean_box(x_5); +return x_6; +} +} +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__9___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__9(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_7 = lean_box(x_6); return x_7; } } +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__4___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__4(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__10___lambda__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +return x_6; +} +} +lean_object* l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__17___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l___private_Init_Lean_WHNF_9__deltaBetaDefinition___at_Lean_Meta_whnfImpl___main___spec__17(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__18___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_reduceQuotRec___at_Lean_Meta_whnfImpl___main___spec__18(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__21___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4) { +_start: +{ +uint8_t x_5; lean_object* x_6; +x_5 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__21(x_1, x_2, x_3, x_4); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +x_6 = lean_box(x_5); +return x_6; +} +} +lean_object* l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__22___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +uint8_t x_6; lean_object* x_7; +x_6 = l_Array_anyRangeMAux___main___at_Lean_Meta_whnfImpl___main___spec__22(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_7 = lean_box(x_6); +return x_7; +} +} +lean_object* l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__19___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5, lean_object* x_6, lean_object* x_7, lean_object* x_8) { +_start: +{ +lean_object* x_9; +x_9 = l_Lean_reduceRec___at_Lean_Meta_whnfImpl___main___spec__19(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8); +lean_dec(x_6); +lean_dec(x_3); +lean_dec(x_2); +return x_9; +} +} +lean_object* l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__1___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__23___lambda__1(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +return x_6; +} +} +lean_object* l_Lean_isQuotRecStuck___at_Lean_Meta_whnfImpl___main___spec__25___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_isQuotRecStuck___at_Lean_Meta_whnfImpl___main___spec__25(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_Lean_isRecStuck___at_Lean_Meta_whnfImpl___main___spec__26___boxed(lean_object* x_1, lean_object* x_2, lean_object* x_3, lean_object* x_4, lean_object* x_5) { +_start: +{ +lean_object* x_6; +x_6 = l_Lean_isRecStuck___at_Lean_Meta_whnfImpl___main___spec__26(x_1, x_2, x_3, x_4, x_5); +lean_dec(x_3); +lean_dec(x_2); +lean_dec(x_1); +return x_6; +} +} +lean_object* l_Lean_Meta_whnfImpl(lean_object* x_1, lean_object* x_2, lean_object* x_3) { +_start: +{ +lean_object* x_4; +x_4 = l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34(x_1, x_2, x_3); +return x_4; +} +} +lean_object* _init_l_Lean_Meta_setWHNFRef___closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_alloc_closure((void*)(l_Lean_Meta_whnfImpl), 3, 0); +return x_1; +} +} +lean_object* l_Lean_Meta_setWHNFRef(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_2 = l_Lean_Meta_whnfRef; +x_3 = l_Lean_Meta_setWHNFRef___closed__1; +x_4 = lean_io_ref_set(x_2, x_3, x_1); +return x_4; +} +} lean_object* initialize_Init_Lean_AuxRecursor(lean_object*); lean_object* initialize_Init_Lean_WHNF(lean_object*); lean_object* initialize_Init_Lean_Meta_Basic(lean_object*); +lean_object* initialize_Init_Lean_Meta_LevelDefEq(lean_object*); static bool _G_initialized = false; lean_object* initialize_Init_Lean_Meta_WHNF(lean_object* w) { lean_object * res; @@ -276,6 +12233,9 @@ lean_dec_ref(res); res = initialize_Init_Lean_Meta_Basic(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); +res = initialize_Init_Lean_Meta_LevelDefEq(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1 = _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1(); lean_mark_persistent(l_Lean_Meta_unfoldDefinitionAux___rarg___closed__1); l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2 = _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__2(); @@ -286,6 +12246,21 @@ l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4 = _init_l_Lean_Meta_unfoldDef lean_mark_persistent(l_Lean_Meta_unfoldDefinitionAux___rarg___closed__4); l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5 = _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5(); lean_mark_persistent(l_Lean_Meta_unfoldDefinitionAux___rarg___closed__5); +l_Lean_Meta_unfoldDefinitionAux___rarg___closed__6 = _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__6(); +lean_mark_persistent(l_Lean_Meta_unfoldDefinitionAux___rarg___closed__6); +l_Lean_Meta_unfoldDefinitionAux___rarg___closed__7 = _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__7(); +lean_mark_persistent(l_Lean_Meta_unfoldDefinitionAux___rarg___closed__7); +l_Lean_Meta_unfoldDefinitionAux___rarg___closed__8 = _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__8(); +lean_mark_persistent(l_Lean_Meta_unfoldDefinitionAux___rarg___closed__8); +l_Lean_Meta_unfoldDefinitionAux___rarg___closed__9 = _init_l_Lean_Meta_unfoldDefinitionAux___rarg___closed__9(); +lean_mark_persistent(l_Lean_Meta_unfoldDefinitionAux___rarg___closed__9); +l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34___closed__1 = _init_l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34___closed__1(); +lean_mark_persistent(l_Lean_whnfEasyCases___main___at_Lean_Meta_whnfImpl___main___spec__34___closed__1); +l_Lean_Meta_setWHNFRef___closed__1 = _init_l_Lean_Meta_setWHNFRef___closed__1(); +lean_mark_persistent(l_Lean_Meta_setWHNFRef___closed__1); +res = l_Lean_Meta_setWHNFRef(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; +lean_dec_ref(res); return lean_mk_io_result(lean_box(0)); } #ifdef __cplusplus diff --git a/stage0/src/shell/CMakeLists.txt b/stage0/src/shell/CMakeLists.txt index 1ead7d97d8..de3f017814 100644 --- a/stage0/src/shell/CMakeLists.txt +++ b/stage0/src/shell/CMakeLists.txt @@ -14,7 +14,7 @@ if(NOT STAGE0) # '-G Ninja' complains otherwise BYPRODUCTS "${CMAKE_BINARY_DIR}/stage1/libleanstdlib.a" WORKING_DIRECTORY "${LEAN_SOURCE_DIR}/../library" - COMMAND ${CMAKE_COMMAND} -E env "LEAN_PATH=." $(MAKE) "${CMAKE_BINARY_DIR}/stage1/libleanstdlib.a" "LEAN=$" "LEANC_OPTS=${LEANC_OPTS}" "STAGE1_OUT=${CMAKE_BINARY_DIR}/stage1" + COMMAND ${CMAKE_COMMAND} -E env "LEAN_PATH=Init=Init" $(MAKE) "${CMAKE_BINARY_DIR}/stage1/libleanstdlib.a" "LEAN=$" "LEANC_OPTS=${LEANC_OPTS}" "STAGE1_OUT=${CMAKE_BINARY_DIR}/stage1" DEPENDS stage0) set_target_properties(leanstdlib PROPERTIES IMPORTED_LOCATION "${CMAKE_BINARY_DIR}/stage1/libleanstdlib.a" @@ -245,15 +245,11 @@ if(${CMAKE_SYSTEM_NAME} MATCHES "Windows") # Skip stdlib tests on Windows message(STATUS "skipping stdlib tests") else() - file(GLOB_RECURSE STDLIBFILES "${LEAN_SOURCE_DIR}/../library/*.lean") - set(STDIDX 0) + file(GLOB_RECURSE STDLIBFILES RELATIVE "${LEAN_SOURCE_DIR}/../library" "${LEAN_SOURCE_DIR}/../library/*.lean") FOREACH(T ${STDLIBFILES}) - GET_FILENAME_COMPONENT(T_NAME ${T} NAME) - GET_FILENAME_COMPONENT(T_DIR ${T} DIRECTORY) - MATH(EXPR STDIDX "${STDIDX}+1") - add_test(NAME "stdlib_${STDIDX}" - WORKING_DIRECTORY "${T_DIR}" - COMMAND "${LEAN_SOURCE_DIR}/../bin/lean" ${T_NAME}) + add_test(NAME "stdlib_${T}" + WORKING_DIRECTORY "${LEAN_SOURCE_DIR}/../library" + COMMAND "${LEAN_SOURCE_DIR}/../bin/lean" "${T}") ENDFOREACH(T) endif()