From c55c8ee01b99dbcac8f136d5ba5fa0c5d238d0e5 Mon Sep 17 00:00:00 2001 From: Leonardo de Moura Date: Fri, 19 Feb 2021 13:53:08 -0800 Subject: [PATCH] chore: update stage0 --- stage0/src/Lean/Elab/Match.lean | 38 +- stage0/src/Lean/Elab/Tactic/Basic.lean | 2 +- stage0/src/Lean/Elab/Term.lean | 18 +- stage0/stdlib/Lean/Elab/Match.c | 4370 ++++++++++--------- stage0/stdlib/Lean/Elab/Tactic/Basic.c | 150 +- stage0/stdlib/Lean/Elab/Tactic/Match.c | 4 +- stage0/stdlib/Lean/Elab/Term.c | 5488 +++++++++++++----------- 7 files changed, 5465 insertions(+), 4605 deletions(-) diff --git a/stage0/src/Lean/Elab/Match.lean b/stage0/src/Lean/Elab/Match.lean index f7d8b40d53..baf49bc745 100644 --- a/stage0/src/Lean/Elab/Match.lean +++ b/stage0/src/Lean/Elab/Match.lean @@ -36,10 +36,11 @@ private def expandSimpleMatchWithType (stx discr lhsVar type rhs : Syntax) (expe let newStx ← `(let $lhsVar : $type := $discr; $rhs) withMacroExpansion stx newStx <| elabTerm newStx expectedType? -private def elabDiscrsWitMatchType (discrStxs : Array Syntax) (matchType : Expr) (expectedType : Expr) : TermElabM (Array Expr) := do +private def elabDiscrsWitMatchType (discrStxs : Array Syntax) (matchType : Expr) (expectedType : Expr) : TermElabM (Array Expr × Bool) := do let mut discrs := #[] let mut i := 0 let mut matchType := matchType + let mut isDep := false for discrStx in discrStxs do i := i + 1 matchType ← whnf matchType @@ -47,11 +48,13 @@ private def elabDiscrsWitMatchType (discrStxs : Array Syntax) (matchType : Expr) | Expr.forallE _ d b _ => let discr ← fullApproxDefEq <| elabTermEnsuringType discrStx[1] d trace[Elab.match]! "discr #{i} {discr} : {d}" + if b.hasLooseBVars then + isDep := true matchType ← b.instantiate1 discr discrs := discrs.push discr | _ => throwError! "invalid type provided to match-expression, function type with arity #{discrStxs.size} expected" - pure discrs + pure (discrs, isDep) private def mkUserNameFor (e : Expr) : TermElabM Name := match e with @@ -74,13 +77,19 @@ private def elabAtomicDiscr (discr : Syntax) : TermElabM Expr := do pure localDecl.value | _ => throwErrorAt discr "unexpected discriminant" +structure ElabMatchTypeAndDiscsResult where + discrs : Array Expr + matchType : Expr + isDep : Bool + alts : Array MatchAltView + private def elabMatchTypeAndDiscrs (discrStxs : Array Syntax) (matchOptType : Syntax) (matchAltViews : Array MatchAltView) (expectedType : Expr) - : TermElabM (Array Expr × Expr × Array MatchAltView) := do + : TermElabM ElabMatchTypeAndDiscsResult := do let numDiscrs := discrStxs.size if matchOptType.isNone then - let rec loop (i : Nat) (discrs : Array Expr) (matchType : Expr) (matchAltViews : Array MatchAltView) := do + let rec loop (i : Nat) (discrs : Array Expr) (matchType : Expr) (isDep : Bool) (matchAltViews : Array MatchAltView) := do match i with - | 0 => pure (discrs.reverse, matchType, matchAltViews) + | 0 => return { discrs := discrs.reverse, matchType := matchType, isDep := isDep, alts := matchAltViews } | i+1 => let discrStx := discrStxs[i] let discr ← elabAtomicDiscr discrStx @@ -88,9 +97,10 @@ private def elabMatchTypeAndDiscrs (discrStxs : Array Syntax) (matchOptType : Sy let discrType ← inferType discr let discrType ← instantiateMVars discrType let matchTypeBody ← kabstract matchType discr + let isDep := isDep || matchTypeBody.hasLooseBVars let userName ← mkUserNameFor discr if discrStx[0].isNone then - loop i (discrs.push discr) (Lean.mkForall userName BinderInfo.default discrType matchTypeBody) matchAltViews + loop i (discrs.push discr) (Lean.mkForall userName BinderInfo.default discrType matchTypeBody) isDep matchAltViews else let identStx := discrStx[0][0] withLocalDeclD userName discrType fun x => do @@ -102,13 +112,13 @@ private def elabMatchTypeAndDiscrs (discrStxs : Array Syntax) (matchOptType : Sy let discrs := (discrs.push refl).push discr let matchAltViews := matchAltViews.map fun altView => { altView with patterns := altView.patterns.insertAt (i+1) identStx } - loop i discrs matchType matchAltViews - loop discrStxs.size #[] expectedType matchAltViews + loop i discrs matchType isDep matchAltViews + loop discrStxs.size (discrs := #[]) (isDep := false) expectedType matchAltViews else let matchTypeStx := matchOptType[0][1] let matchType ← elabType matchTypeStx - let discrs ← elabDiscrsWitMatchType discrStxs matchType expectedType - pure (discrs, matchType, matchAltViews) + let (discrs, isDep) ← elabDiscrsWitMatchType discrStxs matchType expectedType + return { discrs := discrs, matchType := matchType, isDep := isDep, alts := matchAltViews } def expandMacrosInPatterns (matchAlts : Array MatchAltView) : MacroM (Array MatchAltView) := do matchAlts.mapM fun matchAlt => do @@ -723,8 +733,8 @@ private def isMatchUnit? (altLHSS : List Match.AltLHS) (rhss : Array Expr) : Met private def elabMatchAux (discrStxs : Array Syntax) (altViews : Array MatchAltView) (matchOptType : Syntax) (expectedType : Expr) : TermElabM Expr := do - let (discrs, matchType, altLHSS, rhss) ← commitIfDidNotPostpone do - let (discrs, matchType, altViews) ← elabMatchTypeAndDiscrs discrStxs matchOptType altViews expectedType + let (discrs, matchType, altLHSS, isDep, rhss) ← commitIfDidNotPostpone do + let ⟨discrs, matchType, isDep, altViews⟩ ← elabMatchTypeAndDiscrs discrStxs matchOptType altViews expectedType let matchAlts ← liftMacroM <| expandMacrosInPatterns altViews trace[Elab.match]! "matchType: {matchType}" let alts ← matchAlts.mapM fun alt => elabMatchAltView alt matchType @@ -780,8 +790,8 @@ private def elabMatchAux (discrStxs : Array Syntax) (altViews : Array MatchAltVi tryPostpone throwMVarError m!"invalid match-expression, pattern contains metavariables{indentExpr (← p.toExpr)}" pure altLHS - return (discrs, matchType, altLHSS, rhss) - if let some r ← isMatchUnit? altLHSS rhss then + return (discrs, matchType, altLHSS, isDep, rhss) + if let some r ← if isDep then pure none else isMatchUnit? altLHSS rhss then return r else let numDiscrs := discrs.size diff --git a/stage0/src/Lean/Elab/Tactic/Basic.lean b/stage0/src/Lean/Elab/Tactic/Basic.lean index 05539355bd..c3782d55c5 100644 --- a/stage0/src/Lean/Elab/Tactic/Basic.lean +++ b/stage0/src/Lean/Elab/Tactic/Basic.lean @@ -342,7 +342,7 @@ partial def evalChoiceAux (tactics : Array Syntax) (i : Nat) : TacticM Unit := | `(tactic| intro) => introStep `_ | `(tactic| intro $h:ident) => introStep h.getId | `(tactic| intro _) => introStep `_ - | `(tactic| intro $pat:term) => evalTactic (← `(tactic| intro h; match h with | $pat:term => _; clear h)) + | `(tactic| intro $pat:term) => evalTactic (← `(tactic| intro h; match h with | $pat:term => _; try clear h)) | `(tactic| intro $h:term $hs:term*) => evalTactic (← `(tactic| intro $h:term; intro $hs:term*)) | _ => throwUnsupportedSyntax where diff --git a/stage0/src/Lean/Elab/Term.lean b/stage0/src/Lean/Elab/Term.lean index 33b495fde8..387273e5cb 100644 --- a/stage0/src/Lean/Elab/Term.lean +++ b/stage0/src/Lean/Elab/Term.lean @@ -574,6 +574,11 @@ def synthesizeInstMVarCore (instMVar : MVarId) (maxResultSize? : Option Nat := n | LOption.undef => pure false -- we will try later | LOption.none => throwError! "failed to synthesize instance{indentExpr type}" +register_builtin_option autoLift : Bool := { + defValue := true + descr := "insert monadic lifts (i.e., `liftM` and `liftCoeM`) when needed" +} + register_builtin_option maxCoeSize : Nat := { defValue := 16 descr := "maximum number of instances used to construct an automatic coercion" @@ -757,14 +762,17 @@ private def tryLiftAndCoe (errorMsgHeader? : Option String) (expectedType : Expr tryCoe errorMsgHeader? expectedType eType e f? let some (n, β) ← isTypeApp? expectedType | tryCoeSimple let tryPureCoeAndSimple : TermElabM Expr := do - match (← tryPureCoe? errorMsgHeader? n β eType e) with - | some eNew => pure eNew - | none => tryCoeSimple + if autoLift.get (← getOptions) then + match (← tryPureCoe? errorMsgHeader? n β eType e) with + | some eNew => pure eNew + | none => tryCoeSimple + else + tryCoeSimple let some (m, α) ← isTypeApp? eType | tryPureCoeAndSimple if (← isDefEq m n) then let some monadInst ← isMonad? n | tryCoeSimple try expandCoe (← mkAppOptM `coeM #[m, α, β, none, monadInst, e]) catch _ => throwMismatch - else + else if autoLift.get (← getOptions) then try -- Construct lift from `m` to `n` let monadLiftType ← mkAppM `MonadLiftT #[m, n] @@ -794,6 +802,8 @@ private def tryLiftAndCoe (errorMsgHeader? : Option String) (expectedType : Expr match (← isMonad? m) with | none => tryPureCoeAndSimple | some _ => tryCoeSimple + else + tryCoeSimple /-- If `expectedType?` is `some t`, then ensure `t` and `eType` are definitionally equal. diff --git a/stage0/stdlib/Lean/Elab/Match.c b/stage0/stdlib/Lean/Elab/Match.c index f24fcac515..2dc275aae3 100644 --- a/stage0/stdlib/Lean/Elab/Match.c +++ b/stage0/stdlib/Lean/Elab/Match.c @@ -35,6 +35,7 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_Ct extern lean_object* l_myMacro____x40_Init_Notation___hyg_14424____closed__12; lean_object* l_Lean_Elab_Term_withDepElimPatterns___rarg___lambda__1___boxed(lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_namedPattern___elambda__1___closed__2; +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__2___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*, lean_object*); lean_object* l_Lean_Expr_mvarId_x21(lean_object*); lean_object* l_Lean_throwError___at___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwCtorExpected___spec__1(lean_object*); uint8_t l_Lean_Expr_isCharLit(lean_object*); @@ -46,12 +47,13 @@ lean_object* l_Lean_Meta_forallTelescopeReducing___at_Lean_Elab_Term_CollectPatt lean_object* lean_erase_macro_scopes(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withPatternVars_loop___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* l_Lean_Elab_Term_ToDepElimPattern_main___closed__2; -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___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_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___closed__2; lean_object* l_Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorApp___lambda__2___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_stringToMessageData(lean_object*); lean_object* l_Lean_throwError___at___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwInvalidPattern___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_withElaboratedLHS___spec__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_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__1; lean_object* lean_mk_empty_array_with_capacity(lean_object*); extern lean_object* l_Lean_Elab_throwIllFormedSyntax___rarg___closed__3; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withPatternVars_loop___rarg___closed__1; @@ -60,9 +62,11 @@ lean_object* l_Lean_Meta_mkForallFVars(lean_object*, lean_object*, uint8_t, uint lean_object* l_Lean_Elab_Term_ToDepElimPattern_main_match__2___rarg(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_nameToPattern___closed__18; lean_object* l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__2; lean_object* l_Lean_Elab_Term_CollectPatternVars_collect___closed__4; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_nameToPattern___closed__5; lean_object* l_Lean_LocalDecl_userName(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__1; lean_object* l_Lean_Elab_Term_elabMatch(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__2(size_t, size_t, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_expandNonAtomicDiscrs_x3f___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -107,8 +111,8 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_th lean_object* l_Lean_throwError___at_Lean_Elab_Term_getPatternsVars___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwCtorExpected___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(lean_object*, lean_object*); -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; lean_object* l_Lean_throwError___at_Lean_Elab_Term_quoteAutoTactic___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__4; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_nameToPattern___closed__15; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwInvalidPattern___rarg___closed__2; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_mkMVarSyntax___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -128,6 +132,7 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withPatternVars_loop_ lean_object* l_Array_mapMUnsafe_map___at_myMacro____x40_Init_NotationExtra___hyg_5198____spec__3(size_t, size_t, lean_object*); lean_object* l_Lean_throwError___at_Lean_Elab_Term_ToDepElimPattern_main___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_throwError___at___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwInvalidPattern___spec__1(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__4; lean_object* l_Array_forM___at___private_Lean_Elab_Match_0__Lean_Elab_Term_withPatternVars_loop___spec__1(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_Lean_Elab_Match_0__Lean_Elab_Term_ToDepElimPattern_mkLocalDeclFor(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabMVarWithIdKind(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -136,7 +141,6 @@ lean_object* lean_local_ctx_erase(lean_object*, lean_object*); lean_object* l_List_mapM___at_Lean_Elab_Term_ToDepElimPattern_main___spec__3(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_Parser_Term_anonymousCtor___elambda__1___closed__2; lean_object* l_Lean_mkMVar(lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__3; extern lean_object* l_Array_empty___closed__1; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_ToDepElimPattern_throwInvalidPattern___rarg___closed__2; lean_object* lean_environment_find(lean_object*, lean_object*); @@ -147,13 +151,12 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_isMatchUnit_x3f_match extern lean_object* l___private_Lean_Meta_ExprDefEq_0__Lean_Meta_checkTypesAndAssign___closed__7; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_nameToPattern___closed__8; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_processVar___lambda__3___closed__3; +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__2; lean_object* l_Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorApp___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_List_forIn_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__4___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_st_ref_get(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_CollectPatternVars_processCtorApp_match__1___rarg(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__5; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_nameToPattern___closed__17; -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__6; extern lean_object* l_Lean_instInhabitedParserDescr___closed__1; lean_object* l_Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorApp___lambda__1___boxed__const__1; uint8_t lean_name_eq(lean_object*, lean_object*); @@ -177,7 +180,7 @@ lean_object* l_Lean_Elab_Term_elabMatchAltView___lambda__3(lean_object*, lean_ob lean_object* l_Lean_Elab_Term_ToDepElimPattern_main___lambda__2(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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop_match__1___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withExistingLocalDecls___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__3(lean_object*); -lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1(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*); +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1(lean_object*, lean_object*, lean_object*, 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*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_nameToPattern___closed__9; lean_object* l_Lean_MonadRef_mkInfoFromRefPos___at_Lean_Elab_Term_quoteAutoTactic___spec__3___rarg(lean_object*, lean_object*, lean_object*); lean_object* lean_expr_instantiate1(lean_object*, lean_object*); @@ -272,7 +275,7 @@ lean_object* l_Lean_Elab_throwUnsupportedSyntax___at___private_Lean_Elab_Match_0 lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabPatterns___spec__1___closed__1; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_ToDepElimPattern_throwInvalidPattern___rarg___closed__1; lean_object* l_Lean_Elab_Term_getPatternVars_match__1(lean_object*); -lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1___boxed(lean_object**); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwInvalidPattern___rarg___closed__3; lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabPatterns___spec__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_myMacro____x40_Init_Notation___hyg_14424____closed__4; @@ -295,7 +298,6 @@ lean_object* l_Lean_Elab_Term_withDepElimPatterns___rarg___boxed__const__1; lean_object* l_Lean_Syntax_mkApp(lean_object*, lean_object*); lean_object* l___private_Lean_Expr_0__Lean_Expr_getAppArgsAux(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_ToDepElimPattern_mkLocalDeclFor_match__2(lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__4; lean_object* l_Lean_LocalDecl_value(lean_object*); uint8_t l_Lean_Name_hasMacroScopes(lean_object*); lean_object* l_Lean_Elab_Term_elabMatchAltView(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -361,11 +363,10 @@ lean_object* l___private_Init_Meta_0__Array_mapSepElemsMAux___at_Lean_Elab_Term_ extern lean_object* l_Lean_Parser_Term_quotedName___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_CollectPatternVars_State_found___default; lean_object* l_Lean_Elab_Term_ToDepElimPattern_main_match__2(lean_object*); -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_quotedNameToPattern_match__1___rarg(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchOptType___boxed(lean_object*); lean_object* l_Array_forM___at___private_Lean_Elab_Match_0__Lean_Elab_Term_withPatternVars_loop___spec__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_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__7; lean_object* l_Lean_Elab_Term_elabTerm(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_forInUnsafe_loop___at_Lean_Elab_Term_finalizePatternDecls___spec__1___closed__6; lean_object* l_Lean_mkAnnotation(lean_object*, lean_object*); @@ -388,6 +389,7 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_isPatternVar_isAtomic lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwInvalidPattern___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_instInhabited___rarg(lean_object*, lean_object*); lean_object* l_Lean_Meta_forallBoundedTelescope___at_Lean_Elab_Term_elabLetDeclAux___spec__1___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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_match__1(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_nameToPattern___closed__12; extern lean_object* l_myMacro____x40_Init_Notation___hyg_12938____closed__10; lean_object* l_Lean_Meta_instantiateLocalDeclMVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -417,7 +419,6 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_expandNonAtomicDiscrs extern lean_object* l_Lean_Syntax_getHead_x3f___closed__4; extern lean_object* l_myMacro____x40_Init_Notation___hyg_14424____closed__1; lean_object* l_Lean_Elab_Term_inaccessible_x3f___boxed(lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1; lean_object* l_Lean_Syntax_getId(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchOptType(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwInvalidPattern___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -439,21 +440,21 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_expandNonAtomicDiscrs extern lean_object* l_Lean_Parser_Term_explicitUniv___elambda__1___closed__2; lean_object* l_Lean_Elab_Term_finalizePatternDecls_match__2(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorAppAux_match__1___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__2; extern lean_object* l_myMacro____x40_Init_Notation___hyg_2191____closed__2; lean_object* l_Lean_Elab_throwUnsupportedSyntax___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__9(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__4; +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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_Lean_Elab_Match_0__Lean_Elab_Term_expandNonAtomicDiscrs_x3f_loop___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_Elab_Term_getCurrMacroScope(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_throwError___at___private_Lean_Elab_Match_0__Lean_Elab_Term_ToDepElimPattern_throwInvalidPattern___spec__1(lean_object*); lean_object* lean_array_to_list(lean_object*, lean_object*); uint8_t l_Lean_Name_isAtomic(lean_object*); -lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(lean_object*, lean_object*, 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_Lean_Elab_Term_elabMatch_elabMatchDefault(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs(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___regBuiltin_Lean_Elab_Term_elabNoMatch___closed__1; lean_object* l_Lean_Elab_Term_CollectPatternVars_collect___closed__10; extern lean_object* l___private_Init_Meta_0__Lean_quoteName___closed__2; +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__3; lean_object* l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__1(lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_CollectPatternVars_processCtorApp(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_throwUnsupportedSyntax___at_Lean_Elab_Term_getPatternsVars___spec__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -467,6 +468,7 @@ extern lean_object* l_Std_Range_myMacro____x40_Init_Data_Range___hyg_276____clos extern lean_object* l_Lean_instInhabitedExpr; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_isMatchUnit_x3f_match__2___rarg___closed__1; lean_object* l_Lean_Elab_Term_expandApp(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__3___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___regBuiltin_Lean_Elab_Term_elabInaccessible(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType_match__1(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_collectPatternVars_match__1___rarg(lean_object*, lean_object*); @@ -505,7 +507,6 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_pr lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_CtorApp_pushNewArg(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* l_Lean_mkFVar(lean_object*); uint8_t l_List_elem___at_Lean_Occurrences_contains___spec__1(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_getMVarSyntaxMVarId___boxed(lean_object*); lean_object* l_Lean_throwErrorAt___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_finalizePatternDecls_match__2___rarg(lean_object*, lean_object*, lean_object*); @@ -547,7 +548,6 @@ lean_object* l_Lean_throwError___at___private_Lean_Elab_Match_0__Lean_Elab_Term_ lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_tryPostponeIfDiscrTypeIsMVar___spec__1___closed__1; extern lean_object* l_Lean_Elab_Term_termElabAttribute; extern lean_object* l_Lean_Syntax_getHead_x3f___closed__3; -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__1; lean_object* l_Lean_Elab_Term_instToStringPatternVar(lean_object*); lean_object* l_Lean_mkAtomFrom(lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_waitExpectedType(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -629,8 +629,10 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_pr uint8_t l_Lean_BinderInfo_isExplicit(uint8_t); lean_object* l_Lean_MonadRef_mkInfoFromRefPos___at_Lean_Elab_Term_CollectPatternVars_collect___spec__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Syntax_getKind(lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__7; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_throwCtorExpected(lean_object*); lean_object* l_Lean_throwError___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__8(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_match__1___rarg(lean_object*, lean_object*); lean_object* l_List_forIn_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__4___lambda__1___closed__3; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_waitExpectedTypeAndDiscrs(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_CollectPatternVars_collect___lambda__1___boxed__const__1; @@ -641,11 +643,14 @@ lean_object* lean_panic_fn(lean_object*, lean_object*); lean_object* l_Lean_Meta_withLocalDecl___at___private_Lean_Elab_Term_0__Lean_Elab_Term_elabImplicitLambda___spec__1___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* l_List_forIn_loop___at_Lean_Elab_Term_reportMatcherResultErrors___spec__1___closed__4; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_processId_match__3(lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; lean_object* l_Lean_Elab_Term_CollectPatternVars_State_vars___default; lean_object* l_Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorApp_match__2(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__3; lean_object* l_Std_fmt___at_Lean_Elab_Term_elabMatchAltView___spec__1(lean_object*); uint8_t l_Lean_LocalDecl_hasExprMVar(lean_object*); uint8_t l_Lean_TagAttribute_hasTag(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__5; lean_object* l_Lean_getConstInfo___at_Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorApp___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_List_forIn_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__5___lambda__1___closed__1; extern lean_object* l___private_Lean_Hygiene_0__Lean_mkInaccessibleUserNameAux___closed__2; @@ -674,7 +679,6 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabPatterns_match__1 lean_object* l_Std_fmt___at_Lean_Level_PP_Result_format___spec__2(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_processId_match__3___rarg(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop_match__1(lean_object*); -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__2; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabAtomicDiscr_match__1(lean_object*); lean_object* l_Lean_throwError___at_Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorApp___spec__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_getNumExplicitCtorParams___spec__1(lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -784,6 +788,7 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabAtomicDiscr___clo extern lean_object* l_rawNatLit___closed__5; extern lean_object* l_Lean_expandExplicitBindersAux_loop___closed__4; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withPatternVars_loop_match__2___rarg(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__2; lean_object* l_unsafeCast(lean_object*, lean_object*, lean_object*); uint8_t l_List_isEmpty___rarg(lean_object*); lean_object* l_Lean_Elab_Term_ToDepElimPattern_main___lambda__1___boxed__const__1; @@ -808,6 +813,7 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withElaboratedLHS_mat lean_object* l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1(lean_object*, size_t, size_t, lean_object*); lean_object* l_Lean_Elab_Term_CollectPatternVars_collect___closed__3; lean_object* l_Lean_throwErrorAt___at___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_processVar___spec__2___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_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1; lean_object* l_Lean_Meta_mkEq(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withPatternVars_loop_match__2(lean_object*); lean_object* l_Lean_Elab_Term_reportMatcherResultErrors___closed__2; @@ -819,32 +825,31 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_Ct lean_object* l_Lean_Meta_mkFreshExprMVarWithId(lean_object*, lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabPatterns_match__2___rarg(lean_object*, lean_object*); lean_object* l_Array_mapMUnsafe_map___at_Lean_Elab_Term_withDepElimPatterns___spec__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_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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*, lean_object*); lean_object* l_Lean_Elab_Term_ToDepElimPattern_main_match__3(lean_object*); lean_object* l_Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorApp_match__3___rarg(lean_object*, lean_object*); -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__1; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_CtorApp_isNextArgAccessible___boxed(lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_CtorApp_pushNewArg_match__1(lean_object*); lean_object* l_Array_forInUnsafe_loop___at_Lean_Elab_Term_getPatternsVars___spec__4(lean_object*, size_t, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_CtorApp_processCtorAppAux_match__1(lean_object*); lean_object* l_Lean_Meta_kabstract(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabMatchAltView___closed__2; -lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__2(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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__2(lean_object*, lean_object*, 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*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux_match__3___rarg(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_isLocalIdent_x3f(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_List_forIn_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__4___lambda__1___closed__1; lean_object* l_Array_mapMUnsafe_map___at_Lean_Meta_Closure_mkBinding___spec__1(size_t, size_t, lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_8718_(lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489_(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_8841_(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601_(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105_(lean_object*); lean_object* l_Lean_Elab_Term_CollectPatternVars_CtorApp_Context_paramDeclIdx___default; -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993_(lean_object*); lean_object* l_Lean_mkConst(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_reportMatcherResultErrors___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_mkSimpleThunk(lean_object*); lean_object* l_Lean_Meta_Match_counterExamplesToMessageData(lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__6; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_isMatchUnit_x3f___closed__4; lean_object* l_Lean_Elab_Term_CollectPatternVars_collect___closed__14; -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__3; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withElaboratedLHS___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* l_Array_insertAt___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabMatchAltView___lambda__1___closed__2; @@ -864,6 +869,7 @@ lean_object* l___regBuiltin_Lean_Elab_Term_elabMVarWithIdKind(lean_object*); lean_object* l_Lean_Elab_Term_CollectPatternVars_collect___closed__5; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_withElaboratedLHS(lean_object*); uint8_t l___private_Lean_Elab_Match_0__Lean_Elab_Term_ToDepElimPattern_mkLocalDeclFor___lambda__1(lean_object*, lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__3(lean_object*, size_t, lean_object*, lean_object*, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withDepElimPatterns___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__2___boxed(lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_isPatternVar(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -885,10 +891,11 @@ uint8_t lean_string_dec_eq(lean_object*, lean_object*); lean_object* l_Lean_Syntax_mkLit(lean_object*, lean_object*, lean_object*); uint8_t lean_nat_dec_lt(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_reportMatcherResultErrors___closed__1; +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2; lean_object* l_Lean_Meta_getFVarLocalDecl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_Lean_matchPatternAttr; lean_object* l_Lean_Elab_Term_getPatternVars_match__1___rarg(lean_object*, lean_object*); -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2(lean_object*, size_t, lean_object*, lean_object*, size_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Syntax_isIdent(lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabNoMatch(lean_object*); static lean_object* _init_l_Lean_Elab_Term_instInhabitedMatchAltView___closed__1() { @@ -1108,19 +1115,24 @@ return x_2; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType_match__2___rarg(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_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 = lean_ctor_get(x_1, 1); lean_inc(x_3); -x_4 = lean_ctor_get(x_1, 0); +x_4 = lean_ctor_get(x_3, 1); lean_inc(x_4); -lean_dec(x_1); -x_5 = lean_ctor_get(x_3, 0); +x_5 = lean_ctor_get(x_1, 0); lean_inc(x_5); -x_6 = lean_ctor_get(x_3, 1); +lean_dec(x_1); +x_6 = lean_ctor_get(x_3, 0); lean_inc(x_6); lean_dec(x_3); -x_7 = lean_apply_3(x_2, x_4, x_5, x_6); -return x_7; +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 = lean_apply_4(x_2, x_5, x_6, x_7, x_8); +return x_9; } } lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType_match__2(lean_object* x_1) { @@ -1131,7 +1143,31 @@ x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Match_0__Lean_Elab_Term_e return x_2; } } -static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__1() { +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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* x_13, lean_object* x_14) { +_start: +{ +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_15 = lean_expr_instantiate1(x_1, x_2); +x_16 = lean_array_push(x_5, x_2); +x_17 = lean_box(x_6); +x_18 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_18, 0, x_16); +lean_ctor_set(x_18, 1, x_17); +x_19 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_19, 0, x_3); +lean_ctor_set(x_19, 1, x_18); +x_20 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_20, 0, x_15); +lean_ctor_set(x_20, 1, x_19); +x_21 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_21, 0, 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_14); +return x_22; +} +} +static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__1() { _start: { lean_object* x_1; @@ -1139,16 +1175,16 @@ x_1 = lean_mk_string("invalid type provided to match-expression, function type w return x_1; } } -static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__2() { +static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__2() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__1; +x_1 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__1; x_2 = l_Lean_stringToMessageData(x_1); return x_2; } } -static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__3() { +static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__3() { _start: { lean_object* x_1; @@ -1156,16 +1192,16 @@ x_1 = lean_mk_string(" expected"); return x_1; } } -static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__4() { +static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__4() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__3; +x_1 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__3; x_2 = l_Lean_stringToMessageData(x_1); return x_2; } } -static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5() { +static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -1175,7 +1211,7 @@ x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__6() { +static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__6() { _start: { lean_object* x_1; @@ -1183,626 +1219,544 @@ x_1 = lean_mk_string("discr #"); return x_1; } } -static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__7() { +static lean_object* _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__7() { _start: { lean_object* x_1; lean_object* x_2; -x_1 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__6; +x_1 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__6; x_2 = l_Lean_stringToMessageData(x_1); return x_2; } } -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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* x_9, lean_object* x_10) { +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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* x_10) { _start: { -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_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; x_11 = lean_ctor_get(x_1, 1); lean_inc(x_11); -x_12 = lean_ctor_get(x_1, 0); +x_12 = lean_ctor_get(x_11, 1); lean_inc(x_12); -lean_dec(x_1); -x_13 = lean_ctor_get(x_11, 0); +x_13 = lean_ctor_get(x_1, 0); lean_inc(x_13); -x_14 = lean_ctor_get(x_11, 1); +lean_dec(x_1); +x_14 = lean_ctor_get(x_11, 0); lean_inc(x_14); -if (lean_is_exclusive(x_11)) { - lean_ctor_release(x_11, 0); - lean_ctor_release(x_11, 1); - x_15 = x_11; -} else { - lean_dec_ref(x_11); - x_15 = lean_box(0); -} -x_16 = lean_unsigned_to_nat(1u); -x_17 = lean_nat_add(x_13, x_16); -lean_dec(x_13); +lean_dec(x_11); +x_15 = lean_ctor_get(x_12, 0); +lean_inc(x_15); +x_16 = lean_ctor_get(x_12, 1); +lean_inc(x_16); +lean_dec(x_12); +x_17 = lean_unsigned_to_nat(1u); +x_18 = lean_nat_add(x_14, x_17); +lean_dec(x_14); lean_inc(x_9); lean_inc(x_8); lean_inc(x_7); lean_inc(x_6); -x_18 = l_Lean_Meta_whnf(x_12, x_6, x_7, x_8, x_9, x_10); -if (lean_obj_tag(x_18) == 0) +x_19 = l_Lean_Meta_whnf(x_13, x_6, x_7, x_8, x_9, x_10); +if (lean_obj_tag(x_19) == 0) { -lean_object* x_19; -x_19 = lean_ctor_get(x_18, 0); -lean_inc(x_19); -if (lean_obj_tag(x_19) == 7) -{ -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; -x_20 = lean_ctor_get(x_18, 1); +lean_object* x_20; +x_20 = lean_ctor_get(x_19, 0); lean_inc(x_20); -lean_dec(x_18); +if (lean_obj_tag(x_20) == 7) +{ +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; uint8_t x_30; x_21 = lean_ctor_get(x_19, 1); lean_inc(x_21); -x_22 = lean_ctor_get(x_19, 2); -lean_inc(x_22); lean_dec(x_19); -x_23 = l_Lean_Syntax_getArg(x_5, x_16); -lean_inc(x_21); -x_24 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_24, 0, x_21); -x_25 = lean_box(0); -x_26 = lean_ctor_get(x_6, 0); -lean_inc(x_26); -x_27 = lean_ctor_get(x_6, 1); +x_22 = lean_ctor_get(x_20, 1); +lean_inc(x_22); +x_23 = lean_ctor_get(x_20, 2); +lean_inc(x_23); +x_24 = l_Lean_Syntax_getArg(x_5, x_17); +lean_inc(x_22); +x_25 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_25, 0, x_22); +x_26 = lean_box(0); +x_27 = lean_ctor_get(x_6, 0); lean_inc(x_27); -x_28 = lean_ctor_get(x_6, 2); +x_28 = lean_ctor_get(x_6, 1); lean_inc(x_28); -x_29 = !lean_is_exclusive(x_26); -if (x_29 == 0) +x_29 = lean_ctor_get(x_6, 2); +lean_inc(x_29); +x_30 = !lean_is_exclusive(x_27); +if (x_30 == 0) { -uint8_t x_30; lean_object* x_31; lean_object* x_32; -x_30 = 1; -lean_ctor_set_uint8(x_26, 0, x_30); -lean_ctor_set_uint8(x_26, 1, x_30); -lean_ctor_set_uint8(x_26, 2, x_30); -lean_ctor_set_uint8(x_26, 3, x_30); -x_31 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_31, 0, x_26); -lean_ctor_set(x_31, 1, x_27); -lean_ctor_set(x_31, 2, x_28); +uint8_t x_31; lean_object* x_32; lean_object* x_33; +x_31 = 1; +lean_ctor_set_uint8(x_27, 0, x_31); +lean_ctor_set_uint8(x_27, 1, x_31); +lean_ctor_set_uint8(x_27, 2, x_31); +lean_ctor_set_uint8(x_27, 3, x_31); +x_32 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_32, 0, x_27); +lean_ctor_set(x_32, 1, x_28); +lean_ctor_set(x_32, 2, x_29); lean_inc(x_9); lean_inc(x_8); lean_inc(x_7); lean_inc(x_4); lean_inc(x_3); -x_32 = l_Lean_Elab_Term_elabTermEnsuringType(x_23, x_24, x_30, x_25, x_3, x_4, x_31, x_7, x_8, x_9, x_20); -if (lean_obj_tag(x_32) == 0) +x_33 = l_Lean_Elab_Term_elabTermEnsuringType(x_24, x_25, x_31, x_26, x_3, x_4, x_32, x_7, x_8, x_9, x_21); +if (lean_obj_tag(x_33) == 0) { -lean_object* x_33; lean_object* x_34; lean_object* x_35; uint8_t x_36; lean_object* x_37; lean_object* x_75; lean_object* x_76; lean_object* x_77; uint8_t x_78; -x_33 = lean_ctor_get(x_32, 0); -lean_inc(x_33); -x_34 = lean_ctor_get(x_32, 1); +lean_object* x_34; lean_object* x_35; lean_object* x_36; uint8_t x_44; lean_object* x_45; lean_object* x_64; lean_object* x_65; lean_object* x_66; uint8_t x_67; +x_34 = lean_ctor_get(x_33, 0); lean_inc(x_34); -if (lean_is_exclusive(x_32)) { - lean_ctor_release(x_32, 0); - lean_ctor_release(x_32, 1); - x_35 = x_32; -} else { - lean_dec_ref(x_32); - x_35 = lean_box(0); -} -x_75 = lean_st_ref_get(x_9, x_34); -x_76 = lean_ctor_get(x_75, 0); -lean_inc(x_76); -x_77 = lean_ctor_get(x_76, 3); -lean_inc(x_77); -lean_dec(x_76); -x_78 = lean_ctor_get_uint8(x_77, sizeof(void*)*1); -lean_dec(x_77); -if (x_78 == 0) +x_35 = lean_ctor_get(x_33, 1); +lean_inc(x_35); +lean_dec(x_33); +x_64 = lean_st_ref_get(x_9, x_35); +x_65 = lean_ctor_get(x_64, 0); +lean_inc(x_65); +x_66 = lean_ctor_get(x_65, 3); +lean_inc(x_66); +lean_dec(x_65); +x_67 = lean_ctor_get_uint8(x_66, sizeof(void*)*1); +lean_dec(x_66); +if (x_67 == 0) { -lean_object* x_79; uint8_t x_80; -x_79 = lean_ctor_get(x_75, 1); -lean_inc(x_79); -lean_dec(x_75); -x_80 = 0; -x_36 = x_80; -x_37 = x_79; -goto block_74; +lean_object* x_68; uint8_t x_69; +x_68 = lean_ctor_get(x_64, 1); +lean_inc(x_68); +lean_dec(x_64); +x_69 = 0; +x_44 = x_69; +x_45 = x_68; +goto block_63; } else { -lean_object* x_81; lean_object* x_82; lean_object* x_83; lean_object* x_84; lean_object* x_85; uint8_t x_86; -x_81 = lean_ctor_get(x_75, 1); -lean_inc(x_81); -lean_dec(x_75); -x_82 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_83 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_82, x_3, x_4, x_6, x_7, x_8, x_9, x_81); -x_84 = lean_ctor_get(x_83, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_83, 1); -lean_inc(x_85); -lean_dec(x_83); -x_86 = lean_unbox(x_84); -lean_dec(x_84); -x_36 = x_86; -x_37 = x_85; -goto block_74; +lean_object* x_70; lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; uint8_t x_75; +x_70 = lean_ctor_get(x_64, 1); +lean_inc(x_70); +lean_dec(x_64); +x_71 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_72 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_71, x_3, x_4, x_6, x_7, x_8, x_9, x_70); +x_73 = lean_ctor_get(x_72, 0); +lean_inc(x_73); +x_74 = lean_ctor_get(x_72, 1); +lean_inc(x_74); +lean_dec(x_72); +x_75 = lean_unbox(x_73); +lean_dec(x_73); +x_44 = x_75; +x_45 = x_74; +goto block_63; } -block_74: +block_43: { -if (x_36 == 0) +uint8_t x_37; +x_37 = l_Lean_Expr_hasLooseBVars(x_23); +if (x_37 == 0) { -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_dec(x_21); +lean_object* x_38; uint8_t x_39; lean_object* x_40; +x_38 = lean_box(0); +x_39 = lean_unbox(x_16); +lean_dec(x_16); +x_40 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1(x_23, x_34, x_18, x_20, x_15, x_39, x_38, x_3, x_4, x_6, x_7, x_8, x_9, x_36); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); -x_38 = lean_expr_instantiate1(x_22, x_33); -lean_dec(x_22); -x_39 = lean_array_push(x_14, x_33); -if (lean_is_scalar(x_15)) { - x_40 = lean_alloc_ctor(0, 2, 0); -} else { - x_40 = x_15; -} -lean_ctor_set(x_40, 0, x_17); -lean_ctor_set(x_40, 1, x_39); -x_41 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_41, 0, x_38); -lean_ctor_set(x_41, 1, x_40); -x_42 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_42, 0, x_41); -if (lean_is_scalar(x_35)) { - x_43 = lean_alloc_ctor(0, 2, 0); -} else { - x_43 = x_35; -} -lean_ctor_set(x_43, 0, x_42); -lean_ctor_set(x_43, 1, x_37); -return x_43; +lean_dec(x_20); +lean_dec(x_23); +return x_40; } 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_54; lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; -lean_dec(x_35); -lean_inc(x_17); -x_44 = l_Std_fmt___at_Lean_Level_PP_Result_format___spec__2(x_17); -x_45 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_45, 0, x_44); -x_46 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__7; -x_47 = lean_alloc_ctor(10, 2, 0); +lean_object* x_41; lean_object* x_42; +lean_dec(x_16); +x_41 = lean_box(0); +x_42 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1(x_23, x_34, x_18, x_20, x_15, x_31, x_41, x_3, x_4, x_6, x_7, x_8, x_9, x_36); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_20); +lean_dec(x_23); +return x_42; +} +} +block_63: +{ +if (x_44 == 0) +{ +lean_dec(x_22); +x_36 = x_45; +goto block_43; +} +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_object* x_61; lean_object* x_62; +lean_inc(x_18); +x_46 = l_Std_fmt___at_Lean_Level_PP_Result_format___spec__2(x_18); +x_47 = lean_alloc_ctor(0, 1, 0); lean_ctor_set(x_47, 0, x_46); -lean_ctor_set(x_47, 1, x_45); -x_48 = l_Lean_Meta_substCore___lambda__1___closed__3; +x_48 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__7; x_49 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); -lean_inc(x_33); -x_50 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_50, 0, x_33); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_47); +x_50 = l_Lean_Meta_substCore___lambda__1___closed__3; x_51 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_51, 0, x_49); lean_ctor_set(x_51, 1, x_50); -x_52 = l___private_Lean_Meta_ExprDefEq_0__Lean_Meta_checkTypesAndAssign___closed__7; +lean_inc(x_34); +x_52 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_52, 0, x_34); x_53 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_53, 0, x_51); lean_ctor_set(x_53, 1, x_52); -x_54 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_54, 0, x_21); +x_54 = l___private_Lean_Meta_ExprDefEq_0__Lean_Meta_checkTypesAndAssign___closed__7; x_55 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_55, 0, x_53); lean_ctor_set(x_55, 1, x_54); -x_56 = l_Lean_KernelException_toMessageData___closed__15; +x_56 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_56, 0, x_22); x_57 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_57, 0, x_55); lean_ctor_set(x_57, 1, x_56); -x_58 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_59 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_58, x_57, x_3, x_4, x_6, x_7, x_8, x_9, x_37); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -x_60 = !lean_is_exclusive(x_59); -if (x_60 == 0) -{ -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_59, 0); +x_58 = l_Lean_KernelException_toMessageData___closed__15; +x_59 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_59, 0, x_57); +lean_ctor_set(x_59, 1, x_58); +x_60 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_61 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_60, x_59, x_3, x_4, x_6, x_7, x_8, x_9, x_45); +x_62 = lean_ctor_get(x_61, 1); +lean_inc(x_62); lean_dec(x_61); -x_62 = lean_expr_instantiate1(x_22, x_33); -lean_dec(x_22); -x_63 = lean_array_push(x_14, x_33); -if (lean_is_scalar(x_15)) { - x_64 = lean_alloc_ctor(0, 2, 0); -} else { - x_64 = x_15; -} -lean_ctor_set(x_64, 0, x_17); -lean_ctor_set(x_64, 1, x_63); -x_65 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_65, 0, x_62); -lean_ctor_set(x_65, 1, x_64); -x_66 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_66, 0, x_65); -lean_ctor_set(x_59, 0, x_66); -return x_59; -} -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; -x_67 = lean_ctor_get(x_59, 1); -lean_inc(x_67); -lean_dec(x_59); -x_68 = lean_expr_instantiate1(x_22, x_33); -lean_dec(x_22); -x_69 = lean_array_push(x_14, x_33); -if (lean_is_scalar(x_15)) { - x_70 = lean_alloc_ctor(0, 2, 0); -} else { - x_70 = x_15; -} -lean_ctor_set(x_70, 0, x_17); -lean_ctor_set(x_70, 1, x_69); -x_71 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_71, 0, x_68); -lean_ctor_set(x_71, 1, x_70); -x_72 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_72, 0, 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_67); -return x_73; -} +x_36 = x_62; +goto block_43; } } } else { -uint8_t x_87; +uint8_t x_76; +lean_dec(x_23); lean_dec(x_22); -lean_dec(x_21); -lean_dec(x_17); +lean_dec(x_20); +lean_dec(x_18); +lean_dec(x_16); lean_dec(x_15); -lean_dec(x_14); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); -x_87 = !lean_is_exclusive(x_32); -if (x_87 == 0) +x_76 = !lean_is_exclusive(x_33); +if (x_76 == 0) { -return x_32; +return x_33; } else { -lean_object* x_88; lean_object* x_89; lean_object* x_90; -x_88 = lean_ctor_get(x_32, 0); -x_89 = lean_ctor_get(x_32, 1); -lean_inc(x_89); -lean_inc(x_88); -lean_dec(x_32); -x_90 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_90, 0, x_88); -lean_ctor_set(x_90, 1, x_89); -return x_90; +lean_object* x_77; lean_object* x_78; lean_object* x_79; +x_77 = lean_ctor_get(x_33, 0); +x_78 = lean_ctor_get(x_33, 1); +lean_inc(x_78); +lean_inc(x_77); +lean_dec(x_33); +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_91; uint8_t x_92; uint8_t x_93; uint8_t x_94; uint8_t x_95; uint8_t x_96; lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_91 = lean_ctor_get_uint8(x_26, 4); -x_92 = lean_ctor_get_uint8(x_26, 5); -x_93 = lean_ctor_get_uint8(x_26, 6); -x_94 = lean_ctor_get_uint8(x_26, 7); -x_95 = lean_ctor_get_uint8(x_26, 8); -lean_dec(x_26); -x_96 = 1; -x_97 = lean_alloc_ctor(0, 0, 9); -lean_ctor_set_uint8(x_97, 0, x_96); -lean_ctor_set_uint8(x_97, 1, x_96); -lean_ctor_set_uint8(x_97, 2, x_96); -lean_ctor_set_uint8(x_97, 3, x_96); -lean_ctor_set_uint8(x_97, 4, x_91); -lean_ctor_set_uint8(x_97, 5, x_92); -lean_ctor_set_uint8(x_97, 6, x_93); -lean_ctor_set_uint8(x_97, 7, x_94); -lean_ctor_set_uint8(x_97, 8, x_95); -x_98 = lean_alloc_ctor(0, 3, 0); -lean_ctor_set(x_98, 0, x_97); -lean_ctor_set(x_98, 1, x_27); -lean_ctor_set(x_98, 2, x_28); +uint8_t x_80; uint8_t x_81; uint8_t x_82; uint8_t x_83; uint8_t x_84; uint8_t x_85; lean_object* x_86; lean_object* x_87; lean_object* x_88; +x_80 = lean_ctor_get_uint8(x_27, 4); +x_81 = lean_ctor_get_uint8(x_27, 5); +x_82 = lean_ctor_get_uint8(x_27, 6); +x_83 = lean_ctor_get_uint8(x_27, 7); +x_84 = lean_ctor_get_uint8(x_27, 8); +lean_dec(x_27); +x_85 = 1; +x_86 = lean_alloc_ctor(0, 0, 9); +lean_ctor_set_uint8(x_86, 0, x_85); +lean_ctor_set_uint8(x_86, 1, x_85); +lean_ctor_set_uint8(x_86, 2, x_85); +lean_ctor_set_uint8(x_86, 3, x_85); +lean_ctor_set_uint8(x_86, 4, x_80); +lean_ctor_set_uint8(x_86, 5, x_81); +lean_ctor_set_uint8(x_86, 6, x_82); +lean_ctor_set_uint8(x_86, 7, x_83); +lean_ctor_set_uint8(x_86, 8, x_84); +x_87 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_87, 0, x_86); +lean_ctor_set(x_87, 1, x_28); +lean_ctor_set(x_87, 2, x_29); lean_inc(x_9); lean_inc(x_8); lean_inc(x_7); lean_inc(x_4); lean_inc(x_3); -x_99 = l_Lean_Elab_Term_elabTermEnsuringType(x_23, x_24, x_96, x_25, x_3, x_4, x_98, x_7, x_8, x_9, x_20); -if (lean_obj_tag(x_99) == 0) +x_88 = l_Lean_Elab_Term_elabTermEnsuringType(x_24, x_25, x_85, x_26, x_3, x_4, x_87, x_7, x_8, x_9, x_21); +if (lean_obj_tag(x_88) == 0) { -lean_object* x_100; lean_object* x_101; lean_object* x_102; uint8_t x_103; lean_object* x_104; lean_object* x_136; lean_object* x_137; lean_object* x_138; uint8_t x_139; -x_100 = lean_ctor_get(x_99, 0); -lean_inc(x_100); -x_101 = lean_ctor_get(x_99, 1); -lean_inc(x_101); -if (lean_is_exclusive(x_99)) { - lean_ctor_release(x_99, 0); - lean_ctor_release(x_99, 1); - x_102 = x_99; -} else { - lean_dec_ref(x_99); - x_102 = lean_box(0); -} -x_136 = lean_st_ref_get(x_9, x_101); -x_137 = lean_ctor_get(x_136, 0); -lean_inc(x_137); -x_138 = lean_ctor_get(x_137, 3); -lean_inc(x_138); -lean_dec(x_137); -x_139 = lean_ctor_get_uint8(x_138, sizeof(void*)*1); -lean_dec(x_138); -if (x_139 == 0) +lean_object* x_89; lean_object* x_90; lean_object* x_91; uint8_t x_99; lean_object* x_100; lean_object* x_119; lean_object* x_120; lean_object* x_121; uint8_t x_122; +x_89 = lean_ctor_get(x_88, 0); +lean_inc(x_89); +x_90 = lean_ctor_get(x_88, 1); +lean_inc(x_90); +lean_dec(x_88); +x_119 = lean_st_ref_get(x_9, x_90); +x_120 = lean_ctor_get(x_119, 0); +lean_inc(x_120); +x_121 = lean_ctor_get(x_120, 3); +lean_inc(x_121); +lean_dec(x_120); +x_122 = lean_ctor_get_uint8(x_121, sizeof(void*)*1); +lean_dec(x_121); +if (x_122 == 0) { -lean_object* x_140; uint8_t x_141; -x_140 = lean_ctor_get(x_136, 1); -lean_inc(x_140); -lean_dec(x_136); -x_141 = 0; -x_103 = x_141; -x_104 = x_140; -goto block_135; +lean_object* x_123; uint8_t x_124; +x_123 = lean_ctor_get(x_119, 1); +lean_inc(x_123); +lean_dec(x_119); +x_124 = 0; +x_99 = x_124; +x_100 = x_123; +goto block_118; } else { -lean_object* x_142; lean_object* x_143; lean_object* x_144; lean_object* x_145; lean_object* x_146; uint8_t x_147; -x_142 = lean_ctor_get(x_136, 1); -lean_inc(x_142); -lean_dec(x_136); -x_143 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_144 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_143, x_3, x_4, x_6, x_7, x_8, x_9, x_142); -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); -x_147 = lean_unbox(x_145); -lean_dec(x_145); -x_103 = x_147; -x_104 = x_146; -goto block_135; +lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; lean_object* x_129; uint8_t x_130; +x_125 = lean_ctor_get(x_119, 1); +lean_inc(x_125); +lean_dec(x_119); +x_126 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_127 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_126, x_3, x_4, x_6, x_7, x_8, x_9, x_125); +x_128 = lean_ctor_get(x_127, 0); +lean_inc(x_128); +x_129 = lean_ctor_get(x_127, 1); +lean_inc(x_129); +lean_dec(x_127); +x_130 = lean_unbox(x_128); +lean_dec(x_128); +x_99 = x_130; +x_100 = x_129; +goto block_118; } -block_135: +block_98: { -if (x_103 == 0) +uint8_t x_92; +x_92 = l_Lean_Expr_hasLooseBVars(x_23); +if (x_92 == 0) { -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_dec(x_21); +lean_object* x_93; uint8_t x_94; lean_object* x_95; +x_93 = lean_box(0); +x_94 = lean_unbox(x_16); +lean_dec(x_16); +x_95 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1(x_23, x_89, x_18, x_20, x_15, x_94, x_93, x_3, x_4, x_6, x_7, x_8, x_9, x_91); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); -x_105 = lean_expr_instantiate1(x_22, x_100); -lean_dec(x_22); -x_106 = lean_array_push(x_14, x_100); -if (lean_is_scalar(x_15)) { - x_107 = lean_alloc_ctor(0, 2, 0); -} else { - x_107 = x_15; +lean_dec(x_20); +lean_dec(x_23); +return x_95; } -lean_ctor_set(x_107, 0, x_17); -lean_ctor_set(x_107, 1, x_106); -x_108 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_108, 0, x_105); +else +{ +lean_object* x_96; lean_object* x_97; +lean_dec(x_16); +x_96 = lean_box(0); +x_97 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1(x_23, x_89, x_18, x_20, x_15, x_85, x_96, x_3, x_4, x_6, x_7, x_8, x_9, x_91); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_20); +lean_dec(x_23); +return x_97; +} +} +block_118: +{ +if (x_99 == 0) +{ +lean_dec(x_22); +x_91 = x_100; +goto block_98; +} +else +{ +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; 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_inc(x_18); +x_101 = l_Std_fmt___at_Lean_Level_PP_Result_format___spec__2(x_18); +x_102 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_102, 0, x_101); +x_103 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__7; +x_104 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_104, 0, x_103); +lean_ctor_set(x_104, 1, x_102); +x_105 = l_Lean_Meta_substCore___lambda__1___closed__3; +x_106 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_106, 0, x_104); +lean_ctor_set(x_106, 1, x_105); +lean_inc(x_89); +x_107 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_107, 0, x_89); +x_108 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_108, 0, x_106); lean_ctor_set(x_108, 1, x_107); -x_109 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_109, 0, x_108); -if (lean_is_scalar(x_102)) { - x_110 = lean_alloc_ctor(0, 2, 0); -} else { - x_110 = x_102; +x_109 = l___private_Lean_Meta_ExprDefEq_0__Lean_Meta_checkTypesAndAssign___closed__7; +x_110 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_110, 0, x_108); +lean_ctor_set(x_110, 1, x_109); +x_111 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_111, 0, x_22); +x_112 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_112, 0, x_110); +lean_ctor_set(x_112, 1, x_111); +x_113 = l_Lean_KernelException_toMessageData___closed__15; +x_114 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_114, 0, x_112); +lean_ctor_set(x_114, 1, x_113); +x_115 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_116 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_115, x_114, x_3, x_4, x_6, x_7, x_8, x_9, x_100); +x_117 = lean_ctor_get(x_116, 1); +lean_inc(x_117); +lean_dec(x_116); +x_91 = x_117; +goto block_98; +} } -lean_ctor_set(x_110, 0, x_109); -lean_ctor_set(x_110, 1, x_104); -return x_110; } else { -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; 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_dec(x_102); -lean_inc(x_17); -x_111 = l_Std_fmt___at_Lean_Level_PP_Result_format___spec__2(x_17); -x_112 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_112, 0, x_111); -x_113 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__7; -x_114 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_114, 0, x_113); -lean_ctor_set(x_114, 1, x_112); -x_115 = l_Lean_Meta_substCore___lambda__1___closed__3; -x_116 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_116, 0, x_114); -lean_ctor_set(x_116, 1, x_115); -lean_inc(x_100); -x_117 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_117, 0, x_100); -x_118 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_118, 0, x_116); -lean_ctor_set(x_118, 1, x_117); -x_119 = l___private_Lean_Meta_ExprDefEq_0__Lean_Meta_checkTypesAndAssign___closed__7; -x_120 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_120, 0, x_118); -lean_ctor_set(x_120, 1, x_119); -x_121 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_121, 0, x_21); -x_122 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_122, 0, x_120); -lean_ctor_set(x_122, 1, x_121); -x_123 = l_Lean_KernelException_toMessageData___closed__15; -x_124 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_124, 0, x_122); -lean_ctor_set(x_124, 1, x_123); -x_125 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_126 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_125, x_124, x_3, x_4, x_6, x_7, x_8, x_9, x_104); +lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; +lean_dec(x_23); +lean_dec(x_22); +lean_dec(x_20); +lean_dec(x_18); +lean_dec(x_16); +lean_dec(x_15); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); -x_127 = lean_ctor_get(x_126, 1); -lean_inc(x_127); -if (lean_is_exclusive(x_126)) { - lean_ctor_release(x_126, 0); - lean_ctor_release(x_126, 1); - x_128 = x_126; +x_131 = lean_ctor_get(x_88, 0); +lean_inc(x_131); +x_132 = lean_ctor_get(x_88, 1); +lean_inc(x_132); +if (lean_is_exclusive(x_88)) { + lean_ctor_release(x_88, 0); + lean_ctor_release(x_88, 1); + x_133 = x_88; } else { - lean_dec_ref(x_126); - x_128 = lean_box(0); + lean_dec_ref(x_88); + x_133 = lean_box(0); } -x_129 = lean_expr_instantiate1(x_22, x_100); -lean_dec(x_22); -x_130 = lean_array_push(x_14, x_100); -if (lean_is_scalar(x_15)) { - x_131 = lean_alloc_ctor(0, 2, 0); +if (lean_is_scalar(x_133)) { + x_134 = lean_alloc_ctor(1, 2, 0); } else { - x_131 = x_15; + x_134 = x_133; } -lean_ctor_set(x_131, 0, x_17); -lean_ctor_set(x_131, 1, x_130); -x_132 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_132, 0, x_129); -lean_ctor_set(x_132, 1, x_131); -x_133 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_133, 0, x_132); -if (lean_is_scalar(x_128)) { - x_134 = lean_alloc_ctor(0, 2, 0); -} else { - x_134 = x_128; -} -lean_ctor_set(x_134, 0, x_133); -lean_ctor_set(x_134, 1, x_127); +lean_ctor_set(x_134, 0, x_131); +lean_ctor_set(x_134, 1, x_132); return x_134; } } } else { -lean_object* x_148; lean_object* x_149; lean_object* x_150; lean_object* x_151; -lean_dec(x_22); -lean_dec(x_21); -lean_dec(x_17); +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_dec(x_20); +lean_dec(x_18); +lean_dec(x_16); +lean_dec(x_15); +x_135 = lean_ctor_get(x_19, 1); +lean_inc(x_135); +lean_dec(x_19); +x_136 = lean_array_get_size(x_2); +x_137 = l_Std_fmt___at_Lean_Level_PP_Result_format___spec__2(x_136); +x_138 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_138, 0, x_137); +x_139 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__2; +x_140 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_140, 0, x_139); +lean_ctor_set(x_140, 1, x_138); +x_141 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__4; +x_142 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_142, 0, x_140); +lean_ctor_set(x_142, 1, x_141); +x_143 = l_Lean_throwError___at___private_Lean_Elab_Term_0__Lean_Elab_Term_applyAttributesCore___spec__1(x_142, x_3, x_4, x_6, x_7, x_8, x_9, x_135); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_4); +x_144 = !lean_is_exclusive(x_143); +if (x_144 == 0) +{ +return x_143; +} +else +{ +lean_object* x_145; lean_object* x_146; lean_object* x_147; +x_145 = lean_ctor_get(x_143, 0); +x_146 = lean_ctor_get(x_143, 1); +lean_inc(x_146); +lean_inc(x_145); +lean_dec(x_143); +x_147 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_147, 0, x_145); +lean_ctor_set(x_147, 1, x_146); +return x_147; +} +} +} +else +{ +uint8_t x_148; +lean_dec(x_18); +lean_dec(x_16); lean_dec(x_15); -lean_dec(x_14); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_4); lean_dec(x_3); -x_148 = lean_ctor_get(x_99, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_99, 1); +x_148 = !lean_is_exclusive(x_19); +if (x_148 == 0) +{ +return x_19; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; +x_149 = lean_ctor_get(x_19, 0); +x_150 = lean_ctor_get(x_19, 1); +lean_inc(x_150); lean_inc(x_149); -if (lean_is_exclusive(x_99)) { - lean_ctor_release(x_99, 0); - lean_ctor_release(x_99, 1); - x_150 = x_99; -} else { - lean_dec_ref(x_99); - x_150 = lean_box(0); -} -if (lean_is_scalar(x_150)) { - x_151 = lean_alloc_ctor(1, 2, 0); -} else { - x_151 = x_150; -} -lean_ctor_set(x_151, 0, x_148); -lean_ctor_set(x_151, 1, x_149); +lean_dec(x_19); +x_151 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_151, 0, x_149); +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; uint8_t x_161; -lean_dec(x_19); -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_14); -x_152 = lean_ctor_get(x_18, 1); -lean_inc(x_152); -lean_dec(x_18); -x_153 = lean_array_get_size(x_2); -x_154 = l_Std_fmt___at_Lean_Level_PP_Result_format___spec__2(x_153); -x_155 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_155, 0, x_154); -x_156 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__2; -x_157 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_157, 0, x_156); -lean_ctor_set(x_157, 1, x_155); -x_158 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__4; -x_159 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_159, 0, x_157); -lean_ctor_set(x_159, 1, x_158); -x_160 = l_Lean_throwError___at___private_Lean_Elab_Term_0__Lean_Elab_Term_applyAttributesCore___spec__1(x_159, x_3, x_4, x_6, x_7, x_8, x_9, x_152); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -x_161 = !lean_is_exclusive(x_160); -if (x_161 == 0) -{ -return x_160; } -else -{ -lean_object* x_162; lean_object* x_163; lean_object* x_164; -x_162 = lean_ctor_get(x_160, 0); -x_163 = lean_ctor_get(x_160, 1); -lean_inc(x_163); -lean_inc(x_162); -lean_dec(x_160); -x_164 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_164, 0, x_162); -lean_ctor_set(x_164, 1, x_163); -return x_164; -} -} -} -else -{ -uint8_t x_165; -lean_dec(x_17); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_4); -lean_dec(x_3); -x_165 = !lean_is_exclusive(x_18); -if (x_165 == 0) -{ -return x_18; -} -else -{ -lean_object* x_166; lean_object* x_167; lean_object* x_168; -x_166 = lean_ctor_get(x_18, 0); -x_167 = lean_ctor_get(x_18, 1); -lean_inc(x_167); -lean_inc(x_166); -lean_dec(x_18); -x_168 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_168, 0, x_166); -lean_ctor_set(x_168, 1, x_167); -return x_168; -} -} -} -} -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2(lean_object* x_1, size_t x_2, lean_object* x_3, lean_object* x_4, size_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* x_12, lean_object* x_13) { +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__3(lean_object* x_1, size_t x_2, lean_object* x_3, lean_object* x_4, size_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* x_12, lean_object* x_13) { _start: { if (lean_obj_tag(x_8) == 0) @@ -1867,7 +1821,7 @@ lean_inc(x_19); lean_inc(x_8); lean_inc(x_7); lean_inc(x_1); -x_20 = lean_alloc_closure((void*)(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___boxed), 10, 5); +x_20 = lean_alloc_closure((void*)(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___boxed), 10, 5); lean_closure_set(x_20, 0, x_6); lean_closure_set(x_20, 1, x_1); lean_closure_set(x_20, 2, x_7); @@ -1875,7 +1829,7 @@ lean_closure_set(x_20, 3, x_8); lean_closure_set(x_20, 4, x_18); x_21 = lean_box_usize(x_5); x_22 = lean_box_usize(x_4); -x_23 = lean_alloc_closure((void*)(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___boxed), 13, 7); +x_23 = lean_alloc_closure((void*)(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__3___boxed), 13, 7); lean_closure_set(x_23, 0, x_2); lean_closure_set(x_23, 1, x_21); lean_closure_set(x_23, 2, x_1); @@ -1891,9 +1845,22 @@ return x_24; static lean_object* _init_l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__1() { _start: { +lean_object* x_1; uint8_t x_2; lean_object* x_3; lean_object* x_4; +x_1 = l_Array_empty___closed__1; +x_2 = 0; +x_3 = lean_box(x_2); +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; +} +} +static lean_object* _init_l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__2() { +_start: +{ lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_unsigned_to_nat(0u); -x_2 = l_Array_empty___closed__1; +x_2 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__1; x_3 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_3, 0, x_1); lean_ctor_set(x_3, 1, x_2); @@ -1904,7 +1871,7 @@ lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchTyp _start: { lean_object* x_11; lean_object* x_12; lean_object* x_13; size_t x_14; size_t x_15; lean_object* x_16; lean_object* x_17; -x_11 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__1; +x_11 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__2; x_12 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_12, 0, x_2); lean_ctor_set(x_12, 1, x_11); @@ -1917,74 +1884,106 @@ lean_inc(x_1); x_17 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1(x_1, x_16, x_1, x_14, x_15, x_12, x_4, x_5, x_6, x_7, x_8, x_9, x_10); if (lean_obj_tag(x_17) == 0) { -lean_object* x_18; lean_object* x_19; uint8_t x_20; +lean_object* x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; x_18 = lean_ctor_get(x_17, 0); lean_inc(x_18); x_19 = lean_ctor_get(x_18, 1); lean_inc(x_19); lean_dec(x_18); -x_20 = !lean_is_exclusive(x_17); -if (x_20 == 0) -{ -lean_object* x_21; lean_object* x_22; -x_21 = lean_ctor_get(x_17, 0); -lean_dec(x_21); -x_22 = lean_ctor_get(x_19, 1); -lean_inc(x_22); +x_20 = lean_ctor_get(x_19, 1); +lean_inc(x_20); lean_dec(x_19); -lean_ctor_set(x_17, 0, x_22); -return x_17; -} -else +x_21 = !lean_is_exclusive(x_17); +if (x_21 == 0) { -lean_object* x_23; lean_object* x_24; lean_object* x_25; -x_23 = lean_ctor_get(x_17, 1); +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; +x_22 = lean_ctor_get(x_17, 0); +lean_dec(x_22); +x_23 = lean_ctor_get(x_20, 0); lean_inc(x_23); -lean_dec(x_17); -x_24 = lean_ctor_get(x_19, 1); +x_24 = lean_ctor_get(x_20, 1); lean_inc(x_24); -lean_dec(x_19); +lean_dec(x_20); x_25 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_25, 0, x_24); -lean_ctor_set(x_25, 1, x_23); -return x_25; -} -} -else -{ -uint8_t x_26; -x_26 = !lean_is_exclusive(x_17); -if (x_26 == 0) -{ +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_24); +lean_ctor_set(x_17, 0, x_25); return x_17; } else { -lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_27 = lean_ctor_get(x_17, 0); -x_28 = lean_ctor_get(x_17, 1); -lean_inc(x_28); -lean_inc(x_27); +lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; +x_26 = lean_ctor_get(x_17, 1); +lean_inc(x_26); lean_dec(x_17); -x_29 = lean_alloc_ctor(1, 2, 0); +x_27 = lean_ctor_get(x_20, 0); +lean_inc(x_27); +x_28 = lean_ctor_get(x_20, 1); +lean_inc(x_28); +lean_dec(x_20); +x_29 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_29, 0, x_27); lean_ctor_set(x_29, 1, x_28); -return x_29; +x_30 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_30, 0, x_29); +lean_ctor_set(x_30, 1, x_26); +return x_30; +} +} +else +{ +uint8_t x_31; +x_31 = !lean_is_exclusive(x_17); +if (x_31 == 0) +{ +return x_17; +} +else +{ +lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_32 = lean_ctor_get(x_17, 0); +x_33 = lean_ctor_get(x_17, 1); +lean_inc(x_33); +lean_inc(x_32); +lean_dec(x_17); +x_34 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_34, 0, x_32); +lean_ctor_set(x_34, 1, x_33); +return x_34; } } } } -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___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, lean_object* x_7, lean_object* x_8, lean_object* x_9, lean_object* x_10) { +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___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, 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_6); +lean_dec(x_6); +x_16 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1(x_1, x_2, x_3, x_4, x_5, x_15, x_7, x_8, x_9, x_10, x_11, x_12, x_13, x_14); +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_1); +return x_16; +} +} +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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, lean_object* x_10) { _start: { lean_object* x_11; -x_11 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +x_11 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); lean_dec(x_5); lean_dec(x_2); return x_11; } } -lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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, lean_object* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { +lean_object* l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___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* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13) { _start: { size_t x_14; size_t x_15; lean_object* x_16; @@ -1992,7 +1991,7 @@ x_14 = lean_unbox_usize(x_2); lean_dec(x_2); x_15 = lean_unbox_usize(x_5); lean_dec(x_5); -x_16 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2(x_1, x_14, x_3, x_4, x_15, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); +x_16 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__3(x_1, x_14, x_3, x_4, x_15, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); return x_16; } } @@ -2431,6 +2430,27 @@ lean_dec(x_1); return x_4; } } +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_match__1___rarg(lean_object* x_1, lean_object* x_2) { +_start: +{ +lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_3 = lean_ctor_get(x_1, 0); +lean_inc(x_3); +x_4 = lean_ctor_get(x_1, 1); +lean_inc(x_4); +lean_dec(x_1); +x_5 = lean_apply_2(x_2, x_3, x_4); +return x_5; +} +} +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_match__1(lean_object* x_1) { +_start: +{ +lean_object* x_2; +x_2 = lean_alloc_closure((void*)(l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_match__1___rarg), 2, 0); +return x_2; +} +} lean_object* l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___spec__1(lean_object* x_1, lean_object* x_2, size_t x_3, size_t x_4, lean_object* x_5) { _start: { @@ -2499,18 +2519,228 @@ goto _start; } } } -lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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* 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* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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, uint8_t 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) { _start: { -lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; uint8_t x_22; lean_object* x_23; -x_17 = lean_expr_instantiate1(x_1, x_2); -x_18 = l_Lean_Syntax_mkApp___closed__1; -x_19 = lean_array_push(x_18, x_2); -x_20 = lean_array_push(x_19, x_9); -x_21 = 0; -x_22 = 1; +lean_object* x_18; lean_object* x_19; lean_object* x_20; lean_object* x_21; uint8_t x_22; uint8_t x_23; lean_object* x_24; +x_18 = lean_expr_instantiate1(x_1, x_2); +x_19 = l_Lean_Syntax_mkApp___closed__1; +x_20 = lean_array_push(x_19, x_2); +x_21 = lean_array_push(x_20, x_10); +x_22 = 0; +x_23 = 1; +lean_inc(x_13); +x_24 = l_Lean_Meta_mkForallFVars(x_21, x_18, x_22, x_23, x_13, x_14, x_15, x_16, x_17); +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_16); +lean_inc(x_15); +lean_inc(x_14); +lean_inc(x_13); +lean_inc(x_3); +x_27 = l_Lean_Meta_mkEqRefl(x_3, x_13, x_14, x_15, x_16, x_26); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; size_t x_33; size_t x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +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); +x_30 = lean_array_push(x_4, x_28); +x_31 = lean_array_push(x_30, x_3); +x_32 = lean_array_get_size(x_5); +x_33 = lean_usize_of_nat(x_32); +lean_dec(x_32); +x_34 = 0; +x_35 = x_5; +x_36 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___spec__1(x_6, x_7, x_33, x_34, x_35); +x_37 = x_36; +x_38 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(x_8, x_6, x_31, x_25, x_9, x_37, x_11, x_12, x_13, x_14, x_15, x_16, x_29); +return x_38; +} +else +{ +uint8_t x_39; +lean_dec(x_25); +lean_dec(x_16); +lean_dec(x_15); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(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_39 = !lean_is_exclusive(x_27); +if (x_39 == 0) +{ +return x_27; +} +else +{ +lean_object* x_40; lean_object* x_41; lean_object* x_42; +x_40 = lean_ctor_get(x_27, 0); +x_41 = lean_ctor_get(x_27, 1); +lean_inc(x_41); +lean_inc(x_40); +lean_dec(x_27); +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_16); +lean_dec(x_15); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(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_43 = !lean_is_exclusive(x_24); +if (x_43 == 0) +{ +return x_24; +} +else +{ +lean_object* x_44; lean_object* x_45; lean_object* x_46; +x_44 = lean_ctor_get(x_24, 0); +x_45 = lean_ctor_get(x_24, 1); +lean_inc(x_45); +lean_inc(x_44); +lean_dec(x_24); +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; +} +} +} +} +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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, uint8_t 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) { +_start: +{ +lean_object* x_17; +lean_inc(x_15); +lean_inc(x_14); +lean_inc(x_13); lean_inc(x_12); -x_23 = l_Lean_Meta_mkForallFVars(x_20, x_17, x_21, x_22, x_12, x_13, x_14, x_15, x_16); +lean_inc(x_9); +lean_inc(x_1); +x_17 = l_Lean_Meta_mkEq(x_1, x_9, x_12, x_13, x_14, x_15, x_16); +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_23; lean_object* x_24; +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_Syntax_getId(x_2); +x_21 = lean_box(x_8); +x_22 = lean_alloc_closure((void*)(l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1___boxed), 17, 9); +lean_closure_set(x_22, 0, x_3); +lean_closure_set(x_22, 1, x_9); +lean_closure_set(x_22, 2, x_1); +lean_closure_set(x_22, 3, x_4); +lean_closure_set(x_22, 4, x_5); +lean_closure_set(x_22, 5, x_6); +lean_closure_set(x_22, 6, x_2); +lean_closure_set(x_22, 7, x_7); +lean_closure_set(x_22, 8, x_21); +x_23 = 0; +x_24 = l_Lean_Meta_withLocalDecl___at___private_Lean_Elab_Term_0__Lean_Elab_Term_elabImplicitLambda___spec__1___rarg(x_20, x_23, x_18, x_22, x_10, x_11, x_12, x_13, x_14, x_15, x_19); +return x_24; +} +else +{ +uint8_t x_25; +lean_dec(x_15); +lean_dec(x_14); +lean_dec(x_13); +lean_dec(x_12); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_9); +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_25 = !lean_is_exclusive(x_17); +if (x_25 == 0) +{ +return x_17; +} +else +{ +lean_object* x_26; lean_object* x_27; lean_object* x_28; +x_26 = lean_ctor_get(x_17, 0); +x_27 = lean_ctor_get(x_17, 1); +lean_inc(x_27); +lean_inc(x_26); +lean_dec(x_17); +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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(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* x_12, lean_object* x_13) { +_start: +{ +lean_object* x_14; uint8_t x_15; +x_14 = lean_unsigned_to_nat(0u); +x_15 = lean_nat_dec_eq(x_2, 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; +x_16 = lean_unsigned_to_nat(1u); +x_17 = lean_nat_sub(x_2, x_16); +lean_dec(x_2); +x_18 = l_Lean_instInhabitedSyntax; +x_19 = lean_array_get(x_18, x_1, x_17); +lean_inc(x_11); +lean_inc(x_9); +lean_inc(x_7); +x_20 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabAtomicDiscr(x_19, x_7, x_8, x_9, x_10, x_11, x_12, x_13); +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); +lean_inc(x_12); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +x_23 = l_Lean_Meta_instantiateMVars(x_21, x_9, x_10, x_11, x_12, x_22); if (lean_obj_tag(x_23) == 0) { lean_object* x_24; lean_object* x_25; lean_object* x_26; @@ -2519,142 +2749,347 @@ lean_inc(x_24); x_25 = lean_ctor_get(x_23, 1); lean_inc(x_25); lean_dec(x_23); -lean_inc(x_15); -lean_inc(x_14); -lean_inc(x_13); lean_inc(x_12); -lean_inc(x_3); -x_26 = l_Lean_Meta_mkEqRefl(x_3, x_12, x_13, x_14, x_15, x_25); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_24); +x_26 = l_Lean_Meta_inferType(x_24, x_9, x_10, x_11, x_12, x_25); if (lean_obj_tag(x_26) == 0) { -lean_object* x_27; lean_object* x_28; lean_object* x_29; lean_object* x_30; lean_object* x_31; size_t x_32; size_t x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; lean_object* x_37; +lean_object* x_27; lean_object* x_28; lean_object* x_29; 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 = lean_array_push(x_4, x_27); -x_30 = lean_array_push(x_29, x_3); -x_31 = lean_array_get_size(x_5); -x_32 = lean_usize_of_nat(x_31); -lean_dec(x_31); -x_33 = 0; -x_34 = x_5; -x_35 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___spec__1(x_6, x_7, x_32, x_33, x_34); -x_36 = x_35; -x_37 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(x_8, x_6, x_30, x_24, x_36, x_10, x_11, x_12, x_13, x_14, x_15, x_28); -return x_37; +lean_inc(x_12); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +x_29 = l_Lean_Meta_instantiateMVars(x_27, x_9, x_10, x_11, x_12, x_28); +if (lean_obj_tag(x_29) == 0) +{ +lean_object* x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; +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 = lean_box(0); +lean_inc(x_12); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_24); +x_33 = l_Lean_Meta_kabstract(x_4, x_24, x_32, x_9, x_10, x_11, x_12, x_31); +if (lean_obj_tag(x_33) == 0) +{ +lean_object* x_34; lean_object* x_35; uint8_t x_36; lean_object* x_37; lean_object* x_38; lean_object* x_51; +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); +lean_inc(x_9); +lean_inc(x_7); +lean_inc(x_24); +x_51 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_mkUserNameFor(x_24, x_7, x_8, x_9, x_10, x_11, x_12, x_35); +if (x_5 == 0) +{ +if (lean_obj_tag(x_51) == 0) +{ +lean_object* x_52; lean_object* x_53; uint8_t 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); +x_54 = l_Lean_Expr_hasLooseBVars(x_34); +x_36 = x_54; +x_37 = x_52; +x_38 = x_53; +goto block_50; } else { -uint8_t x_38; +uint8_t x_55; +lean_dec(x_34); +lean_dec(x_30); lean_dec(x_24); -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); +lean_dec(x_19); +lean_dec(x_17); 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_6); +lean_dec(x_3); +lean_dec(x_1); +x_55 = !lean_is_exclusive(x_51); +if (x_55 == 0) +{ +return x_51; +} +else +{ +lean_object* x_56; lean_object* x_57; lean_object* x_58; +x_56 = lean_ctor_get(x_51, 0); +x_57 = lean_ctor_get(x_51, 1); +lean_inc(x_57); +lean_inc(x_56); +lean_dec(x_51); +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 +{ +if (lean_obj_tag(x_51) == 0) +{ +lean_object* x_59; lean_object* x_60; uint8_t x_61; +x_59 = lean_ctor_get(x_51, 0); +lean_inc(x_59); +x_60 = lean_ctor_get(x_51, 1); +lean_inc(x_60); +lean_dec(x_51); +x_61 = 1; +x_36 = x_61; +x_37 = x_59; +x_38 = x_60; +goto block_50; +} +else +{ +uint8_t x_62; +lean_dec(x_34); +lean_dec(x_30); +lean_dec(x_24); +lean_dec(x_19); +lean_dec(x_17); +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_6); +lean_dec(x_3); +lean_dec(x_1); +x_62 = !lean_is_exclusive(x_51); +if (x_62 == 0) +{ +return x_51; +} +else +{ +lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_63 = lean_ctor_get(x_51, 0); +x_64 = lean_ctor_get(x_51, 1); +lean_inc(x_64); +lean_inc(x_63); +lean_dec(x_51); +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; +} +} +} +block_50: +{ +lean_object* x_39; uint8_t x_40; +x_39 = l_Lean_Syntax_getArg(x_19, x_14); +lean_dec(x_19); +x_40 = l_Lean_Syntax_isNone(x_39); +if (x_40 == 0) +{ +lean_object* x_41; lean_object* x_42; lean_object* x_43; uint8_t x_44; lean_object* x_45; +x_41 = l_Lean_Syntax_getArg(x_39, x_14); +lean_dec(x_39); +x_42 = lean_box(x_36); +x_43 = lean_alloc_closure((void*)(l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__2___boxed), 16, 8); +lean_closure_set(x_43, 0, x_24); +lean_closure_set(x_43, 1, x_41); +lean_closure_set(x_43, 2, x_34); +lean_closure_set(x_43, 3, x_3); +lean_closure_set(x_43, 4, x_6); +lean_closure_set(x_43, 5, x_17); +lean_closure_set(x_43, 6, x_1); +lean_closure_set(x_43, 7, x_42); +x_44 = 0; +x_45 = l_Lean_Meta_withLocalDecl___at___private_Lean_Elab_Term_0__Lean_Elab_Term_elabImplicitLambda___spec__1___rarg(x_37, x_44, x_30, x_43, x_7, x_8, x_9, x_10, x_11, x_12, x_38); +return x_45; +} +else +{ +lean_object* x_46; uint8_t x_47; lean_object* x_48; +lean_dec(x_39); +x_46 = lean_array_push(x_3, x_24); +x_47 = 0; +x_48 = l_Lean_mkForall(x_37, x_47, x_30, x_34); +x_2 = x_17; +x_3 = x_46; +x_4 = x_48; +x_5 = x_36; +x_13 = x_38; +goto _start; +} +} +} +else +{ +uint8_t x_66; +lean_dec(x_30); +lean_dec(x_24); +lean_dec(x_19); +lean_dec(x_17); +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_6); +lean_dec(x_3); +lean_dec(x_1); +x_66 = !lean_is_exclusive(x_33); +if (x_66 == 0) +{ +return x_33; +} +else +{ +lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_67 = lean_ctor_get(x_33, 0); +x_68 = lean_ctor_get(x_33, 1); +lean_inc(x_68); +lean_inc(x_67); +lean_dec(x_33); +x_69 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_69, 0, x_67); +lean_ctor_set(x_69, 1, x_68); +return x_69; +} +} +} +else +{ +uint8_t x_70; +lean_dec(x_24); +lean_dec(x_19); +lean_dec(x_17); +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_6); -lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_38 = !lean_is_exclusive(x_26); -if (x_38 == 0) +lean_dec(x_1); +x_70 = !lean_is_exclusive(x_29); +if (x_70 == 0) +{ +return x_29; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; +x_71 = lean_ctor_get(x_29, 0); +x_72 = lean_ctor_get(x_29, 1); +lean_inc(x_72); +lean_inc(x_71); +lean_dec(x_29); +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_19); +lean_dec(x_17); +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_6); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_1); +x_74 = !lean_is_exclusive(x_26); +if (x_74 == 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_object* x_75; lean_object* x_76; lean_object* x_77; +x_75 = lean_ctor_get(x_26, 0); +x_76 = lean_ctor_get(x_26, 1); +lean_inc(x_76); +lean_inc(x_75); 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; +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_42; -lean_dec(x_15); -lean_dec(x_14); -lean_dec(x_13); +uint8_t x_78; +lean_dec(x_19); +lean_dec(x_17); 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_6); -lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -x_42 = !lean_is_exclusive(x_23); -if (x_42 == 0) +lean_dec(x_1); +x_78 = !lean_is_exclusive(x_23); +if (x_78 == 0) { return x_23; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_23, 0); -x_44 = lean_ctor_get(x_23, 1); -lean_inc(x_44); -lean_inc(x_43); +lean_object* x_79; lean_object* x_80; lean_object* x_81; +x_79 = lean_ctor_get(x_23, 0); +x_80 = lean_ctor_get(x_23, 1); +lean_inc(x_80); +lean_inc(x_79); lean_dec(x_23); -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; +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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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* x_10, lean_object* x_11, lean_object* x_12, lean_object* x_13, lean_object* x_14, lean_object* x_15) { -_start: -{ -lean_object* x_16; -lean_inc(x_14); -lean_inc(x_13); -lean_inc(x_12); -lean_inc(x_11); -lean_inc(x_8); -lean_inc(x_1); -x_16 = l_Lean_Meta_mkEq(x_1, x_8, x_11, x_12, x_13, x_14, 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; uint8_t x_21; lean_object* x_22; -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_Syntax_getId(x_2); -x_20 = lean_alloc_closure((void*)(l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1___boxed), 16, 8); -lean_closure_set(x_20, 0, x_3); -lean_closure_set(x_20, 1, x_8); -lean_closure_set(x_20, 2, x_1); -lean_closure_set(x_20, 3, x_4); -lean_closure_set(x_20, 4, x_5); -lean_closure_set(x_20, 5, x_6); -lean_closure_set(x_20, 6, x_2); -lean_closure_set(x_20, 7, x_7); -x_21 = 0; -x_22 = l_Lean_Meta_withLocalDecl___at___private_Lean_Elab_Term_0__Lean_Elab_Term_elabImplicitLambda___spec__1___rarg(x_19, x_21, x_17, x_20, x_9, x_10, x_11, x_12, x_13, x_14, x_18); -return x_22; -} else { -uint8_t x_23; -lean_dec(x_14); -lean_dec(x_13); +uint8_t x_82; +lean_dec(x_19); +lean_dec(x_17); lean_dec(x_12); lean_dec(x_11); lean_dec(x_10); @@ -2662,396 +3097,50 @@ 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_1); +x_82 = !lean_is_exclusive(x_20); +if (x_82 == 0) +{ +return x_20; +} +else +{ +lean_object* x_83; lean_object* x_84; lean_object* x_85; +x_83 = lean_ctor_get(x_20, 0); +x_84 = lean_ctor_get(x_20, 1); +lean_inc(x_84); +lean_inc(x_83); +lean_dec(x_20); +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 +{ +lean_object* x_86; lean_object* x_87; lean_object* x_88; +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_2); lean_dec(x_1); -x_23 = !lean_is_exclusive(x_16); -if (x_23 == 0) -{ -return x_16; -} -else -{ -lean_object* x_24; lean_object* x_25; lean_object* x_26; -x_24 = lean_ctor_get(x_16, 0); -x_25 = lean_ctor_get(x_16, 1); -lean_inc(x_25); -lean_inc(x_24); -lean_dec(x_16); -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_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(lean_object* x_1, 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; uint8_t x_14; -x_13 = lean_unsigned_to_nat(0u); -x_14 = lean_nat_dec_eq(x_2, 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; -x_15 = lean_unsigned_to_nat(1u); -x_16 = lean_nat_sub(x_2, x_15); -lean_dec(x_2); -x_17 = l_Lean_instInhabitedSyntax; -x_18 = lean_array_get(x_17, x_1, x_16); -lean_inc(x_10); -lean_inc(x_8); -lean_inc(x_6); -x_19 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabAtomicDiscr(x_18, x_6, x_7, x_8, x_9, x_10, x_11, x_12); -if (lean_obj_tag(x_19) == 0) -{ -lean_object* x_20; lean_object* x_21; lean_object* x_22; -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); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_22 = l_Lean_Meta_instantiateMVars(x_20, x_8, x_9, x_10, x_11, x_21); -if (lean_obj_tag(x_22) == 0) -{ -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_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_23); -x_25 = l_Lean_Meta_inferType(x_23, x_8, x_9, x_10, x_11, x_24); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; -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); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_28 = l_Lean_Meta_instantiateMVars(x_26, x_8, x_9, x_10, x_11, x_27); -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 = lean_box(0); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_23); -x_32 = l_Lean_Meta_kabstract(x_4, x_23, x_31, x_8, x_9, x_10, x_11, x_30); -if (lean_obj_tag(x_32) == 0) -{ -lean_object* x_33; lean_object* x_34; lean_object* x_35; -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_8); -lean_inc(x_6); -lean_inc(x_23); -x_35 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_mkUserNameFor(x_23, x_6, x_7, x_8, x_9, x_10, x_11, x_34); -if (lean_obj_tag(x_35) == 0) -{ -lean_object* x_36; lean_object* x_37; lean_object* x_38; uint8_t 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); -lean_dec(x_35); -x_38 = l_Lean_Syntax_getArg(x_18, x_13); -lean_dec(x_18); -x_39 = l_Lean_Syntax_isNone(x_38); -if (x_39 == 0) -{ -lean_object* x_40; lean_object* x_41; uint8_t x_42; lean_object* x_43; -x_40 = l_Lean_Syntax_getArg(x_38, x_13); -lean_dec(x_38); -x_41 = lean_alloc_closure((void*)(l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__2), 15, 7); -lean_closure_set(x_41, 0, x_23); -lean_closure_set(x_41, 1, x_40); -lean_closure_set(x_41, 2, x_33); -lean_closure_set(x_41, 3, x_3); -lean_closure_set(x_41, 4, x_5); -lean_closure_set(x_41, 5, x_16); -lean_closure_set(x_41, 6, x_1); -x_42 = 0; -x_43 = l_Lean_Meta_withLocalDecl___at___private_Lean_Elab_Term_0__Lean_Elab_Term_elabImplicitLambda___spec__1___rarg(x_36, x_42, x_29, x_41, x_6, x_7, x_8, x_9, x_10, x_11, x_37); -return x_43; -} -else -{ -lean_object* x_44; uint8_t x_45; lean_object* x_46; -lean_dec(x_38); -x_44 = lean_array_push(x_3, x_23); -x_45 = 0; -x_46 = l_Lean_mkForall(x_36, x_45, x_29, x_33); -x_2 = x_16; -x_3 = x_44; -x_4 = x_46; -x_12 = x_37; -goto _start; -} -} -else -{ -uint8_t x_48; -lean_dec(x_33); -lean_dec(x_29); -lean_dec(x_23); -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_1); -x_48 = !lean_is_exclusive(x_35); -if (x_48 == 0) -{ -return x_35; -} -else -{ -lean_object* x_49; lean_object* x_50; lean_object* x_51; -x_49 = lean_ctor_get(x_35, 0); -x_50 = lean_ctor_get(x_35, 1); -lean_inc(x_50); -lean_inc(x_49); -lean_dec(x_35); -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_52; -lean_dec(x_29); -lean_dec(x_23); -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_3); -lean_dec(x_1); -x_52 = !lean_is_exclusive(x_32); -if (x_52 == 0) -{ -return x_32; -} -else -{ -lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_53 = lean_ctor_get(x_32, 0); -x_54 = lean_ctor_get(x_32, 1); -lean_inc(x_54); -lean_inc(x_53); -lean_dec(x_32); -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_56; -lean_dec(x_23); -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_56 = !lean_is_exclusive(x_28); -if (x_56 == 0) -{ -return x_28; -} -else -{ -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_28, 0); -x_58 = lean_ctor_get(x_28, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_28); -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_23); -lean_dec(x_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_60 = !lean_is_exclusive(x_25); -if (x_60 == 0) -{ -return x_25; -} -else -{ -lean_object* x_61; lean_object* x_62; lean_object* x_63; -x_61 = lean_ctor_get(x_25, 0); -x_62 = lean_ctor_get(x_25, 1); -lean_inc(x_62); -lean_inc(x_61); -lean_dec(x_25); -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_18); -lean_dec(x_16); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_64 = !lean_is_exclusive(x_22); -if (x_64 == 0) -{ -return x_22; -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_65 = lean_ctor_get(x_22, 0); -x_66 = lean_ctor_get(x_22, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_22); -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_16); -lean_dec(x_11); -lean_dec(x_10); -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_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 -{ -lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_2); -lean_dec(x_1); -x_72 = l_Array_reverse___rarg(x_3); -x_73 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_73, 0, x_4); -lean_ctor_set(x_73, 1, x_5); -x_74 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_74, 0, x_72); -lean_ctor_set(x_74, 1, x_73); -x_75 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_75, 0, x_74); -lean_ctor_set(x_75, 1, x_12); -return x_75; +x_86 = l_Array_reverse___rarg(x_3); +x_87 = lean_alloc_ctor(0, 3, 1); +lean_ctor_set(x_87, 0, x_86); +lean_ctor_set(x_87, 1, x_4); +lean_ctor_set(x_87, 2, x_6); +lean_ctor_set_uint8(x_87, sizeof(void*)*3, x_5); +x_88 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_88, 0, x_87); +lean_ctor_set(x_88, 1, x_13); +return x_88; } } } @@ -3068,13 +3157,52 @@ lean_dec(x_1); return x_8; } } -lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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, lean_object* x_13, lean_object* x_14, lean_object* x_15, lean_object* x_16) { +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1___boxed(lean_object** _args) { +lean_object* x_1 = _args[0]; +lean_object* x_2 = _args[1]; +lean_object* x_3 = _args[2]; +lean_object* x_4 = _args[3]; +lean_object* x_5 = _args[4]; +lean_object* x_6 = _args[5]; +lean_object* x_7 = _args[6]; +lean_object* x_8 = _args[7]; +lean_object* x_9 = _args[8]; +lean_object* x_10 = _args[9]; +lean_object* x_11 = _args[10]; +lean_object* x_12 = _args[11]; +lean_object* x_13 = _args[12]; +lean_object* x_14 = _args[13]; +lean_object* x_15 = _args[14]; +lean_object* x_16 = _args[15]; +lean_object* x_17 = _args[16]; _start: { -lean_object* x_17; -x_17 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1(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, x_14, x_15, x_16); +uint8_t x_18; lean_object* x_19; +x_18 = lean_unbox(x_9); +lean_dec(x_9); +x_19 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__1(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_18, x_10, x_11, x_12, x_13, x_14, x_15, x_16, x_17); lean_dec(x_1); -return x_17; +return x_19; +} +} +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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, 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) { +_start: +{ +uint8_t x_17; lean_object* x_18; +x_17 = lean_unbox(x_8); +lean_dec(x_8); +x_18 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___lambda__2(x_1, x_2, x_3, x_4, x_5, x_6, x_7, x_17, x_9, x_10, x_11, x_12, x_13, x_14, x_15, x_16); +return x_18; +} +} +lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop___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_5); +lean_dec(x_5); +x_15 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(x_1, x_2, x_3, x_4, x_14, x_6, x_7, x_8, x_9, x_10, x_11, x_12, x_13); +return x_15; } } lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs(lean_object* x_1, 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) { @@ -3114,87 +3242,67 @@ uint8_t x_21; x_21 = !lean_is_exclusive(x_20); if (x_21 == 0) { -lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_object* x_22; lean_object* x_23; lean_object* x_24; lean_object* x_25; uint8_t x_26; x_22 = lean_ctor_get(x_20, 0); -x_23 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_23, 0, x_18); -lean_ctor_set(x_23, 1, x_3); -x_24 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_24, 0, x_22); -lean_ctor_set(x_24, 1, x_23); -lean_ctor_set(x_20, 0, x_24); +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_alloc_ctor(0, 3, 1); +lean_ctor_set(x_25, 0, x_23); +lean_ctor_set(x_25, 1, x_18); +lean_ctor_set(x_25, 2, x_3); +x_26 = lean_unbox(x_24); +lean_dec(x_24); +lean_ctor_set_uint8(x_25, sizeof(void*)*3, x_26); +lean_ctor_set(x_20, 0, x_25); return x_20; } else { -lean_object* x_25; lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_25 = lean_ctor_get(x_20, 0); -x_26 = lean_ctor_get(x_20, 1); -lean_inc(x_26); -lean_inc(x_25); +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; +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_27 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_27, 0, x_18); -lean_ctor_set(x_27, 1, x_3); -x_28 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_28, 0, x_25); -lean_ctor_set(x_28, 1, x_27); -x_29 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_29, 0, x_28); -lean_ctor_set(x_29, 1, x_26); -return x_29; -} -} -else -{ -uint8_t x_30; -lean_dec(x_18); -lean_dec(x_3); -x_30 = !lean_is_exclusive(x_20); -if (x_30 == 0) -{ -return x_20; -} -else -{ -lean_object* x_31; lean_object* x_32; lean_object* x_33; -x_31 = lean_ctor_get(x_20, 0); -x_32 = lean_ctor_get(x_20, 1); -lean_inc(x_32); -lean_inc(x_31); -lean_dec(x_20); -x_33 = lean_alloc_ctor(1, 2, 0); +x_29 = lean_ctor_get(x_27, 0); +lean_inc(x_29); +x_30 = lean_ctor_get(x_27, 1); +lean_inc(x_30); +lean_dec(x_27); +x_31 = lean_alloc_ctor(0, 3, 1); +lean_ctor_set(x_31, 0, x_29); +lean_ctor_set(x_31, 1, x_18); +lean_ctor_set(x_31, 2, x_3); +x_32 = lean_unbox(x_30); +lean_dec(x_30); +lean_ctor_set_uint8(x_31, sizeof(void*)*3, x_32); +x_33 = lean_alloc_ctor(0, 2, 0); lean_ctor_set(x_33, 0, x_31); -lean_ctor_set(x_33, 1, x_32); +lean_ctor_set(x_33, 1, x_28); return x_33; } } -} else { uint8_t x_34; -lean_dec(x_10); -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_18); lean_dec(x_3); -lean_dec(x_1); -x_34 = !lean_is_exclusive(x_17); +x_34 = !lean_is_exclusive(x_20); if (x_34 == 0) { -return x_17; +return x_20; } else { lean_object* x_35; lean_object* x_36; lean_object* x_37; -x_35 = lean_ctor_get(x_17, 0); -x_36 = lean_ctor_get(x_17, 1); +x_35 = lean_ctor_get(x_20, 0); +x_36 = lean_ctor_get(x_20, 1); lean_inc(x_36); lean_inc(x_35); -lean_dec(x_17); +lean_dec(x_20); x_37 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_37, 0, x_35); lean_ctor_set(x_37, 1, x_36); @@ -3204,11 +3312,44 @@ return x_37; } else { -lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_38 = lean_array_get_size(x_1); -x_39 = l_Array_empty___closed__1; -x_40 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(x_1, x_38, x_39, x_4, x_3, x_5, x_6, x_7, x_8, x_9, x_10, x_11); -return x_40; +uint8_t x_38; +lean_dec(x_10); +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_1); +x_38 = !lean_is_exclusive(x_17); +if (x_38 == 0) +{ +return x_17; +} +else +{ +lean_object* x_39; lean_object* x_40; lean_object* x_41; +x_39 = lean_ctor_get(x_17, 0); +x_40 = lean_ctor_get(x_17, 1); +lean_inc(x_40); +lean_inc(x_39); +lean_dec(x_17); +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; uint8_t x_44; lean_object* x_45; +x_42 = lean_array_get_size(x_1); +x_43 = l_Array_empty___closed__1; +x_44 = 0; +x_45 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchTypeAndDiscrs_loop(x_1, x_42, x_43, x_4, x_44, x_3, x_5, x_6, x_7, x_8, x_9, x_10, x_11); +return x_45; } } } @@ -3536,7 +3677,7 @@ _start: lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; x_1 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1___closed__1; x_2 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1___closed__2; -x_3 = lean_unsigned_to_nat(127u); +x_3 = lean_unsigned_to_nat(137u); x_4 = lean_unsigned_to_nat(13u); x_5 = l_Lean_Name_getString_x21___closed__3; x_6 = l___private_Init_Util_0__mkPanicMessageWithDecl(x_1, x_2, x_3, x_4, x_5); @@ -3613,7 +3754,7 @@ _start: lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; x_1 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1___closed__1; x_2 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1___closed__2; -x_3 = lean_unsigned_to_nat(128u); +x_3 = lean_unsigned_to_nat(138u); x_4 = lean_unsigned_to_nat(9u); x_5 = l_Lean_Name_getString_x21___closed__3; x_6 = l___private_Init_Util_0__mkPanicMessageWithDecl(x_1, x_2, x_3, x_4, x_5); @@ -3873,7 +4014,7 @@ return x_11; } } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__1() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__1() { _start: { lean_object* x_1; @@ -3881,21 +4022,21 @@ x_1 = lean_mk_string("MVarWithIdKind"); return x_1; } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; x_1 = lean_box(0); -x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__1; +x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__1; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489_(lean_object* x_1) { +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601_(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; -x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2; +x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2; x_3 = l_Lean_Parser_registerBuiltinNodeKind(x_2, x_1); return x_3; } @@ -3916,7 +4057,7 @@ lean_ctor_set(x_7, 0, x_5); lean_ctor_set(x_7, 1, x_6); x_8 = l_Lean_mkOptionalNode___closed__2; x_9 = lean_array_push(x_8, x_7); -x_10 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2; +x_10 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2; x_11 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_11, 0, x_10); lean_ctor_set(x_11, 1, x_9); @@ -3937,7 +4078,7 @@ lean_ctor_set(x_15, 0, x_12); lean_ctor_set(x_15, 1, x_14); x_16 = l_Lean_mkOptionalNode___closed__2; x_17 = lean_array_push(x_16, x_15); -x_18 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2; +x_18 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2; x_19 = lean_alloc_ctor(1, 2, 0); lean_ctor_set(x_19, 0, x_18); lean_ctor_set(x_19, 1, x_17); @@ -4039,7 +4180,7 @@ _start: { lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_2 = l_Lean_Elab_Term_termElabAttribute; -x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2; +x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2; x_4 = l___regBuiltin_Lean_Elab_Term_elabMVarWithIdKind___closed__1; x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; @@ -5224,7 +5365,7 @@ _start: lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; x_1 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1___closed__1; x_2 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_CollectPatternVars_CtorApp_pushNewArg___closed__3; -x_3 = lean_unsigned_to_nat(272u); +x_3 = lean_unsigned_to_nat(282u); x_4 = lean_unsigned_to_nat(9u); x_5 = l_Lean_Name_getString_x21___closed__3; x_6 = l___private_Init_Util_0__mkPanicMessageWithDecl(x_1, x_2, x_3, x_4, x_5); @@ -15121,7 +15262,7 @@ lean_object* x_60; lean_object* x_61; lean_object* x_62; lean_object* x_63; lean x_60 = lean_ctor_get(x_54, 1); lean_inc(x_60); lean_dec(x_54); -x_61 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_61 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_62 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at_Lean_Elab_Term_CollectPatternVars_main___spec__2(x_61, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_60); x_63 = lean_ctor_get(x_62, 0); lean_inc(x_63); @@ -15209,7 +15350,7 @@ x_36 = l_Lean_KernelException_toMessageData___closed__15; x_37 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_37, 0, x_35); lean_ctor_set(x_37, 1, x_36); -x_38 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_38 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_39 = l_Lean_addTrace___at_Lean_Elab_Term_CollectPatternVars_main___spec__1(x_38, x_37, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_20); x_40 = lean_ctor_get(x_39, 1); lean_inc(x_40); @@ -17722,7 +17863,7 @@ lean_object* x_121; lean_object* x_122; lean_object* x_123; lean_object* x_124; x_121 = lean_ctor_get(x_115, 1); lean_inc(x_121); lean_dec(x_115); -x_122 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_122 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_123 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_122, x_5, x_6, x_7, x_8, x_9, x_10, x_121); x_124 = lean_ctor_get(x_123, 0); lean_inc(x_124); @@ -17776,7 +17917,7 @@ lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; lean x_87 = lean_ctor_get(x_81, 1); lean_inc(x_87); lean_dec(x_81); -x_88 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_88 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_89 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_88, x_5, x_6, x_7, x_8, x_9, x_10, x_87); x_90 = lean_ctor_get(x_89, 0); lean_inc(x_90); @@ -17905,7 +18046,7 @@ x_57 = l_Lean_KernelException_toMessageData___closed__15; x_58 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_58, 0, x_56); lean_ctor_set(x_58, 1, x_57); -x_59 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_59 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_60 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_59, x_58, x_5, x_6, x_7, x_8, x_9, x_10, x_32); x_61 = lean_ctor_get(x_60, 1); lean_inc(x_61); @@ -18052,7 +18193,7 @@ x_109 = l_Lean_KernelException_toMessageData___closed__15; x_110 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_110, 0, x_108); lean_ctor_set(x_110, 1, x_109); -x_111 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_111 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_112 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_111, x_110, x_5, x_6, x_7, x_8, x_9, x_10, x_96); x_113 = lean_ctor_get(x_112, 1); lean_inc(x_113); @@ -22041,7 +22182,7 @@ lean_object* x_43; lean_object* x_44; lean_object* x_45; lean_object* x_46; lean x_43 = lean_ctor_get(x_37, 1); lean_inc(x_43); lean_dec(x_37); -x_44 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_44 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_45 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_44, x_3, x_4, x_5, x_6, x_7, x_8, x_43); x_46 = lean_ctor_get(x_45, 0); lean_inc(x_46); @@ -22059,7 +22200,7 @@ block_36: if (x_19 == 0) { lean_object* x_21; lean_object* x_22; lean_object* x_23; -x_21 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_21 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_22 = lean_alloc_closure((void*)(l_Lean_Elab_Term_elabMatchAltView___lambda__3___boxed), 11, 3); lean_closure_set(x_22, 0, x_18); lean_closure_set(x_22, 1, x_21); @@ -22083,7 +22224,7 @@ x_29 = l_Lean_KernelException_toMessageData___closed__15; x_30 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_30, 0, x_28); lean_ctor_set(x_30, 1, x_29); -x_31 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_31 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_32 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_31, x_30, x_3, x_4, x_5, x_6, x_7, x_8, x_20); x_33 = lean_ctor_get(x_32, 1); lean_inc(x_33); @@ -22204,7 +22345,7 @@ lean_object* x_92; lean_object* x_93; lean_object* x_94; lean_object* x_95; lean x_92 = lean_ctor_get(x_86, 1); lean_inc(x_92); lean_dec(x_86); -x_93 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_93 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_94 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_93, x_3, x_4, x_5, x_6, x_62, x_8, x_92); x_95 = lean_ctor_get(x_94, 0); lean_inc(x_95); @@ -22222,7 +22363,7 @@ block_85: if (x_68 == 0) { lean_object* x_70; lean_object* x_71; lean_object* x_72; -x_70 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_70 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_71 = lean_alloc_closure((void*)(l_Lean_Elab_Term_elabMatchAltView___lambda__3___boxed), 11, 3); lean_closure_set(x_71, 0, x_67); lean_closure_set(x_71, 1, x_70); @@ -22246,7 +22387,7 @@ x_78 = l_Lean_KernelException_toMessageData___closed__15; x_79 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_79, 0, x_77); lean_ctor_set(x_79, 1, x_78); -x_80 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_80 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_81 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_80, x_79, x_3, x_4, x_5, x_6, x_62, x_8, x_69); x_82 = lean_ctor_get(x_81, 1); lean_inc(x_82); @@ -22335,7 +22476,7 @@ lean_dec(x_5); return x_12; } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -22345,7 +22486,7 @@ x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__2() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__2() { _start: { lean_object* x_1; @@ -22353,17 +22494,17 @@ x_1 = lean_mk_string("ignoreUnusedAlts"); return x_1; } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__3() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__3() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; -x_1 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1; -x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__2; +x_1 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1; +x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__2; x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__4() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__4() { _start: { lean_object* x_1; @@ -22371,13 +22512,13 @@ x_1 = lean_mk_string("if true, do not generate error if an alternative is not us return x_1; } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__5() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__5() { _start: { uint8_t x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; x_1 = 0; x_2 = l_Lean_instInhabitedParserDescr___closed__1; -x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__4; +x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__4; x_4 = lean_box(x_1); x_5 = lean_alloc_ctor(0, 3, 0); lean_ctor_set(x_5, 0, x_4); @@ -22386,12 +22527,12 @@ lean_ctor_set(x_5, 2, x_3); return x_5; } } -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993_(lean_object* x_1) { +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105_(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; lean_object* x_4; -x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__3; -x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__5; +x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__3; +x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__5; x_4 = l_Lean_Option_register___at_Lean_Elab_initFn____x40_Lean_Elab_AutoBound___hyg_4____spec__1(x_2, x_3, x_1); return x_4; } @@ -24421,7 +24562,7 @@ _start: lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; x_1 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___spec__1___closed__1; x_2 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_isMatchUnit_x3f___closed__3; -x_3 = lean_unsigned_to_nat(715u); +x_3 = lean_unsigned_to_nat(725u); x_4 = lean_unsigned_to_nat(2u); x_5 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_isMatchUnit_x3f___closed__2; x_6 = l___private_Init_Util_0__mkPanicMessageWithDecl(x_1, x_2, x_3, x_4, x_5); @@ -24665,19 +24806,18 @@ return x_8; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux_match__1___rarg(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; -x_3 = lean_ctor_get(x_1, 1); +lean_object* x_3; lean_object* x_4; uint8_t x_5; lean_object* x_6; lean_object* x_7; lean_object* x_8; +x_3 = lean_ctor_get(x_1, 0); lean_inc(x_3); -x_4 = lean_ctor_get(x_1, 0); +x_4 = lean_ctor_get(x_1, 1); lean_inc(x_4); -lean_dec(x_1); -x_5 = lean_ctor_get(x_3, 0); -lean_inc(x_5); -x_6 = lean_ctor_get(x_3, 1); +x_5 = lean_ctor_get_uint8(x_1, sizeof(void*)*3); +x_6 = lean_ctor_get(x_1, 2); lean_inc(x_6); -lean_dec(x_3); -x_7 = lean_apply_3(x_2, x_4, x_5, x_6); -return x_7; +lean_dec(x_1); +x_7 = lean_box(x_5); +x_8 = lean_apply_4(x_2, x_3, x_4, x_7, x_6); +return x_8; } } lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux_match__1(lean_object* x_1) { @@ -24721,24 +24861,29 @@ return x_2; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux_match__3___rarg(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_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; x_3 = lean_ctor_get(x_1, 1); lean_inc(x_3); x_4 = lean_ctor_get(x_3, 1); lean_inc(x_4); -x_5 = lean_ctor_get(x_1, 0); +x_5 = lean_ctor_get(x_4, 1); lean_inc(x_5); -lean_dec(x_1); -x_6 = lean_ctor_get(x_3, 0); +x_6 = lean_ctor_get(x_1, 0); lean_inc(x_6); -lean_dec(x_3); -x_7 = lean_ctor_get(x_4, 0); +lean_dec(x_1); +x_7 = lean_ctor_get(x_3, 0); lean_inc(x_7); -x_8 = lean_ctor_get(x_4, 1); +lean_dec(x_3); +x_8 = lean_ctor_get(x_4, 0); lean_inc(x_8); lean_dec(x_4); -x_9 = lean_apply_4(x_2, x_5, x_6, x_7, x_8); -return x_9; +x_9 = lean_ctor_get(x_5, 0); +lean_inc(x_9); +x_10 = lean_ctor_get(x_5, 1); +lean_inc(x_10); +lean_dec(x_5); +x_11 = lean_apply_5(x_2, x_6, x_7, x_8, x_9, x_10); +return x_11; } } lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux_match__3(lean_object* x_1) { @@ -25923,528 +26068,494 @@ return x_2; lean_object* l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___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) { _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_object* x_16; 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; lean_object* x_111; -x_9 = lean_ctor_get(x_1, 1); +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_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; lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_9 = lean_ctor_get(x_1, 0); lean_inc(x_9); -x_10 = lean_ctor_get(x_1, 0); +x_10 = lean_ctor_get(x_1, 1); lean_inc(x_10); -if (lean_is_exclusive(x_1)) { - lean_ctor_release(x_1, 0); - lean_ctor_release(x_1, 1); - x_11 = x_1; -} else { - lean_dec_ref(x_1); - x_11 = lean_box(0); -} -x_12 = lean_ctor_get(x_9, 0); +x_11 = lean_ctor_get_uint8(x_1, sizeof(void*)*3); +x_12 = lean_ctor_get(x_1, 2); lean_inc(x_12); -x_13 = lean_ctor_get(x_9, 1); -lean_inc(x_13); -if (lean_is_exclusive(x_9)) { - lean_ctor_release(x_9, 0); - lean_ctor_release(x_9, 1); - x_14 = x_9; -} else { - lean_dec_ref(x_9); - x_14 = lean_box(0); -} -x_93 = lean_st_ref_get(x_7, x_8); -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 = lean_ctor_get(x_94, 0); +lean_dec(x_1); +x_95 = lean_st_ref_get(x_7, x_8); +x_96 = lean_ctor_get(x_95, 0); lean_inc(x_96); -lean_dec(x_94); -x_97 = lean_ctor_get(x_6, 3); +x_97 = lean_ctor_get(x_95, 1); lean_inc(x_97); -x_98 = l_Lean_Elab_Term_getCurrMacroScope(x_2, x_3, x_4, x_5, x_6, x_7, x_95); -x_99 = lean_ctor_get(x_98, 0); +lean_dec(x_95); +x_98 = lean_ctor_get(x_96, 0); +lean_inc(x_98); +lean_dec(x_96); +x_99 = lean_ctor_get(x_6, 3); lean_inc(x_99); -x_100 = lean_ctor_get(x_98, 1); -lean_inc(x_100); -lean_dec(x_98); -x_101 = lean_ctor_get(x_6, 1); +x_100 = l_Lean_Elab_Term_getCurrMacroScope(x_2, x_3, x_4, x_5, x_6, x_7, x_97); +x_101 = lean_ctor_get(x_100, 0); lean_inc(x_101); -x_102 = lean_ctor_get(x_6, 2); +x_102 = lean_ctor_get(x_100, 1); lean_inc(x_102); -x_103 = lean_st_ref_get(x_7, x_100); -x_104 = lean_ctor_get(x_103, 0); +lean_dec(x_100); +x_103 = lean_ctor_get(x_6, 1); +lean_inc(x_103); +x_104 = lean_ctor_get(x_6, 2); lean_inc(x_104); -x_105 = lean_ctor_get(x_103, 1); -lean_inc(x_105); -lean_dec(x_103); -x_106 = lean_ctor_get(x_104, 1); +x_105 = lean_st_ref_get(x_7, x_102); +x_106 = lean_ctor_get(x_105, 0); lean_inc(x_106); -lean_dec(x_104); -lean_inc(x_96); -x_107 = lean_alloc_closure((void*)(l___private_Lean_Elab_Util_0__Lean_Elab_expandMacro_x3f___boxed), 4, 1); -lean_closure_set(x_107, 0, x_96); -x_108 = x_107; -x_109 = lean_environment_main_module(x_96); -x_110 = lean_alloc_ctor(0, 6, 0); -lean_ctor_set(x_110, 0, x_108); -lean_ctor_set(x_110, 1, x_109); -lean_ctor_set(x_110, 2, x_99); -lean_ctor_set(x_110, 3, x_101); -lean_ctor_set(x_110, 4, x_102); -lean_ctor_set(x_110, 5, x_97); -x_111 = l_Lean_Elab_Term_expandMacrosInPatterns(x_13, x_110, x_106); -if (lean_obj_tag(x_111) == 0) +x_107 = lean_ctor_get(x_105, 1); +lean_inc(x_107); +lean_dec(x_105); +x_108 = lean_ctor_get(x_106, 1); +lean_inc(x_108); +lean_dec(x_106); +lean_inc(x_98); +x_109 = lean_alloc_closure((void*)(l___private_Lean_Elab_Util_0__Lean_Elab_expandMacro_x3f___boxed), 4, 1); +lean_closure_set(x_109, 0, x_98); +x_110 = x_109; +x_111 = lean_environment_main_module(x_98); +x_112 = lean_alloc_ctor(0, 6, 0); +lean_ctor_set(x_112, 0, x_110); +lean_ctor_set(x_112, 1, x_111); +lean_ctor_set(x_112, 2, x_101); +lean_ctor_set(x_112, 3, x_103); +lean_ctor_set(x_112, 4, x_104); +lean_ctor_set(x_112, 5, x_99); +x_113 = l_Lean_Elab_Term_expandMacrosInPatterns(x_12, x_112, x_108); +if (lean_obj_tag(x_113) == 0) { -lean_object* x_112; lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; uint8_t x_117; -x_112 = lean_ctor_get(x_111, 0); -lean_inc(x_112); -x_113 = lean_ctor_get(x_111, 1); -lean_inc(x_113); -lean_dec(x_111); -x_114 = lean_st_ref_take(x_7, x_105); -x_115 = lean_ctor_get(x_114, 0); +lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; lean_object* x_118; uint8_t x_119; +x_114 = lean_ctor_get(x_113, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_113, 1); lean_inc(x_115); -x_116 = lean_ctor_get(x_114, 1); -lean_inc(x_116); -lean_dec(x_114); -x_117 = !lean_is_exclusive(x_115); -if (x_117 == 0) +lean_dec(x_113); +x_116 = lean_st_ref_take(x_7, x_107); +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); +x_119 = !lean_is_exclusive(x_117); +if (x_119 == 0) { -lean_object* x_118; lean_object* x_119; lean_object* x_120; -x_118 = lean_ctor_get(x_115, 1); -lean_dec(x_118); -lean_ctor_set(x_115, 1, x_113); -x_119 = lean_st_ref_set(x_7, x_115, x_116); -x_120 = lean_ctor_get(x_119, 1); -lean_inc(x_120); -lean_dec(x_119); -x_15 = x_112; -x_16 = x_120; -goto block_92; -} -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; -x_121 = lean_ctor_get(x_115, 0); -x_122 = lean_ctor_get(x_115, 2); -x_123 = lean_ctor_get(x_115, 3); -lean_inc(x_123); +lean_object* x_120; lean_object* x_121; lean_object* x_122; +x_120 = lean_ctor_get(x_117, 1); +lean_dec(x_120); +lean_ctor_set(x_117, 1, x_115); +x_121 = lean_st_ref_set(x_7, x_117, x_118); +x_122 = lean_ctor_get(x_121, 1); lean_inc(x_122); -lean_inc(x_121); -lean_dec(x_115); -x_124 = lean_alloc_ctor(0, 4, 0); -lean_ctor_set(x_124, 0, x_121); -lean_ctor_set(x_124, 1, x_113); -lean_ctor_set(x_124, 2, x_122); -lean_ctor_set(x_124, 3, x_123); -x_125 = lean_st_ref_set(x_7, x_124, x_116); -x_126 = lean_ctor_get(x_125, 1); -lean_inc(x_126); -lean_dec(x_125); -x_15 = x_112; -x_16 = x_126; -goto block_92; +lean_dec(x_121); +x_13 = x_114; +x_14 = x_122; +goto block_94; +} +else +{ +lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; lean_object* x_127; lean_object* x_128; +x_123 = lean_ctor_get(x_117, 0); +x_124 = lean_ctor_get(x_117, 2); +x_125 = lean_ctor_get(x_117, 3); +lean_inc(x_125); +lean_inc(x_124); +lean_inc(x_123); +lean_dec(x_117); +x_126 = lean_alloc_ctor(0, 4, 0); +lean_ctor_set(x_126, 0, x_123); +lean_ctor_set(x_126, 1, x_115); +lean_ctor_set(x_126, 2, x_124); +lean_ctor_set(x_126, 3, x_125); +x_127 = lean_st_ref_set(x_7, x_126, x_118); +x_128 = lean_ctor_get(x_127, 1); +lean_inc(x_128); +lean_dec(x_127); +x_13 = x_114; +x_14 = x_128; +goto block_94; } } else { -lean_object* x_127; -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_11); +lean_object* x_129; lean_dec(x_10); -x_127 = lean_ctor_get(x_111, 0); -lean_inc(x_127); -lean_dec(x_111); -if (lean_obj_tag(x_127) == 0) -{ -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_128 = lean_ctor_get(x_127, 0); -lean_inc(x_128); -x_129 = lean_ctor_get(x_127, 1); +lean_dec(x_9); +x_129 = lean_ctor_get(x_113, 0); lean_inc(x_129); -lean_dec(x_127); -x_130 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_130, 0, x_129); -x_131 = lean_alloc_ctor(0, 1, 0); -lean_ctor_set(x_131, 0, x_130); -x_132 = l_Lean_throwErrorAt___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__7(x_128, x_131, x_2, x_3, x_4, x_5, x_6, x_7, x_105); +lean_dec(x_113); +if (lean_obj_tag(x_129) == 0) +{ +lean_object* x_130; lean_object* x_131; lean_object* x_132; lean_object* x_133; lean_object* x_134; uint8_t x_135; +x_130 = lean_ctor_get(x_129, 0); +lean_inc(x_130); +x_131 = lean_ctor_get(x_129, 1); +lean_inc(x_131); +lean_dec(x_129); +x_132 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_132, 0, x_131); +x_133 = lean_alloc_ctor(0, 1, 0); +lean_ctor_set(x_133, 0, x_132); +x_134 = l_Lean_throwErrorAt___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__7(x_130, x_133, x_2, x_3, x_4, x_5, x_6, x_7, x_107); lean_dec(x_7); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); -lean_dec(x_128); -x_133 = !lean_is_exclusive(x_132); -if (x_133 == 0) +lean_dec(x_130); +x_135 = !lean_is_exclusive(x_134); +if (x_135 == 0) { -return x_132; +return x_134; } else { -lean_object* x_134; lean_object* x_135; lean_object* x_136; -x_134 = lean_ctor_get(x_132, 0); -x_135 = lean_ctor_get(x_132, 1); -lean_inc(x_135); -lean_inc(x_134); -lean_dec(x_132); -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; +lean_object* x_136; lean_object* x_137; lean_object* x_138; +x_136 = lean_ctor_get(x_134, 0); +x_137 = lean_ctor_get(x_134, 1); +lean_inc(x_137); +lean_inc(x_136); +lean_dec(x_134); +x_138 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_138, 0, x_136); +lean_ctor_set(x_138, 1, x_137); +return x_138; } } else { -lean_object* x_137; uint8_t x_138; +lean_object* x_139; uint8_t x_140; lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_137 = l_Lean_Elab_throwUnsupportedSyntax___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__9___rarg(x_105); -x_138 = !lean_is_exclusive(x_137); -if (x_138 == 0) +x_139 = l_Lean_Elab_throwUnsupportedSyntax___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__9___rarg(x_107); +x_140 = !lean_is_exclusive(x_139); +if (x_140 == 0) { -return x_137; +return x_139; } else { -lean_object* x_139; lean_object* x_140; lean_object* x_141; -x_139 = lean_ctor_get(x_137, 0); -x_140 = lean_ctor_get(x_137, 1); -lean_inc(x_140); -lean_inc(x_139); -lean_dec(x_137); -x_141 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_141, 0, x_139); -lean_ctor_set(x_141, 1, x_140); -return x_141; +lean_object* x_141; lean_object* x_142; lean_object* x_143; +x_141 = lean_ctor_get(x_139, 0); +x_142 = lean_ctor_get(x_139, 1); +lean_inc(x_142); +lean_inc(x_141); +lean_dec(x_139); +x_143 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_143, 0, x_141); +lean_ctor_set(x_143, 1, x_142); +return x_143; } } } -block_92: +block_94: { -lean_object* x_17; uint8_t x_69; lean_object* x_70; lean_object* x_80; lean_object* x_81; lean_object* x_82; uint8_t x_83; -x_80 = lean_st_ref_get(x_7, x_16); -x_81 = lean_ctor_get(x_80, 0); -lean_inc(x_81); -x_82 = lean_ctor_get(x_81, 3); -lean_inc(x_82); -lean_dec(x_81); -x_83 = lean_ctor_get_uint8(x_82, sizeof(void*)*1); -lean_dec(x_82); -if (x_83 == 0) -{ -lean_object* x_84; uint8_t x_85; -x_84 = lean_ctor_get(x_80, 1); +lean_object* x_15; uint8_t x_71; lean_object* x_72; lean_object* x_82; lean_object* x_83; lean_object* x_84; uint8_t x_85; +x_82 = lean_st_ref_get(x_7, x_14); +x_83 = lean_ctor_get(x_82, 0); +lean_inc(x_83); +x_84 = lean_ctor_get(x_83, 3); lean_inc(x_84); -lean_dec(x_80); -x_85 = 0; -x_69 = x_85; -x_70 = x_84; -goto block_79; +lean_dec(x_83); +x_85 = lean_ctor_get_uint8(x_84, sizeof(void*)*1); +lean_dec(x_84); +if (x_85 == 0) +{ +lean_object* x_86; uint8_t x_87; +x_86 = lean_ctor_get(x_82, 1); +lean_inc(x_86); +lean_dec(x_82); +x_87 = 0; +x_71 = x_87; +x_72 = x_86; +goto block_81; } else { -lean_object* x_86; lean_object* x_87; lean_object* x_88; lean_object* x_89; lean_object* x_90; uint8_t x_91; -x_86 = lean_ctor_get(x_80, 1); -lean_inc(x_86); -lean_dec(x_80); -x_87 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_88 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_87, x_2, x_3, x_4, x_5, x_6, x_7, x_86); -x_89 = lean_ctor_get(x_88, 0); -lean_inc(x_89); -x_90 = lean_ctor_get(x_88, 1); -lean_inc(x_90); -lean_dec(x_88); -x_91 = lean_unbox(x_89); -lean_dec(x_89); -x_69 = x_91; -x_70 = x_90; -goto block_79; +lean_object* x_88; lean_object* x_89; lean_object* x_90; lean_object* x_91; lean_object* x_92; uint8_t x_93; +x_88 = lean_ctor_get(x_82, 1); +lean_inc(x_88); +lean_dec(x_82); +x_89 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_90 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_89, x_2, x_3, x_4, x_5, x_6, x_7, x_88); +x_91 = lean_ctor_get(x_90, 0); +lean_inc(x_91); +x_92 = lean_ctor_get(x_90, 1); +lean_inc(x_92); +lean_dec(x_90); +x_93 = lean_unbox(x_91); +lean_dec(x_91); +x_71 = x_93; +x_72 = x_92; +goto block_81; } -block_68: +block_70: { -lean_object* x_18; size_t x_19; size_t 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; -x_18 = lean_array_get_size(x_15); -x_19 = lean_usize_of_nat(x_18); -lean_dec(x_18); -x_20 = 0; -x_21 = x_15; -x_22 = lean_box_usize(x_19); -x_23 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___lambda__1___boxed__const__1; -lean_inc(x_12); -x_24 = lean_alloc_closure((void*)(l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__1___boxed), 11, 4); -lean_closure_set(x_24, 0, x_12); -lean_closure_set(x_24, 1, x_22); -lean_closure_set(x_24, 2, x_23); -lean_closure_set(x_24, 3, x_21); -x_25 = x_24; +lean_object* x_16; size_t x_17; size_t 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; +x_16 = lean_array_get_size(x_13); +x_17 = lean_usize_of_nat(x_16); +lean_dec(x_16); +x_18 = 0; +x_19 = x_13; +x_20 = lean_box_usize(x_17); +x_21 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___lambda__1___boxed__const__1; +lean_inc(x_10); +x_22 = lean_alloc_closure((void*)(l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__1___boxed), 11, 4); +lean_closure_set(x_22, 0, x_10); +lean_closure_set(x_22, 1, x_20); +lean_closure_set(x_22, 2, x_21); +lean_closure_set(x_22, 3, x_19); +x_23 = x_22; lean_inc(x_7); lean_inc(x_6); lean_inc(x_5); lean_inc(x_4); lean_inc(x_3); lean_inc(x_2); -x_26 = lean_apply_7(x_25, x_2, x_3, x_4, x_5, x_6, x_7, x_17); -if (lean_obj_tag(x_26) == 0) +x_24 = lean_apply_7(x_23, x_2, x_3, x_4, x_5, x_6, x_7, x_15); +if (lean_obj_tag(x_24) == 0) { -lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_27 = lean_ctor_get(x_26, 0); -lean_inc(x_27); -x_28 = lean_ctor_get(x_26, 1); +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_7); +lean_inc(x_6); +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_3); +lean_inc(x_2); +x_27 = l_Lean_Elab_Term_synthesizeSyntheticMVarsUsingDefault(x_2, x_3, x_4, x_5, x_6, x_7, x_26); +if (lean_obj_tag(x_27) == 0) +{ +lean_object* x_28; lean_object* x_29; size_t x_30; lean_object* x_31; lean_object* x_32; lean_object* x_33; lean_object* x_34; +x_28 = lean_ctor_get(x_27, 1); lean_inc(x_28); -lean_dec(x_26); -lean_inc(x_7); -lean_inc(x_6); -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_3); -lean_inc(x_2); -x_29 = l_Lean_Elab_Term_synthesizeSyntheticMVarsUsingDefault(x_2, x_3, x_4, x_5, x_6, x_7, x_28); -if (lean_obj_tag(x_29) == 0) -{ -lean_object* x_30; lean_object* x_31; size_t x_32; lean_object* x_33; lean_object* x_34; lean_object* x_35; lean_object* x_36; -x_30 = lean_ctor_get(x_29, 1); -lean_inc(x_30); +lean_dec(x_27); +x_29 = lean_array_get_size(x_25); +x_30 = lean_usize_of_nat(x_29); lean_dec(x_29); -x_31 = lean_array_get_size(x_27); -x_32 = lean_usize_of_nat(x_31); -lean_dec(x_31); -lean_inc(x_27); -x_33 = x_27; -x_34 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__2(x_32, x_20, x_33); -x_35 = x_34; +lean_inc(x_25); +x_31 = x_25; +x_32 = l_Array_mapMUnsafe_map___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__2(x_30, x_18, x_31); +x_33 = x_32; lean_inc(x_7); lean_inc(x_6); lean_inc(x_5); lean_inc(x_4); -x_36 = l_Lean_Meta_instantiateMVars(x_12, x_4, x_5, x_6, x_7, x_30); -if (lean_obj_tag(x_36) == 0) +x_34 = l_Lean_Meta_instantiateMVars(x_10, x_4, x_5, x_6, x_7, x_28); +if (lean_obj_tag(x_34) == 0) { -lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; -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_array_to_list(lean_box(0), x_27); -x_40 = l_List_mapM___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__6(x_39, x_2, x_3, x_4, x_5, x_6, x_7, x_38); -if (lean_obj_tag(x_40) == 0) +lean_object* x_35; lean_object* x_36; lean_object* x_37; lean_object* x_38; +x_35 = lean_ctor_get(x_34, 0); +lean_inc(x_35); +x_36 = lean_ctor_get(x_34, 1); +lean_inc(x_36); +lean_dec(x_34); +x_37 = lean_array_to_list(lean_box(0), x_25); +x_38 = l_List_mapM___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___spec__6(x_37, x_2, x_3, x_4, x_5, x_6, x_7, x_36); +if (lean_obj_tag(x_38) == 0) { -uint8_t x_41; -x_41 = !lean_is_exclusive(x_40); -if (x_41 == 0) +uint8_t x_39; +x_39 = !lean_is_exclusive(x_38); +if (x_39 == 0) { -lean_object* x_42; lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_42 = lean_ctor_get(x_40, 0); -if (lean_is_scalar(x_14)) { - x_43 = lean_alloc_ctor(0, 2, 0); -} else { - x_43 = x_14; -} -lean_ctor_set(x_43, 0, x_42); -lean_ctor_set(x_43, 1, x_35); -if (lean_is_scalar(x_11)) { - x_44 = lean_alloc_ctor(0, 2, 0); -} else { - x_44 = x_11; -} -lean_ctor_set(x_44, 0, x_37); +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_38, 0); +x_41 = lean_box(x_11); +x_42 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_42, 0, x_41); +lean_ctor_set(x_42, 1, x_33); +x_43 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_43, 0, x_40); +lean_ctor_set(x_43, 1, x_42); +x_44 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_44, 0, x_35); lean_ctor_set(x_44, 1, x_43); x_45 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_45, 0, x_10); +lean_ctor_set(x_45, 0, x_9); lean_ctor_set(x_45, 1, x_44); -lean_ctor_set(x_40, 0, x_45); -return x_40; +lean_ctor_set(x_38, 0, x_45); +return x_38; } 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; -x_46 = lean_ctor_get(x_40, 0); -x_47 = lean_ctor_get(x_40, 1); +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_46 = lean_ctor_get(x_38, 0); +x_47 = lean_ctor_get(x_38, 1); lean_inc(x_47); lean_inc(x_46); -lean_dec(x_40); -if (lean_is_scalar(x_14)) { - x_48 = lean_alloc_ctor(0, 2, 0); -} else { - x_48 = x_14; -} -lean_ctor_set(x_48, 0, x_46); -lean_ctor_set(x_48, 1, x_35); -if (lean_is_scalar(x_11)) { - x_49 = lean_alloc_ctor(0, 2, 0); -} else { - x_49 = x_11; -} -lean_ctor_set(x_49, 0, x_37); -lean_ctor_set(x_49, 1, x_48); +lean_dec(x_38); +x_48 = lean_box(x_11); +x_49 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_49, 0, x_48); +lean_ctor_set(x_49, 1, x_33); x_50 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_50, 0, x_10); +lean_ctor_set(x_50, 0, x_46); 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_47); -return x_51; +lean_ctor_set(x_51, 0, x_35); +lean_ctor_set(x_51, 1, x_50); +x_52 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_52, 0, x_9); +lean_ctor_set(x_52, 1, 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_47); +return x_53; } } else { -uint8_t x_52; -lean_dec(x_37); +uint8_t x_54; lean_dec(x_35); -lean_dec(x_14); -lean_dec(x_11); +lean_dec(x_33); +lean_dec(x_9); +x_54 = !lean_is_exclusive(x_38); +if (x_54 == 0) +{ +return x_38; +} +else +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; +x_55 = lean_ctor_get(x_38, 0); +x_56 = lean_ctor_get(x_38, 1); +lean_inc(x_56); +lean_inc(x_55); +lean_dec(x_38); +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_33); +lean_dec(x_25); +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_58 = !lean_is_exclusive(x_34); +if (x_58 == 0) +{ +return x_34; +} +else +{ +lean_object* x_59; lean_object* x_60; lean_object* x_61; +x_59 = lean_ctor_get(x_34, 0); +x_60 = lean_ctor_get(x_34, 1); +lean_inc(x_60); +lean_inc(x_59); +lean_dec(x_34); +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 +{ +uint8_t x_62; +lean_dec(x_25); lean_dec(x_10); -x_52 = !lean_is_exclusive(x_40); -if (x_52 == 0) +lean_dec(x_9); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_3); +lean_dec(x_2); +x_62 = !lean_is_exclusive(x_27); +if (x_62 == 0) { -return x_40; +return x_27; } 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 -{ -uint8_t x_56; -lean_dec(x_35); +lean_object* x_63; lean_object* x_64; lean_object* x_65; +x_63 = lean_ctor_get(x_27, 0); +x_64 = lean_ctor_get(x_27, 1); +lean_inc(x_64); +lean_inc(x_63); lean_dec(x_27); -lean_dec(x_14); -lean_dec(x_11); +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 +{ +uint8_t x_66; lean_dec(x_10); +lean_dec(x_9); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_2); -x_56 = !lean_is_exclusive(x_36); -if (x_56 == 0) +x_66 = !lean_is_exclusive(x_24); +if (x_66 == 0) { -return x_36; +return x_24; } else { -lean_object* x_57; lean_object* x_58; lean_object* x_59; -x_57 = lean_ctor_get(x_36, 0); -x_58 = lean_ctor_get(x_36, 1); -lean_inc(x_58); -lean_inc(x_57); -lean_dec(x_36); -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; +lean_object* x_67; lean_object* x_68; lean_object* x_69; +x_67 = lean_ctor_get(x_24, 0); +x_68 = lean_ctor_get(x_24, 1); +lean_inc(x_68); +lean_inc(x_67); +lean_dec(x_24); +x_69 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_69, 0, x_67); +lean_ctor_set(x_69, 1, x_68); +return x_69; } } } +block_81: +{ +if (x_71 == 0) +{ +x_15 = x_72; +goto block_70; +} else { -uint8_t x_60; -lean_dec(x_27); -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -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 -{ -uint8_t x_64; -lean_dec(x_14); -lean_dec(x_12); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_3); -lean_dec(x_2); -x_64 = !lean_is_exclusive(x_26); -if (x_64 == 0) -{ -return x_26; -} -else -{ -lean_object* x_65; lean_object* x_66; lean_object* x_67; -x_65 = lean_ctor_get(x_26, 0); -x_66 = lean_ctor_get(x_26, 1); -lean_inc(x_66); -lean_inc(x_65); -lean_dec(x_26); -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; -} -} -} -block_79: -{ -if (x_69 == 0) -{ -x_17 = x_70; -goto block_68; -} -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_inc(x_12); -x_71 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_71, 0, x_12); -x_72 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___lambda__1___closed__2; -x_73 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_73, 0, x_72); -lean_ctor_set(x_73, 1, x_71); -x_74 = l_Lean_KernelException_toMessageData___closed__15; +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_inc(x_10); +x_73 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_73, 0, x_10); +x_74 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___lambda__1___closed__2; x_75 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_75, 0, x_73); -lean_ctor_set(x_75, 1, x_74); -x_76 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_77 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_76, x_75, x_2, x_3, x_4, x_5, x_6, x_7, x_70); -x_78 = lean_ctor_get(x_77, 1); -lean_inc(x_78); -lean_dec(x_77); -x_17 = x_78; -goto block_68; +lean_ctor_set(x_75, 0, x_74); +lean_ctor_set(x_75, 1, x_73); +x_76 = l_Lean_KernelException_toMessageData___closed__15; +x_77 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_77, 0, x_75); +lean_ctor_set(x_77, 1, x_76); +x_78 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_79 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_78, x_77, x_2, x_3, x_4, x_5, x_6, x_7, x_72); +x_80 = lean_ctor_get(x_79, 1); +lean_inc(x_80); +lean_dec(x_79); +x_15 = x_80; +goto block_70; } } } @@ -26515,457 +26626,800 @@ lean_inc(x_5); x_15 = l_Lean_Elab_Term_commitIfDidNotPostpone___rarg(x_14, x_5, x_6, x_7, x_8, x_9, x_10, x_11); 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; lean_object* x_22; lean_object* x_23; lean_object* x_24; +lean_object* x_16; lean_object* x_17; lean_object* x_18; lean_object* x_19; lean_object* x_20; uint8_t x_21; x_16 = lean_ctor_get(x_15, 0); lean_inc(x_16); x_17 = lean_ctor_get(x_16, 1); lean_inc(x_17); x_18 = lean_ctor_get(x_17, 1); lean_inc(x_18); -x_19 = lean_ctor_get(x_15, 1); +x_19 = lean_ctor_get(x_18, 1); lean_inc(x_19); -lean_dec(x_15); -x_20 = lean_ctor_get(x_16, 0); +x_20 = lean_ctor_get(x_19, 0); lean_inc(x_20); -lean_dec(x_16); -x_21 = lean_ctor_get(x_17, 0); -lean_inc(x_21); -lean_dec(x_17); -x_22 = lean_ctor_get(x_18, 0); +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; lean_object* x_27; +x_22 = lean_ctor_get(x_15, 1); lean_inc(x_22); -x_23 = lean_ctor_get(x_18, 1); +lean_dec(x_15); +x_23 = lean_ctor_get(x_16, 0); lean_inc(x_23); -lean_dec(x_18); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_7); -x_24 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_isMatchUnit_x3f(x_22, x_23, x_7, x_8, x_9, x_10, x_19); -if (lean_obj_tag(x_24) == 0) -{ -lean_object* x_25; -x_25 = lean_ctor_get(x_24, 0); +lean_dec(x_16); +x_24 = lean_ctor_get(x_17, 0); +lean_inc(x_24); +lean_dec(x_17); +x_25 = lean_ctor_get(x_18, 0); lean_inc(x_25); -if (lean_obj_tag(x_25) == 0) -{ -lean_object* x_26; lean_object* x_27; lean_object* x_28; lean_object* x_29; -x_26 = lean_ctor_get(x_24, 1); +lean_dec(x_18); +x_26 = lean_ctor_get(x_19, 1); lean_inc(x_26); -lean_dec(x_24); -x_27 = lean_array_get_size(x_20); -x_28 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1; -lean_inc(x_5); -x_29 = l_Lean_Elab_Term_mkAuxName(x_28, x_5, x_6, x_7, x_8, x_9, x_10, x_26); -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_dec(x_19); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_7); -lean_inc(x_22); -lean_inc(x_27); -lean_inc(x_21); -x_32 = l_Lean_Meta_Match_mkMatcher(x_30, x_21, x_27, x_22, x_7, x_8, x_9, x_10, x_31); +x_27 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_isMatchUnit_x3f(x_25, x_26, x_7, x_8, x_9, x_10, x_22); +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) +{ +lean_object* x_29; lean_object* x_30; lean_object* x_31; lean_object* x_32; +x_29 = lean_ctor_get(x_27, 1); +lean_inc(x_29); +lean_dec(x_27); +x_30 = lean_array_get_size(x_23); +x_31 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1; +lean_inc(x_5); +x_32 = l_Lean_Elab_Term_mkAuxName(x_31, x_5, x_6, x_7, x_8, x_9, x_10, x_29); if (lean_obj_tag(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_33; lean_object* x_34; lean_object* x_35; 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 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_35, 0, x_27); -x_36 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___closed__2; lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_7); -lean_inc(x_6); -lean_inc(x_5); -x_37 = l_Lean_Meta_forallBoundedTelescope___at_Lean_Elab_Term_elabLetDeclAux___spec__1___rarg(x_21, x_35, x_36, x_5, x_6, x_7, x_8, x_9, x_10, x_34); -if (lean_obj_tag(x_37) == 0) +lean_inc(x_25); +lean_inc(x_30); +lean_inc(x_24); +x_35 = l_Lean_Meta_Match_mkMatcher(x_33, x_24, x_30, x_25, x_7, x_8, x_9, x_10, x_34); +if (lean_obj_tag(x_35) == 0) { -lean_object* x_38; lean_object* x_39; lean_object* x_40; -x_38 = lean_ctor_get(x_37, 0); -lean_inc(x_38); -x_39 = lean_ctor_get(x_37, 1); -lean_inc(x_39); -lean_dec(x_37); +lean_object* x_36; lean_object* x_37; lean_object* x_38; lean_object* x_39; lean_object* x_40; +x_36 = lean_ctor_get(x_35, 0); +lean_inc(x_36); +x_37 = lean_ctor_get(x_35, 1); +lean_inc(x_37); +lean_dec(x_35); +x_38 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_38, 0, x_30); +x_39 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___closed__2; lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_7); lean_inc(x_6); lean_inc(x_5); -lean_inc(x_33); -x_40 = l_Lean_Elab_Term_reportMatcherResultErrors(x_22, x_33, x_5, x_6, x_7, x_8, x_9, x_10, x_39); -lean_dec(x_22); +x_40 = l_Lean_Meta_forallBoundedTelescope___at_Lean_Elab_Term_elabLetDeclAux___spec__1___rarg(x_24, x_38, x_39, x_5, x_6, x_7, x_8, x_9, x_10, x_37); if (lean_obj_tag(x_40) == 0) { -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_62; lean_object* x_63; lean_object* x_64; uint8_t x_65; -x_41 = lean_ctor_get(x_40, 1); +lean_object* x_41; lean_object* x_42; lean_object* x_43; +x_41 = lean_ctor_get(x_40, 0); lean_inc(x_41); -if (lean_is_exclusive(x_40)) { - lean_ctor_release(x_40, 0); - lean_ctor_release(x_40, 1); - x_42 = x_40; +x_42 = lean_ctor_get(x_40, 1); +lean_inc(x_42); +lean_dec(x_40); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_7); +lean_inc(x_6); +lean_inc(x_5); +lean_inc(x_36); +x_43 = l_Lean_Elab_Term_reportMatcherResultErrors(x_25, x_36, x_5, x_6, x_7, x_8, x_9, x_10, x_42); +lean_dec(x_25); +if (lean_obj_tag(x_43) == 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; uint8_t x_50; lean_object* x_51; lean_object* x_65; lean_object* x_66; lean_object* x_67; uint8_t x_68; +x_44 = lean_ctor_get(x_43, 1); +lean_inc(x_44); +if (lean_is_exclusive(x_43)) { + lean_ctor_release(x_43, 0); + lean_ctor_release(x_43, 1); + x_45 = x_43; } else { - lean_dec_ref(x_40); - x_42 = lean_box(0); + lean_dec_ref(x_43); + x_45 = lean_box(0); } -x_43 = lean_ctor_get(x_33, 0); -lean_inc(x_43); -lean_dec(x_33); -x_44 = l_Lean_mkApp(x_43, x_38); -x_45 = l_Lean_mkAppN(x_44, x_20); -lean_dec(x_20); -x_46 = l_Lean_mkAppN(x_45, x_23); -lean_dec(x_23); -x_62 = lean_st_ref_get(x_10, x_41); -x_63 = lean_ctor_get(x_62, 0); -lean_inc(x_63); -x_64 = lean_ctor_get(x_63, 3); -lean_inc(x_64); -lean_dec(x_63); -x_65 = lean_ctor_get_uint8(x_64, sizeof(void*)*1); -lean_dec(x_64); -if (x_65 == 0) -{ -lean_object* x_66; uint8_t x_67; -x_66 = lean_ctor_get(x_62, 1); -lean_inc(x_66); -lean_dec(x_62); -x_67 = 0; -x_47 = x_67; -x_48 = x_66; -goto block_61; -} -else -{ -lean_object* x_68; lean_object* x_69; lean_object* x_70; lean_object* x_71; lean_object* x_72; uint8_t x_73; -x_68 = lean_ctor_get(x_62, 1); -lean_inc(x_68); -lean_dec(x_62); -x_69 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_70 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_69, x_5, x_6, x_7, x_8, x_9, x_10, x_68); -x_71 = lean_ctor_get(x_70, 0); -lean_inc(x_71); -x_72 = lean_ctor_get(x_70, 1); -lean_inc(x_72); -lean_dec(x_70); -x_73 = lean_unbox(x_71); -lean_dec(x_71); -x_47 = x_73; -x_48 = x_72; -goto block_61; -} -block_61: -{ -if (x_47 == 0) -{ -lean_object* x_49; -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -if (lean_is_scalar(x_42)) { - x_49 = lean_alloc_ctor(0, 2, 0); -} else { - x_49 = x_42; -} -lean_ctor_set(x_49, 0, x_46); -lean_ctor_set(x_49, 1, x_48); -return x_49; -} -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; uint8_t x_57; -lean_dec(x_42); +x_46 = lean_ctor_get(x_36, 0); lean_inc(x_46); -x_50 = lean_alloc_ctor(2, 1, 0); -lean_ctor_set(x_50, 0, x_46); -x_51 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___closed__4; -x_52 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_52, 0, x_51); -lean_ctor_set(x_52, 1, x_50); -x_53 = l_Lean_KernelException_toMessageData___closed__15; -x_54 = lean_alloc_ctor(10, 2, 0); -lean_ctor_set(x_54, 0, x_52); -lean_ctor_set(x_54, 1, x_53); -x_55 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; -x_56 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_55, x_54, x_5, x_6, x_7, x_8, x_9, x_10, x_48); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_57 = !lean_is_exclusive(x_56); -if (x_57 == 0) -{ -lean_object* x_58; -x_58 = lean_ctor_get(x_56, 0); -lean_dec(x_58); -lean_ctor_set(x_56, 0, x_46); -return x_56; -} -else -{ -lean_object* x_59; lean_object* x_60; -x_59 = lean_ctor_get(x_56, 1); -lean_inc(x_59); -lean_dec(x_56); -x_60 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_60, 0, x_46); -lean_ctor_set(x_60, 1, x_59); -return x_60; -} -} -} -} -else -{ -uint8_t x_74; -lean_dec(x_38); -lean_dec(x_33); +lean_dec(x_36); +x_47 = l_Lean_mkApp(x_46, x_41); +x_48 = l_Lean_mkAppN(x_47, x_23); lean_dec(x_23); -lean_dec(x_20); +x_49 = l_Lean_mkAppN(x_48, x_26); +lean_dec(x_26); +x_65 = lean_st_ref_get(x_10, x_44); +x_66 = lean_ctor_get(x_65, 0); +lean_inc(x_66); +x_67 = lean_ctor_get(x_66, 3); +lean_inc(x_67); +lean_dec(x_66); +x_68 = lean_ctor_get_uint8(x_67, sizeof(void*)*1); +lean_dec(x_67); +if (x_68 == 0) +{ +lean_object* x_69; uint8_t x_70; +x_69 = lean_ctor_get(x_65, 1); +lean_inc(x_69); +lean_dec(x_65); +x_70 = 0; +x_50 = x_70; +x_51 = x_69; +goto block_64; +} +else +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; lean_object* x_75; uint8_t x_76; +x_71 = lean_ctor_get(x_65, 1); +lean_inc(x_71); +lean_dec(x_65); +x_72 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_73 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_72, x_5, x_6, x_7, x_8, x_9, x_10, x_71); +x_74 = lean_ctor_get(x_73, 0); +lean_inc(x_74); +x_75 = lean_ctor_get(x_73, 1); +lean_inc(x_75); +lean_dec(x_73); +x_76 = lean_unbox(x_74); +lean_dec(x_74); +x_50 = x_76; +x_51 = x_75; +goto block_64; +} +block_64: +{ +if (x_50 == 0) +{ +lean_object* x_52; lean_dec(x_10); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_74 = !lean_is_exclusive(x_40); -if (x_74 == 0) +if (lean_is_scalar(x_45)) { + x_52 = lean_alloc_ctor(0, 2, 0); +} else { + x_52 = x_45; +} +lean_ctor_set(x_52, 0, x_49); +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; lean_object* x_57; lean_object* x_58; lean_object* x_59; uint8_t x_60; +lean_dec(x_45); +lean_inc(x_49); +x_53 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_53, 0, x_49); +x_54 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___closed__4; +x_55 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_55, 0, x_54); +lean_ctor_set(x_55, 1, x_53); +x_56 = l_Lean_KernelException_toMessageData___closed__15; +x_57 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_57, 0, x_55); +lean_ctor_set(x_57, 1, x_56); +x_58 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_59 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_58, x_57, x_5, x_6, x_7, x_8, x_9, x_10, x_51); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_60 = !lean_is_exclusive(x_59); +if (x_60 == 0) +{ +lean_object* x_61; +x_61 = lean_ctor_get(x_59, 0); +lean_dec(x_61); +lean_ctor_set(x_59, 0, x_49); +return x_59; +} +else +{ +lean_object* x_62; lean_object* x_63; +x_62 = lean_ctor_get(x_59, 1); +lean_inc(x_62); +lean_dec(x_59); +x_63 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_63, 0, x_49); +lean_ctor_set(x_63, 1, x_62); +return x_63; +} +} +} +} +else +{ +uint8_t x_77; +lean_dec(x_41); +lean_dec(x_36); +lean_dec(x_26); +lean_dec(x_23); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_77 = !lean_is_exclusive(x_43); +if (x_77 == 0) +{ +return x_43; +} +else +{ +lean_object* x_78; lean_object* x_79; lean_object* x_80; +x_78 = lean_ctor_get(x_43, 0); +x_79 = lean_ctor_get(x_43, 1); +lean_inc(x_79); +lean_inc(x_78); +lean_dec(x_43); +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_36); +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_23); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_81 = !lean_is_exclusive(x_40); +if (x_81 == 0) { return x_40; } else { -lean_object* x_75; lean_object* x_76; lean_object* x_77; -x_75 = lean_ctor_get(x_40, 0); -x_76 = lean_ctor_get(x_40, 1); -lean_inc(x_76); -lean_inc(x_75); +lean_object* x_82; lean_object* x_83; lean_object* x_84; +x_82 = lean_ctor_get(x_40, 0); +x_83 = lean_ctor_get(x_40, 1); +lean_inc(x_83); +lean_inc(x_82); lean_dec(x_40); -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; +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_78; -lean_dec(x_33); +uint8_t x_85; +lean_dec(x_30); +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_24); lean_dec(x_23); -lean_dec(x_22); -lean_dec(x_20); lean_dec(x_10); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_78 = !lean_is_exclusive(x_37); -if (x_78 == 0) +x_85 = !lean_is_exclusive(x_35); +if (x_85 == 0) { -return x_37; +return x_35; } else { -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_37, 0); -x_80 = lean_ctor_get(x_37, 1); -lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_37); -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* x_86; lean_object* x_87; lean_object* x_88; +x_86 = lean_ctor_get(x_35, 0); +x_87 = lean_ctor_get(x_35, 1); +lean_inc(x_87); +lean_inc(x_86); +lean_dec(x_35); +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_82; -lean_dec(x_27); +uint8_t x_89; +lean_dec(x_30); +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_24); lean_dec(x_23); -lean_dec(x_22); -lean_dec(x_21); -lean_dec(x_20); lean_dec(x_10); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_82 = !lean_is_exclusive(x_32); -if (x_82 == 0) +x_89 = !lean_is_exclusive(x_32); +if (x_89 == 0) { return x_32; } else { -lean_object* x_83; lean_object* x_84; lean_object* x_85; -x_83 = lean_ctor_get(x_32, 0); -x_84 = lean_ctor_get(x_32, 1); -lean_inc(x_84); -lean_inc(x_83); +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_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_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_86; +uint8_t x_93; +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_24); +lean_dec(x_23); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_93 = !lean_is_exclusive(x_27); +if (x_93 == 0) +{ +lean_object* x_94; lean_object* x_95; +x_94 = lean_ctor_get(x_27, 0); +lean_dec(x_94); +x_95 = lean_ctor_get(x_28, 0); +lean_inc(x_95); +lean_dec(x_28); +lean_ctor_set(x_27, 0, x_95); +return x_27; +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; +x_96 = lean_ctor_get(x_27, 1); +lean_inc(x_96); lean_dec(x_27); -lean_dec(x_23); -lean_dec(x_22); -lean_dec(x_21); -lean_dec(x_20); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_86 = !lean_is_exclusive(x_29); -if (x_86 == 0) -{ -return x_29; -} -else -{ -lean_object* x_87; lean_object* x_88; lean_object* x_89; -x_87 = lean_ctor_get(x_29, 0); -x_88 = lean_ctor_get(x_29, 1); -lean_inc(x_88); -lean_inc(x_87); -lean_dec(x_29); -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_23); -lean_dec(x_22); -lean_dec(x_21); -lean_dec(x_20); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_90 = !lean_is_exclusive(x_24); -if (x_90 == 0) -{ -lean_object* x_91; lean_object* x_92; -x_91 = lean_ctor_get(x_24, 0); -lean_dec(x_91); -x_92 = lean_ctor_get(x_25, 0); -lean_inc(x_92); -lean_dec(x_25); -lean_ctor_set(x_24, 0, x_92); -return x_24; -} -else -{ -lean_object* x_93; lean_object* x_94; lean_object* x_95; -x_93 = lean_ctor_get(x_24, 1); -lean_inc(x_93); -lean_dec(x_24); -x_94 = lean_ctor_get(x_25, 0); -lean_inc(x_94); -lean_dec(x_25); -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; -lean_dec(x_23); -lean_dec(x_22); -lean_dec(x_21); -lean_dec(x_20); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -x_96 = !lean_is_exclusive(x_24); -if (x_96 == 0) -{ -return x_24; -} -else -{ -lean_object* x_97; lean_object* x_98; lean_object* x_99; -x_97 = lean_ctor_get(x_24, 0); -x_98 = lean_ctor_get(x_24, 1); -lean_inc(x_98); +x_97 = lean_ctor_get(x_28, 0); lean_inc(x_97); -lean_dec(x_24); -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; +lean_dec(x_28); +x_98 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_98, 0, x_97); +lean_ctor_set(x_98, 1, x_96); +return x_98; } } } else { -uint8_t x_100; +uint8_t x_99; +lean_dec(x_26); +lean_dec(x_25); +lean_dec(x_24); +lean_dec(x_23); lean_dec(x_10); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); lean_dec(x_5); -x_100 = !lean_is_exclusive(x_15); -if (x_100 == 0) +x_99 = !lean_is_exclusive(x_27); +if (x_99 == 0) +{ +return x_27; +} +else +{ +lean_object* x_100; lean_object* x_101; lean_object* x_102; +x_100 = lean_ctor_get(x_27, 0); +x_101 = lean_ctor_get(x_27, 1); +lean_inc(x_101); +lean_inc(x_100); +lean_dec(x_27); +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; lean_object* x_110; +x_103 = lean_ctor_get(x_15, 1); +lean_inc(x_103); +lean_dec(x_15); +x_104 = lean_ctor_get(x_16, 0); +lean_inc(x_104); +lean_dec(x_16); +x_105 = lean_ctor_get(x_17, 0); +lean_inc(x_105); +lean_dec(x_17); +x_106 = lean_ctor_get(x_18, 0); +lean_inc(x_106); +lean_dec(x_18); +x_107 = lean_ctor_get(x_19, 1); +lean_inc(x_107); +lean_dec(x_19); +x_108 = lean_array_get_size(x_104); +x_109 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1; +lean_inc(x_5); +x_110 = l_Lean_Elab_Term_mkAuxName(x_109, x_5, x_6, x_7, x_8, x_9, x_10, x_103); +if (lean_obj_tag(x_110) == 0) +{ +lean_object* x_111; lean_object* x_112; lean_object* x_113; +x_111 = lean_ctor_get(x_110, 0); +lean_inc(x_111); +x_112 = lean_ctor_get(x_110, 1); +lean_inc(x_112); +lean_dec(x_110); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_7); +lean_inc(x_106); +lean_inc(x_108); +lean_inc(x_105); +x_113 = l_Lean_Meta_Match_mkMatcher(x_111, x_105, x_108, x_106, x_7, x_8, x_9, x_10, x_112); +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; +x_114 = lean_ctor_get(x_113, 0); +lean_inc(x_114); +x_115 = lean_ctor_get(x_113, 1); +lean_inc(x_115); +lean_dec(x_113); +x_116 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_116, 0, x_108); +x_117 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___closed__2; +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_7); +lean_inc(x_6); +lean_inc(x_5); +x_118 = l_Lean_Meta_forallBoundedTelescope___at_Lean_Elab_Term_elabLetDeclAux___spec__1___rarg(x_105, x_116, x_117, x_5, x_6, x_7, x_8, x_9, x_10, x_115); +if (lean_obj_tag(x_118) == 0) +{ +lean_object* x_119; lean_object* x_120; lean_object* x_121; +x_119 = lean_ctor_get(x_118, 0); +lean_inc(x_119); +x_120 = lean_ctor_get(x_118, 1); +lean_inc(x_120); +lean_dec(x_118); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_7); +lean_inc(x_6); +lean_inc(x_5); +lean_inc(x_114); +x_121 = l_Lean_Elab_Term_reportMatcherResultErrors(x_106, x_114, x_5, x_6, x_7, x_8, x_9, x_10, x_120); +lean_dec(x_106); +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; uint8_t x_128; lean_object* x_129; lean_object* x_143; lean_object* x_144; lean_object* x_145; uint8_t x_146; +x_122 = lean_ctor_get(x_121, 1); +lean_inc(x_122); +if (lean_is_exclusive(x_121)) { + lean_ctor_release(x_121, 0); + lean_ctor_release(x_121, 1); + x_123 = x_121; +} else { + lean_dec_ref(x_121); + x_123 = lean_box(0); +} +x_124 = lean_ctor_get(x_114, 0); +lean_inc(x_124); +lean_dec(x_114); +x_125 = l_Lean_mkApp(x_124, x_119); +x_126 = l_Lean_mkAppN(x_125, x_104); +lean_dec(x_104); +x_127 = l_Lean_mkAppN(x_126, x_107); +lean_dec(x_107); +x_143 = lean_st_ref_get(x_10, x_122); +x_144 = lean_ctor_get(x_143, 0); +lean_inc(x_144); +x_145 = lean_ctor_get(x_144, 3); +lean_inc(x_145); +lean_dec(x_144); +x_146 = lean_ctor_get_uint8(x_145, sizeof(void*)*1); +lean_dec(x_145); +if (x_146 == 0) +{ +lean_object* x_147; uint8_t x_148; +x_147 = lean_ctor_get(x_143, 1); +lean_inc(x_147); +lean_dec(x_143); +x_148 = 0; +x_128 = x_148; +x_129 = x_147; +goto block_142; +} +else +{ +lean_object* x_149; lean_object* x_150; lean_object* x_151; lean_object* x_152; lean_object* x_153; uint8_t x_154; +x_149 = lean_ctor_get(x_143, 1); +lean_inc(x_149); +lean_dec(x_143); +x_150 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_151 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_150, x_5, x_6, x_7, x_8, x_9, x_10, x_149); +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); +x_154 = lean_unbox(x_152); +lean_dec(x_152); +x_128 = x_154; +x_129 = x_153; +goto block_142; +} +block_142: +{ +if (x_128 == 0) +{ +lean_object* x_130; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +if (lean_is_scalar(x_123)) { + x_130 = lean_alloc_ctor(0, 2, 0); +} else { + x_130 = x_123; +} +lean_ctor_set(x_130, 0, x_127); +lean_ctor_set(x_130, 1, x_129); +return x_130; +} +else +{ +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; uint8_t x_138; +lean_dec(x_123); +lean_inc(x_127); +x_131 = lean_alloc_ctor(2, 1, 0); +lean_ctor_set(x_131, 0, x_127); +x_132 = l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabMatchAux___closed__4; +x_133 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_133, 0, x_132); +lean_ctor_set(x_133, 1, x_131); +x_134 = l_Lean_KernelException_toMessageData___closed__15; +x_135 = lean_alloc_ctor(10, 2, 0); +lean_ctor_set(x_135, 0, x_133); +lean_ctor_set(x_135, 1, x_134); +x_136 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; +x_137 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_136, x_135, x_5, x_6, x_7, x_8, x_9, x_10, x_129); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_138 = !lean_is_exclusive(x_137); +if (x_138 == 0) +{ +lean_object* x_139; +x_139 = lean_ctor_get(x_137, 0); +lean_dec(x_139); +lean_ctor_set(x_137, 0, x_127); +return x_137; +} +else +{ +lean_object* x_140; lean_object* x_141; +x_140 = lean_ctor_get(x_137, 1); +lean_inc(x_140); +lean_dec(x_137); +x_141 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_141, 0, x_127); +lean_ctor_set(x_141, 1, x_140); +return x_141; +} +} +} +} +else +{ +uint8_t x_155; +lean_dec(x_119); +lean_dec(x_114); +lean_dec(x_107); +lean_dec(x_104); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_155 = !lean_is_exclusive(x_121); +if (x_155 == 0) +{ +return x_121; +} +else +{ +lean_object* x_156; lean_object* x_157; lean_object* x_158; +x_156 = lean_ctor_get(x_121, 0); +x_157 = lean_ctor_get(x_121, 1); +lean_inc(x_157); +lean_inc(x_156); +lean_dec(x_121); +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; +} +} +} +else +{ +uint8_t x_159; +lean_dec(x_114); +lean_dec(x_107); +lean_dec(x_106); +lean_dec(x_104); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_159 = !lean_is_exclusive(x_118); +if (x_159 == 0) +{ +return x_118; +} +else +{ +lean_object* x_160; lean_object* x_161; lean_object* x_162; +x_160 = lean_ctor_get(x_118, 0); +x_161 = lean_ctor_get(x_118, 1); +lean_inc(x_161); +lean_inc(x_160); +lean_dec(x_118); +x_162 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_162, 0, x_160); +lean_ctor_set(x_162, 1, x_161); +return x_162; +} +} +} +else +{ +uint8_t x_163; +lean_dec(x_108); +lean_dec(x_107); +lean_dec(x_106); +lean_dec(x_105); +lean_dec(x_104); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_163 = !lean_is_exclusive(x_113); +if (x_163 == 0) +{ +return x_113; +} +else +{ +lean_object* x_164; lean_object* x_165; lean_object* x_166; +x_164 = lean_ctor_get(x_113, 0); +x_165 = lean_ctor_get(x_113, 1); +lean_inc(x_165); +lean_inc(x_164); +lean_dec(x_113); +x_166 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_166, 0, x_164); +lean_ctor_set(x_166, 1, x_165); +return x_166; +} +} +} +else +{ +uint8_t x_167; +lean_dec(x_108); +lean_dec(x_107); +lean_dec(x_106); +lean_dec(x_105); +lean_dec(x_104); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_167 = !lean_is_exclusive(x_110); +if (x_167 == 0) +{ +return x_110; +} +else +{ +lean_object* x_168; lean_object* x_169; lean_object* x_170; +x_168 = lean_ctor_get(x_110, 0); +x_169 = lean_ctor_get(x_110, 1); +lean_inc(x_169); +lean_inc(x_168); +lean_dec(x_110); +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 +{ +uint8_t x_171; +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +lean_dec(x_5); +x_171 = !lean_is_exclusive(x_15); +if (x_171 == 0) { return x_15; } else { -lean_object* x_101; lean_object* x_102; lean_object* x_103; -x_101 = lean_ctor_get(x_15, 0); -x_102 = lean_ctor_get(x_15, 1); -lean_inc(x_102); -lean_inc(x_101); +lean_object* x_172; lean_object* x_173; lean_object* x_174; +x_172 = lean_ctor_get(x_15, 0); +x_173 = lean_ctor_get(x_15, 1); +lean_inc(x_173); +lean_inc(x_172); lean_dec(x_15); -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; +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; } } } @@ -28805,7 +29259,7 @@ lean_object* x_73; lean_object* x_74; lean_object* x_75; lean_object* x_76; lean x_73 = lean_ctor_get(x_67, 1); lean_inc(x_73); lean_dec(x_67); -x_74 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_74 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_75 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_74, x_5, x_6, x_7, x_8, x_9, x_10, x_73); x_76 = lean_ctor_get(x_75, 0); lean_inc(x_76); @@ -28891,7 +29345,7 @@ x_54 = l_Lean_KernelException_toMessageData___closed__15; x_55 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_55, 0, x_53); lean_ctor_set(x_55, 1, x_54); -x_56 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_56 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_57 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_56, x_55, x_5, x_6, x_7, x_8, x_9, x_10, x_39); x_58 = lean_ctor_get(x_57, 1); lean_inc(x_58); @@ -30546,11 +31000,11 @@ x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } } -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_8718_(lean_object* x_1) { +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_8841_(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; -x_2 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5; +x_2 = l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5; x_3 = l_Lean_registerTraceClass(x_2, x_1); return x_3; } @@ -30702,22 +31156,24 @@ l_Lean_Elab_Term_instInhabitedMatchAltView___closed__1 = _init_l_Lean_Elab_Term_ lean_mark_persistent(l_Lean_Elab_Term_instInhabitedMatchAltView___closed__1); l_Lean_Elab_Term_instInhabitedMatchAltView = _init_l_Lean_Elab_Term_instInhabitedMatchAltView(); lean_mark_persistent(l_Lean_Elab_Term_instInhabitedMatchAltView); -l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__1 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__1(); -lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__1); -l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__2 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__2(); -lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__2); -l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__3 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__3(); -lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__3); -l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__4 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__4(); -lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__4); -l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5(); -lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__5); -l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__6 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__6(); -lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__6); -l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__7 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__7(); -lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__1___closed__7); +l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__1 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__1(); +lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__1); +l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__2 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__2(); +lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__2); +l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__3 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__3(); +lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__3); +l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__4 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__4(); +lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__4); +l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5(); +lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__5); +l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__6 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__6(); +lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__6); +l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__7 = _init_l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__7(); +lean_mark_persistent(l_Array_forInUnsafe_loop___at___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___spec__1___lambda__2___closed__7); l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__1 = _init_l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__1(); lean_mark_persistent(l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__1); +l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__2 = _init_l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__2(); +lean_mark_persistent(l___private_Lean_Elab_Match_0__Lean_Elab_Term_elabDiscrsWitMatchType___closed__2); l_Lean_Elab_Term_isAuxDiscrName___closed__1 = _init_l_Lean_Elab_Term_isAuxDiscrName___closed__1(); lean_mark_persistent(l_Lean_Elab_Term_isAuxDiscrName___closed__1); l_Lean_Elab_Term_isAuxDiscrName___closed__2 = _init_l_Lean_Elab_Term_isAuxDiscrName___closed__2(); @@ -30742,11 +31198,11 @@ l___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___closed__1 = _init_l lean_mark_persistent(l___private_Lean_Elab_Match_0__Lean_Elab_Term_getMatchAlts___closed__1); l_Lean_Elab_Term_instToStringPatternVar___closed__1 = _init_l_Lean_Elab_Term_instToStringPatternVar___closed__1(); lean_mark_persistent(l_Lean_Elab_Term_instToStringPatternVar___closed__1); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__1 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__1(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__1); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489____closed__2); -res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1489_(lean_io_mk_world()); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__1 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__1); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601____closed__2); +res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_1601_(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); l___regBuiltin_Lean_Elab_Term_elabMVarWithIdKind___closed__1 = _init_l___regBuiltin_Lean_Elab_Term_elabMVarWithIdKind___closed__1(); @@ -30951,17 +31407,17 @@ l_Lean_Elab_Term_elabMatchAltView___closed__1 = _init_l_Lean_Elab_Term_elabMatch lean_mark_persistent(l_Lean_Elab_Term_elabMatchAltView___closed__1); l_Lean_Elab_Term_elabMatchAltView___closed__2 = _init_l_Lean_Elab_Term_elabMatchAltView___closed__2(); lean_mark_persistent(l_Lean_Elab_Term_elabMatchAltView___closed__2); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__2 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__2(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__2); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__3 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__3(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__3); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__4 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__4(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__4); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__5 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__5(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__5); -res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993_(lean_io_mk_world()); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__2 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__2(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__2); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__3 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__3(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__3); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__4 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__4(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__4); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__5 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__5(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__5); +res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105_(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; l_Lean_Elab_Term_match_ignoreUnusedAlts = lean_io_result_get_value(res); lean_mark_persistent(l_Lean_Elab_Term_match_ignoreUnusedAlts); @@ -31045,7 +31501,7 @@ lean_mark_persistent(l___regBuiltin_Lean_Elab_Term_elabMatch___closed__1); res = l___regBuiltin_Lean_Elab_Term_elabMatch(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_8718_(lean_io_mk_world()); +res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_8841_(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); l_Lean_Elab_Term_elabNoMatch___closed__1 = _init_l_Lean_Elab_Term_elabNoMatch___closed__1(); diff --git a/stage0/stdlib/Lean/Elab/Tactic/Basic.c b/stage0/stdlib/Lean/Elab/Tactic/Basic.c index 090aa9d580..a9796b1a79 100644 --- a/stage0/stdlib/Lean/Elab/Tactic/Basic.c +++ b/stage0/stdlib/Lean/Elab/Tactic/Basic.c @@ -83,6 +83,7 @@ lean_object* l_Lean_Elab_Tactic_appendGoals___boxed(lean_object*, lean_object*, lean_object* l_Lean_Elab_Tactic_pruneSolvedGoals___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l_myMacro____x40_Init_Notation___hyg_12336____closed__13; extern lean_object* l_Lean_Elab_initFn____x40_Lean_Elab_Util___hyg_1077____closed__1; +extern lean_object* l___private_Init_Notation_0__Lean_Parser_Tactic_withCheapRefl___closed__1; lean_object* l_Lean_Elab_Tactic_focus(lean_object*); extern lean_object* l_Lean_identKind___closed__2; lean_object* l_Lean_Elab_Tactic_focusAndDone(lean_object*); @@ -405,7 +406,6 @@ lean_object* l___private_Lean_Elab_Tactic_Basic_0__Lean_Elab_Tactic_getIntrosSiz lean_object* l_Lean_Elab_Tactic_tagUntaggedGoals_match__1(lean_object*); lean_object* l_Lean_Elab_Tactic_evalIntros___lambda__1(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_Elab_Tactic_getNameOfIdent_x27___boxed(lean_object*); -lean_object* l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371____closed__1; lean_object* l___private_Lean_Elab_Tactic_Basic_0__Lean_Elab_Tactic_sortFVarIds(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Tactic_appendGoals(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Tactic_saveBacktrackableState(lean_object*); @@ -466,6 +466,7 @@ lean_object* l_Lean_Elab_Tactic_evalAssumption(lean_object*); lean_object* l_Lean_Elab_Tactic_saveBacktrackableState___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Tactic_evalIntro_introStep___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_Elab_Tactic_evalCase___closed__2; +lean_object* l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429____closed__1; extern lean_object* l_Lean_Elab_Term_instInhabitedSavedState___closed__1; lean_object* l_Array_forInUnsafe_loop___at_Lean_Elab_Tactic_evalClear___spec__2___lambda__2(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_Elab_Tactic_setGoals(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -496,6 +497,7 @@ lean_object* l_List_findM_x3f___at___private_Lean_Elab_Tactic_Basic_0__Lean_Elab lean_object* l_Lean_Elab_Tactic_withMacroExpansion___rarg___lambda__1(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___regBuiltin_Lean_Elab_Tactic_evalAllGoals___closed__1; lean_object* lean_st_ref_set(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Parser_Tactic_tacticTry_____closed__2; lean_object* l___regBuiltin_Lean_Elab_Tactic_evalParen___closed__1; lean_object* l___private_Lean_Elab_Tactic_Basic_0__Lean_Elab_Tactic_evalTacticUsing_loop___closed__1; lean_object* l___regBuiltin_Lean_Elab_Tactic_evalRevert(lean_object*); @@ -522,7 +524,7 @@ lean_object* l_Lean_Elab_Tactic_evalIntro_introStep___lambda__1(lean_object*, le lean_object* l_Lean_Elab_log___at_Lean_Elab_Tactic_evalTraceState___spec__1(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Tactic_evalFirst___closed__1; lean_object* l_Lean_Elab_log___at_Lean_Elab_Tactic_evalTacticAux___spec__8(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371_(lean_object*); +lean_object* l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429_(lean_object*); lean_object* l_Lean_Meta_getMVarDecl(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_instantiateMVars(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Tactic_withMacroExpansion___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*); @@ -13050,43 +13052,43 @@ return x_13; } else { -lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_59; lean_object* x_157; uint8_t x_158; +lean_object* x_14; lean_object* x_15; lean_object* x_16; lean_object* x_59; lean_object* x_174; uint8_t x_175; x_14 = lean_unsigned_to_nat(1u); x_15 = l_Lean_Syntax_getArg(x_1, x_14); lean_dec(x_1); -x_157 = l_Lean_nullKind___closed__2; +x_174 = l_Lean_nullKind___closed__2; lean_inc(x_15); -x_158 = l_Lean_Syntax_isOfKind(x_15, x_157); -if (x_158 == 0) +x_175 = l_Lean_Syntax_isOfKind(x_15, x_174); +if (x_175 == 0) { -lean_object* x_159; -x_159 = lean_box(0); -x_59 = x_159; -goto block_156; +lean_object* x_176; +x_176 = lean_box(0); +x_59 = x_176; +goto block_173; } else { -lean_object* x_160; lean_object* x_161; lean_object* x_162; uint8_t x_163; -x_160 = l_Lean_Syntax_getArgs(x_15); -x_161 = lean_array_get_size(x_160); -lean_dec(x_160); -x_162 = lean_unsigned_to_nat(0u); -x_163 = lean_nat_dec_eq(x_161, x_162); -lean_dec(x_161); -if (x_163 == 0) +lean_object* x_177; lean_object* x_178; lean_object* x_179; uint8_t x_180; +x_177 = l_Lean_Syntax_getArgs(x_15); +x_178 = lean_array_get_size(x_177); +lean_dec(x_177); +x_179 = lean_unsigned_to_nat(0u); +x_180 = lean_nat_dec_eq(x_178, x_179); +lean_dec(x_178); +if (x_180 == 0) { -lean_object* x_164; -x_164 = lean_box(0); -x_59 = x_164; -goto block_156; +lean_object* x_181; +x_181 = lean_box(0); +x_59 = x_181; +goto block_173; } else { -lean_object* x_165; lean_object* x_166; +lean_object* x_182; lean_object* x_183; lean_dec(x_15); -x_165 = l_Lean_mkSimpleThunk___closed__1; -x_166 = l_Lean_Elab_Tactic_evalIntro_introStep(x_165, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -return x_166; +x_182 = l_Lean_mkSimpleThunk___closed__1; +x_183 = l_Lean_Elab_Tactic_evalIntro_introStep(x_182, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +return x_183; } } block_58: @@ -13186,7 +13188,7 @@ x_57 = l_Lean_Elab_Tactic_evalTactic(x_56, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_ return x_57; } } -block_156: +block_173: { lean_object* x_60; uint8_t x_61; lean_dec(x_59); @@ -13232,7 +13234,7 @@ lean_inc(x_68); x_72 = l_Lean_Syntax_isOfKind(x_68, 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; 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; 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; 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; 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; 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; lean_object* x_150; lean_object* x_151; +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; 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_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; 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; 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; 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; 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; lean_object* x_166; lean_object* x_167; lean_object* x_168; x_73 = l_Lean_MonadRef_mkInfoFromRefPos___at_Lean_Elab_Tactic_evalIntro___spec__1___rarg(x_8, x_9, x_10); x_74 = lean_ctor_get(x_73, 0); lean_inc(x_74); @@ -13358,44 +13360,74 @@ lean_ctor_set(x_137, 0, x_136); lean_ctor_set(x_137, 1, x_135); x_138 = lean_array_push(x_98, x_137); x_139 = lean_array_push(x_138, x_97); -x_140 = l_Lean_Parser_Tactic_clear___closed__1; +x_140 = l___private_Init_Notation_0__Lean_Parser_Tactic_withCheapRefl___closed__1; +lean_inc(x_74); x_141 = lean_alloc_ctor(2, 2, 0); lean_ctor_set(x_141, 0, x_74); lean_ctor_set(x_141, 1, x_140); x_142 = lean_array_push(x_84, x_141); -x_143 = lean_array_push(x_142, x_92); -x_144 = l_Lean_Parser_Tactic_clear___closed__2; -x_145 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_145, 0, x_144); -lean_ctor_set(x_145, 1, x_143); -x_146 = lean_array_push(x_139, x_145); -x_147 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_147, 0, x_60); -lean_ctor_set(x_147, 1, x_146); -x_148 = lean_array_push(x_84, x_147); -x_149 = l_Lean_Parser_Tactic_myMacro____x40_Init_Notation___hyg_15589____closed__2; -x_150 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_150, 0, x_149); -lean_ctor_set(x_150, 1, x_148); -x_151 = l_Lean_Elab_Tactic_evalTactic(x_150, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_81); -return x_151; +x_143 = l_Lean_Parser_Tactic_clear___closed__1; +x_144 = lean_alloc_ctor(2, 2, 0); +lean_ctor_set(x_144, 0, x_74); +lean_ctor_set(x_144, 1, x_143); +x_145 = lean_array_push(x_84, x_144); +x_146 = lean_array_push(x_145, x_92); +x_147 = l_Lean_Parser_Tactic_clear___closed__2; +x_148 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_148, 0, x_147); +lean_ctor_set(x_148, 1, x_146); +x_149 = lean_array_push(x_84, x_148); +x_150 = lean_array_push(x_149, x_109); +x_151 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_151, 0, x_60); +lean_ctor_set(x_151, 1, x_150); +x_152 = lean_array_push(x_84, x_151); +x_153 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_153, 0, x_60); +lean_ctor_set(x_153, 1, x_152); +x_154 = lean_array_push(x_84, x_153); +x_155 = l_Lean_Parser_Tactic_myMacro____x40_Init_Notation___hyg_15589____closed__5; +x_156 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_156, 0, x_155); +lean_ctor_set(x_156, 1, x_154); +x_157 = lean_array_push(x_84, x_156); +x_158 = l_Lean_Parser_Tactic_myMacro____x40_Init_Notation___hyg_15589____closed__3; +x_159 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_159, 0, x_158); +lean_ctor_set(x_159, 1, x_157); +x_160 = lean_array_push(x_142, x_159); +x_161 = l_Lean_Parser_Tactic_tacticTry_____closed__2; +x_162 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_162, 0, x_161); +lean_ctor_set(x_162, 1, x_160); +x_163 = lean_array_push(x_139, x_162); +x_164 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_164, 0, x_60); +lean_ctor_set(x_164, 1, x_163); +x_165 = lean_array_push(x_84, x_164); +x_166 = l_Lean_Parser_Tactic_myMacro____x40_Init_Notation___hyg_15589____closed__2; +x_167 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_167, 0, x_166); +lean_ctor_set(x_167, 1, x_165); +x_168 = l_Lean_Elab_Tactic_evalTactic(x_167, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_81); +return x_168; } else { -lean_object* x_152; lean_object* x_153; +lean_object* x_169; lean_object* x_170; lean_dec(x_68); -x_152 = l_Lean_mkSimpleThunk___closed__1; -x_153 = l_Lean_Elab_Tactic_evalIntro_introStep(x_152, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -return x_153; +x_169 = l_Lean_mkSimpleThunk___closed__1; +x_170 = l_Lean_Elab_Tactic_evalIntro_introStep(x_169, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +return x_170; } } else { -lean_object* x_154; lean_object* x_155; -x_154 = l_Lean_Syntax_getId(x_68); +lean_object* x_171; lean_object* x_172; +x_171 = l_Lean_Syntax_getId(x_68); lean_dec(x_68); -x_155 = l_Lean_Elab_Tactic_evalIntro_introStep(x_154, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); -return x_155; +x_172 = l_Lean_Elab_Tactic_evalIntro_introStep(x_171, x_2, x_3, x_4, x_5, x_6, x_7, x_8, x_9, x_10); +return x_172; } } } @@ -17348,7 +17380,7 @@ x_5 = l_Lean_KeyedDeclsAttribute_addBuiltin___rarg(x_2, x_3, x_4, x_1); return x_5; } } -static lean_object* _init_l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371____closed__1() { +static lean_object* _init_l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429____closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -17358,11 +17390,11 @@ x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371_(lean_object* x_1) { +lean_object* l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429_(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; -x_2 = l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371____closed__1; +x_2 = l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429____closed__1; x_3 = l_Lean_registerTraceClass(x_2, x_1); return x_3; } @@ -17793,9 +17825,9 @@ lean_mark_persistent(l___regBuiltin_Lean_Elab_Tactic_evalFirst___closed__1); res = l___regBuiltin_Lean_Elab_Tactic_evalFirst(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); -l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371____closed__1 = _init_l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371____closed__1(); -lean_mark_persistent(l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371____closed__1); -res = l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4371_(lean_io_mk_world()); +l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429____closed__1 = _init_l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429____closed__1(); +lean_mark_persistent(l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429____closed__1); +res = l_Lean_Elab_Tactic_initFn____x40_Lean_Elab_Tactic_Basic___hyg_4429_(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); return lean_io_result_mk_ok(lean_box(0)); diff --git a/stage0/stdlib/Lean/Elab/Tactic/Match.c b/stage0/stdlib/Lean/Elab/Tactic/Match.c index 2eec46e980..044f7296b3 100644 --- a/stage0/stdlib/Lean/Elab/Tactic/Match.c +++ b/stage0/stdlib/Lean/Elab/Tactic/Match.c @@ -90,7 +90,6 @@ extern lean_object* l_myMacro____x40_Init_Notation___hyg_12938____closed__10; lean_object* l___regBuiltin_Lean_Elab_Tactic_evalEraseAuxDiscrs___closed__1; lean_object* l_Array_foldlMUnsafe___at_Lean_Elab_Tactic_evalEraseAuxDiscrs___spec__7(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); extern lean_object* l___private_Lean_Elab_Tactic_Basic_0__Lean_Elab_Tactic_sortFVarIds___closed__1; -extern lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1; lean_object* l___private_Std_Data_PersistentArray_0__Std_PersistentArray_foldlMAux___at_Lean_Elab_Tactic_evalEraseAuxDiscrs___spec__4(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_getCurrMacroScope(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); size_t l_USize_shiftLeft(size_t, size_t); @@ -151,6 +150,7 @@ lean_object* l_Lean_Elab_throwUnsupportedSyntax___at_Lean_Elab_Tactic_evalMatch_ lean_object* lean_usize_to_nat(size_t); lean_object* l_Lean_Elab_Tactic_evalEraseAuxDiscrs_match__1___rarg(lean_object*, lean_object*); lean_object* l_Std_PersistentArray_foldlM___at_Lean_Elab_Tactic_evalEraseAuxDiscrs___spec__2___boxed(lean_object*, lean_object*, lean_object*); +extern lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1; lean_object* l___private_Lean_Elab_Tactic_Match_0__Lean_Elab_Tactic_mkAuxiliaryMatchTerm(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Std_Data_PersistentArray_0__Std_PersistentArray_foldlMAux___at_Lean_Elab_Tactic_evalEraseAuxDiscrs___spec__4___closed__2; lean_object* l___regBuiltin_Lean_Elab_Tactic_evalEraseAuxDiscrs(lean_object*); @@ -1377,7 +1377,7 @@ lean_dec(x_177); x_216 = lean_ctor_get(x_6, 0); lean_inc(x_216); lean_dec(x_6); -x_217 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_5993____closed__1; +x_217 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Match___hyg_6105____closed__1; x_218 = l_Lean_Name_appendIndexAfter(x_217, x_216); x_219 = l_Lean_Name_append(x_1, x_218); x_220 = l_Lean_mkIdentFrom(x_30, x_219); diff --git a/stage0/stdlib/Lean/Elab/Term.c b/stage0/stdlib/Lean/Elab/Term.c index 7e279d447e..411dbaabde 100644 --- a/stage0/stdlib/Lean/Elab/Term.c +++ b/stage0/stdlib/Lean/Elab/Term.c @@ -94,6 +94,7 @@ lean_object* l_Lean_Elab_Term_elabNumLit___lambda__1___boxed(lean_object*, lean_ extern lean_object* l_Lean_withIncRecDepth___rarg___lambda__2___closed__2; extern lean_object* l_Array_forInUnsafe_loop___at_myMacro____x40_Init_NotationExtra___hyg_5658____spec__3___lambda__2___closed__2; lean_object* l_Lean_Elab_Term_mkTermInfo_match__3(lean_object*); +lean_object* l_Lean_Elab_Term_autoLift; extern lean_object* l_Lean_nullKind; lean_object* l_Lean_Meta_withMVarContext___at_Lean_Elab_Term_logUnassignedUsingErrorInfos___spec__2(lean_object*); lean_object* l_Lean_Elab_Term_instAddErrorMessageContextTermElabM(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -247,6 +248,7 @@ extern lean_object* l_Lean_charLitKind___closed__2; extern lean_object* l_Lean_Elab_autoBoundImplicitExceptionId; lean_object* l_List_append___rarg(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_withDeclName(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1; extern lean_object* l_Std_PersistentArray_empty___closed__1; uint8_t lean_name_eq(lean_object*, lean_object*); lean_object* l_Lean_throwError___at_Lean_Elab_Term_mkAuxName___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -578,6 +580,7 @@ lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe___boxed(lean_ob extern lean_object* l_Lean_Meta_isCoeDecl___closed__34; lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe_match__7(lean_object*); lean_object* l_Lean_MetavarContext_isWellFormed(lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__3; uint8_t l_Lean_Elab_Term_blockImplicitLambda(lean_object*); extern lean_object* l_Lean_scientificLitKind___closed__2; lean_object* l_Lean_Elab_Term_elabTypeStx(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -612,12 +615,14 @@ lean_object* l_Lean_Elab_Term_commitIfDidNotPostpone(lean_object*); lean_object* l_Lean_resolveGlobalConst___at_Lean_Elab_Term_elabDoubleQuotedName___spec__2___lambda__1___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* lean_st_mk_ref(lean_object*, lean_object*); lean_object* l_List_foldlM___at_Lean_Elab_Term_evalExpr___spec__11___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_Elab_autoBoundImplicitLocal___closed__1; lean_object* l_Lean_Elab_Term_mkTypeMismatchError_match__1___rarg(lean_object*, lean_object*, lean_object*); lean_object* l___regBuiltin_Lean_Elab_Term_elabCharLit(lean_object*); lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_elabOptLevel___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_elabUsingElabFnsAux_match__2___rarg(lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445_(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501_(lean_object*); lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207_(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229_(lean_object*); lean_object* l_Lean_mkAuxName___at_Lean_Elab_Term_mkAuxName___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_setElabConfig(lean_object*); lean_object* l_Lean_Elab_Term_instMetaEvalTermElabM___rarg___closed__4; @@ -647,6 +652,7 @@ lean_object* l_Lean_Elab_Term_resolveId_x3f_match__2(lean_object*); lean_object* l___private_Lean_MonadEnv_0__Lean_checkUnsupported___at_Lean_Elab_Term_evalExpr___spec__8(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_isLetRecAuxMVar(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_instMonadMacroAdapterTermElabM___lambda__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255____closed__1; uint8_t l_Lean_Elab_Term_Context_errToSorry___default; lean_object* l_Lean_Elab_Term_instInhabitedTermElabResult(lean_object*); lean_object* l_Lean_Elab_Term_resolveName(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -686,6 +692,7 @@ lean_object* l_Lean_Elab_Term_resolveId_x3f___lambda__1___closed__3; lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207____closed__4; lean_object* l_Lean_Elab_Term_mkTermInfo_match__2(lean_object*); lean_object* l_Lean_Elab_Term_resolveId_x3f(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__2; lean_object* lean_expr_dbg_to_string(lean_object*); lean_object* l_Lean_Elab_Term_getMessageLog___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_synthesizeInstMVarCore___lambda__1___closed__2; @@ -738,6 +745,7 @@ lean_object* l_Array_forInUnsafe_loop___at_Lean_Elab_Term_addAutoBoundImplicits_ lean_object* l_Lean_Core_checkMaxHeartbeats(lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_withLCtx___at_Lean_Elab_Term_elabSyntheticHole___spec__1___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_ResolveName_resolveGlobalName(lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__4; lean_object* l_Lean_throwError___at_Lean_Elab_Term_mkConst___spec__2___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_pushInfoTree___at_Lean_Elab_Term_addTermInfo___spec__1(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_ofExcept___at_Lean_Elab_Term_evalExpr___spec__14___rarg___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -807,6 +815,7 @@ lean_object* l_Lean_Elab_Term_mkConst___closed__3; lean_object* l___private_Lean_Meta_Basic_0__Lean_Meta_withMVarContextImp___rarg(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_resolveName___closed__4; lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe_match__2(lean_object*); +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__1; extern lean_object* l_Lean_nullKind___closed__2; lean_object* l_Lean_Elab_Term_instMonadLogTermElabM___lambda__3___boxed(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_isLambdaWithImplicit___lambda__1___boxed(lean_object*, lean_object*); @@ -1039,7 +1048,6 @@ lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_applyAttributesCore(le lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_applyAttributesCore_match__2(lean_object*); lean_object* l_Lean_Elab_Term_mkTypeMismatchError___closed__2; lean_object* l_Lean_Elab_Term_adaptExpander(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); -lean_object* l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199____closed__1; lean_object* l_Lean_Meta_getLevel(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_tryPostponeIfMVar(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_evalExpr___rarg___closed__1; @@ -1116,9 +1124,9 @@ extern size_t l_Std_PersistentHashMap_insertAux___rarg___closed__2; lean_object* l_Lean_Elab_Term_mkExplicitBinder___closed__1; lean_object* l_Lean_Elab_Term_registerSyntheticMVarWithCurrRef(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_elabImplicitLambdaAux(lean_object*, uint8_t, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); +lean_object* l_Lean_Option_register___at_Lean_Elab_initFn____x40_Lean_Elab_AutoBound___hyg_4____spec__1(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_logUnassignedUsingErrorInfos(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_Syntax_isOfKind(lean_object*, lean_object*); -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1; lean_object* l_Lean_PersistentEnvExtension_getState___rarg(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_elabByTactic___closed__3; lean_object* l___private_Lean_Elab_Term_0__Lean_Elab_Term_useImplicitLambda_x3f(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -1171,7 +1179,7 @@ lean_object* l_Lean_Elab_Term_applyResult___rarg(lean_object*, lean_object*, lea lean_object* l_IO_println___at_Lean_instEval___spec__1(lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_throwErrorIfErrors(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); uint8_t l_Lean_NameSet_contains(lean_object*, lean_object*); -lean_object* l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199_(lean_object*); +lean_object* l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255_(lean_object*); lean_object* l_Lean_Elab_Term_elabByTactic_match__1___rarg(lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Elab_Term_addAutoBoundImplicits(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); lean_object* l_Lean_Meta_whnfD(lean_object*, lean_object*, lean_object*, lean_object*, lean_object*, lean_object*); @@ -12013,7 +12021,7 @@ static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_32 _start: { lean_object* x_1; -x_1 = lean_mk_string("maxCoeSize"); +x_1 = lean_mk_string("autoLift"); return x_1; } } @@ -12031,22 +12039,23 @@ static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_32 _start: { lean_object* x_1; -x_1 = lean_mk_string("maximum number of instances used to construct an automatic coercion"); +x_1 = lean_mk_string("insert monadic lifts (i.e., `liftM` and `liftCoeM`) when needed"); return x_1; } } static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207____closed__4() { _start: { -lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; -x_1 = lean_unsigned_to_nat(16u); +uint8_t x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; +x_1 = 1; x_2 = l_Lean_instInhabitedParserDescr___closed__1; x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207____closed__3; -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; +x_4 = lean_box(x_1); +x_5 = lean_alloc_ctor(0, 3, 0); +lean_ctor_set(x_5, 0, x_4); +lean_ctor_set(x_5, 1, x_2); +lean_ctor_set(x_5, 2, x_3); +return x_5; } } lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207_(lean_object* x_1) { @@ -12055,6 +12064,56 @@ _start: lean_object* x_2; lean_object* x_3; lean_object* x_4; x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207____closed__2; x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207____closed__4; +x_4 = l_Lean_Option_register___at_Lean_Elab_initFn____x40_Lean_Elab_AutoBound___hyg_4____spec__1(x_2, x_3, x_1); +return x_4; +} +} +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__1() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("maxCoeSize"); +return x_1; +} +} +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__2() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; +x_1 = lean_box(0); +x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__1; +x_3 = lean_name_mk_string(x_1, x_2); +return x_3; +} +} +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__3() { +_start: +{ +lean_object* x_1; +x_1 = lean_mk_string("maximum number of instances used to construct an automatic coercion"); +return x_1; +} +} +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__4() { +_start: +{ +lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_1 = lean_unsigned_to_nat(16u); +x_2 = l_Lean_instInhabitedParserDescr___closed__1; +x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__3; +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_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229_(lean_object* x_1) { +_start: +{ +lean_object* x_2; lean_object* x_3; lean_object* x_4; +x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__2; +x_3 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__4; x_4 = l_Lean_Option_register___at_Lean_initFn____x40_Lean_Util_RecDepth___hyg_4____spec__1(x_2, x_3, x_1); return x_4; } @@ -14766,11 +14825,28 @@ x_34 = lean_ctor_get(x_33, 0); lean_inc(x_34); if (lean_obj_tag(x_34) == 0) { -lean_object* x_35; lean_object* x_36; +lean_object* x_35; lean_object* x_36; lean_object* x_37; uint8_t x_38; lean_free_object(x_25); x_35 = lean_ctor_get(x_33, 1); lean_inc(x_35); lean_dec(x_33); +x_36 = lean_ctor_get(x_10, 0); +lean_inc(x_36); +x_37 = l_Lean_Elab_Term_autoLift; +x_38 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_36, x_37); +lean_dec(x_36); +if (x_38 == 0) +{ +lean_object* x_39; +lean_dec(x_32); +lean_dec(x_31); +x_39 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_35); +lean_dec(x_7); +return x_39; +} +else +{ +lean_object* x_40; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -14780,67 +14856,25 @@ lean_inc(x_6); lean_inc(x_4); lean_inc(x_22); lean_inc(x_1); -x_36 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_31, x_32, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_35); -if (lean_obj_tag(x_36) == 0) +x_40 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_31, x_32, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_35); +if (lean_obj_tag(x_40) == 0) { -lean_object* x_37; -x_37 = lean_ctor_get(x_36, 0); -lean_inc(x_37); -if (lean_obj_tag(x_37) == 0) +lean_object* x_41; +x_41 = lean_ctor_get(x_40, 0); +lean_inc(x_41); +if (lean_obj_tag(x_41) == 0) { -lean_object* x_38; lean_object* x_39; -x_38 = lean_ctor_get(x_36, 1); -lean_inc(x_38); -lean_dec(x_36); -x_39 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_38); -lean_dec(x_7); -return x_39; -} -else -{ -uint8_t x_40; -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_40 = !lean_is_exclusive(x_36); -if (x_40 == 0) -{ -lean_object* x_41; lean_object* x_42; -x_41 = lean_ctor_get(x_36, 0); -lean_dec(x_41); -x_42 = lean_ctor_get(x_37, 0); +lean_object* x_42; lean_object* x_43; +x_42 = lean_ctor_get(x_40, 1); lean_inc(x_42); -lean_dec(x_37); -lean_ctor_set(x_36, 0, x_42); -return x_36; +lean_dec(x_40); +x_43 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_42); +lean_dec(x_7); +return x_43; } else { -lean_object* x_43; lean_object* x_44; lean_object* x_45; -x_43 = lean_ctor_get(x_36, 1); -lean_inc(x_43); -lean_dec(x_36); -x_44 = lean_ctor_get(x_37, 0); -lean_inc(x_44); -lean_dec(x_37); -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; -} -} -} -else -{ -uint8_t x_46; +uint8_t x_44; lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -14852,22 +14886,30 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_46 = !lean_is_exclusive(x_36); -if (x_46 == 0) +x_44 = !lean_is_exclusive(x_40); +if (x_44 == 0) { -return x_36; +lean_object* x_45; lean_object* x_46; +x_45 = lean_ctor_get(x_40, 0); +lean_dec(x_45); +x_46 = lean_ctor_get(x_41, 0); +lean_inc(x_46); +lean_dec(x_41); +lean_ctor_set(x_40, 0, x_46); +return x_40; } else { lean_object* x_47; lean_object* x_48; lean_object* x_49; -x_47 = lean_ctor_get(x_36, 0); -x_48 = lean_ctor_get(x_36, 1); -lean_inc(x_48); +x_47 = lean_ctor_get(x_40, 1); lean_inc(x_47); -lean_dec(x_36); -x_49 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_49, 0, x_47); -lean_ctor_set(x_49, 1, x_48); +lean_dec(x_40); +x_48 = lean_ctor_get(x_41, 0); +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_47); return x_49; } } @@ -14875,148 +14917,148 @@ return x_49; else { uint8_t x_50; -x_50 = !lean_is_exclusive(x_34); +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +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_1); +x_50 = !lean_is_exclusive(x_40); if (x_50 == 0) { -lean_object* x_51; lean_object* x_52; lean_object* x_53; lean_object* x_54; lean_object* x_55; -x_51 = lean_ctor_get(x_34, 0); -x_52 = lean_ctor_get(x_33, 1); +return x_40; +} +else +{ +lean_object* x_51; lean_object* x_52; lean_object* x_53; +x_51 = lean_ctor_get(x_40, 0); +x_52 = lean_ctor_get(x_40, 1); lean_inc(x_52); +lean_inc(x_51); +lean_dec(x_40); +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 +{ +uint8_t x_54; +x_54 = !lean_is_exclusive(x_34); +if (x_54 == 0) +{ +lean_object* x_55; lean_object* x_56; lean_object* x_57; lean_object* x_58; lean_object* x_59; +x_55 = lean_ctor_get(x_34, 0); +x_56 = lean_ctor_get(x_33, 1); +lean_inc(x_56); lean_dec(x_33); -x_53 = lean_ctor_get(x_51, 0); -lean_inc(x_53); -x_54 = lean_ctor_get(x_51, 1); -lean_inc(x_54); -lean_dec(x_51); +x_57 = lean_ctor_get(x_55, 0); +lean_inc(x_57); +x_58 = lean_ctor_get(x_55, 1); +lean_inc(x_58); +lean_dec(x_55); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_31); -lean_inc(x_53); -x_55 = l_Lean_Meta_isExprDefEq(x_53, x_31, x_8, x_9, x_10, x_11, x_52); -if (lean_obj_tag(x_55) == 0) -{ -lean_object* x_56; lean_object* x_57; lean_object* x_58; uint8_t x_93; -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); -x_93 = lean_unbox(x_56); -lean_dec(x_56); -if (x_93 == 0) +x_59 = l_Lean_Meta_isExprDefEq(x_57, x_31, x_8, x_9, x_10, x_11, x_56); +if (lean_obj_tag(x_59) == 0) { -lean_object* x_94; lean_object* x_95; lean_object* x_96; lean_object* x_97; lean_object* x_98; +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); +if (x_61 == 0) +{ +lean_object* x_62; lean_object* x_63; lean_object* x_64; lean_object* x_110; uint8_t x_111; lean_free_object(x_34); lean_free_object(x_25); -x_94 = l_Lean_Syntax_mkApp___closed__1; -lean_inc(x_53); -x_95 = lean_array_push(x_94, x_53); +x_62 = lean_ctor_get(x_59, 1); +lean_inc(x_62); +lean_dec(x_59); +x_63 = lean_ctor_get(x_10, 0); +lean_inc(x_63); +x_110 = l_Lean_Elab_Term_autoLift; +x_111 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_63, x_110); +if (x_111 == 0) +{ +lean_object* x_112; +lean_dec(x_63); +lean_dec(x_58); +lean_dec(x_57); +lean_dec(x_32); +lean_dec(x_31); +x_112 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_62); +lean_dec(x_7); +return x_112; +} +else +{ +lean_object* x_113; lean_object* x_114; lean_object* x_115; lean_object* x_116; lean_object* x_117; +x_113 = l_Lean_Syntax_mkApp___closed__1; +lean_inc(x_57); +x_114 = lean_array_push(x_113, x_57); lean_inc(x_31); -x_96 = lean_array_push(x_95, x_31); -x_97 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__2; +x_115 = lean_array_push(x_114, x_31); +x_116 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__2; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_98 = l_Lean_Meta_mkAppM(x_97, x_96, x_8, x_9, x_10, x_11, x_57); -if (lean_obj_tag(x_98) == 0) +x_117 = l_Lean_Meta_mkAppM(x_116, x_115, x_8, x_9, x_10, x_11, x_62); +if (lean_obj_tag(x_117) == 0) { -lean_object* x_99; lean_object* x_100; lean_object* x_101; -x_99 = lean_ctor_get(x_98, 0); -lean_inc(x_99); -x_100 = lean_ctor_get(x_98, 1); -lean_inc(x_100); -lean_dec(x_98); +lean_object* x_118; lean_object* x_119; lean_object* x_120; +x_118 = lean_ctor_get(x_117, 0); +lean_inc(x_118); +x_119 = lean_ctor_get(x_117, 1); +lean_inc(x_119); +lean_dec(x_117); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_6); -x_101 = l_Lean_Elab_Term_synthesizeInst(x_99, x_6, x_7, x_8, x_9, x_10, x_11, x_100); -if (lean_obj_tag(x_101) == 0) +x_120 = l_Lean_Elab_Term_synthesizeInst(x_118, x_6, x_7, x_8, x_9, x_10, x_11, x_119); +if (lean_obj_tag(x_120) == 0) { -lean_object* x_102; lean_object* x_103; lean_object* x_104; -x_102 = lean_ctor_get(x_101, 0); -lean_inc(x_102); -x_103 = lean_ctor_get(x_101, 1); -lean_inc(x_103); -lean_dec(x_101); +lean_object* x_121; lean_object* x_122; lean_object* x_123; +x_121 = lean_ctor_get(x_120, 0); +lean_inc(x_121); +x_122 = lean_ctor_get(x_120, 1); +lean_inc(x_122); +lean_dec(x_120); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -lean_inc(x_54); -x_104 = l_Lean_Meta_getDecLevel(x_54, x_8, x_9, x_10, x_11, x_103); -if (lean_obj_tag(x_104) == 0) +lean_inc(x_58); +x_123 = l_Lean_Meta_getDecLevel(x_58, x_8, x_9, x_10, x_11, x_122); +if (lean_obj_tag(x_123) == 0) { -lean_object* x_105; lean_object* x_106; lean_object* x_107; -x_105 = lean_ctor_get(x_104, 0); -lean_inc(x_105); -x_106 = lean_ctor_get(x_104, 1); -lean_inc(x_106); -lean_dec(x_104); +lean_object* x_124; lean_object* x_125; lean_object* x_126; +x_124 = lean_ctor_get(x_123, 0); +lean_inc(x_124); +x_125 = lean_ctor_get(x_123, 1); +lean_inc(x_125); +lean_dec(x_123); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_22); -x_107 = l_Lean_Meta_getDecLevel(x_22, x_8, x_9, x_10, x_11, x_106); -if (lean_obj_tag(x_107) == 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_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_19); -x_110 = l_Lean_Meta_getDecLevel(x_19, x_8, x_9, x_10, x_11, x_109); -if (lean_obj_tag(x_110) == 0) -{ -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; lean_object* x_122; lean_object* x_123; lean_object* x_124; lean_object* x_125; lean_object* x_126; -x_111 = lean_ctor_get(x_110, 0); -lean_inc(x_111); -x_112 = lean_ctor_get(x_110, 1); -lean_inc(x_112); -lean_dec(x_110); -x_113 = lean_box(0); -x_114 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_114, 0, x_111); -lean_ctor_set(x_114, 1, x_113); -x_115 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_115, 0, x_108); -lean_ctor_set(x_115, 1, x_114); -x_116 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_116, 0, x_105); -lean_ctor_set(x_116, 1, x_115); -x_117 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__4; -lean_inc(x_116); -x_118 = l_Lean_mkConst(x_117, x_116); -x_119 = l_Lean_Elab_Term_mkExplicitBinder___closed__1; -lean_inc(x_53); -x_120 = lean_array_push(x_119, x_53); -lean_inc(x_31); -x_121 = lean_array_push(x_120, x_31); -lean_inc(x_102); -x_122 = lean_array_push(x_121, x_102); -lean_inc(x_54); -x_123 = lean_array_push(x_122, x_54); -lean_inc(x_4); -x_124 = lean_array_push(x_123, x_4); -x_125 = l_Lean_mkAppN(x_118, x_124); -lean_dec(x_124); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_125); -x_126 = l_Lean_Meta_inferType(x_125, x_8, x_9, x_10, x_11, x_112); +x_126 = l_Lean_Meta_getDecLevel(x_22, x_8, x_9, x_10, x_11, x_125); if (lean_obj_tag(x_126) == 0) { lean_object* x_127; lean_object* x_128; lean_object* x_129; @@ -15030,38 +15072,92 @@ lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_19); -x_129 = l_Lean_Meta_isExprDefEq(x_19, x_127, x_8, x_9, x_10, x_11, x_128); +x_129 = l_Lean_Meta_getDecLevel(x_19, x_8, x_9, x_10, x_11, x_128); if (lean_obj_tag(x_129) == 0) { -lean_object* x_130; uint8_t x_131; +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; 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; x_130 = lean_ctor_get(x_129, 0); lean_inc(x_130); -x_131 = lean_unbox(x_130); -lean_dec(x_130); -if (x_131 == 0) -{ -lean_object* x_132; lean_object* x_133; lean_object* x_134; -lean_dec(x_125); -x_132 = lean_ctor_get(x_129, 1); -lean_inc(x_132); +x_131 = lean_ctor_get(x_129, 1); +lean_inc(x_131); lean_dec(x_129); +x_132 = lean_box(0); +x_133 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_133, 0, x_130); +lean_ctor_set(x_133, 1, x_132); +x_134 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_134, 0, x_127); +lean_ctor_set(x_134, 1, x_133); +x_135 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_135, 0, x_124); +lean_ctor_set(x_135, 1, x_134); +x_136 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__4; +lean_inc(x_135); +x_137 = l_Lean_mkConst(x_136, x_135); +x_138 = l_Lean_Elab_Term_mkExplicitBinder___closed__1; +lean_inc(x_57); +x_139 = lean_array_push(x_138, x_57); +lean_inc(x_31); +x_140 = lean_array_push(x_139, x_31); +lean_inc(x_121); +x_141 = lean_array_push(x_140, x_121); +lean_inc(x_58); +x_142 = lean_array_push(x_141, x_58); +lean_inc(x_4); +x_143 = lean_array_push(x_142, x_4); +x_144 = l_Lean_mkAppN(x_137, x_143); +lean_dec(x_143); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_144); +x_145 = l_Lean_Meta_inferType(x_144, x_8, x_9, x_10, x_11, x_131); +if (lean_obj_tag(x_145) == 0) +{ +lean_object* x_146; lean_object* x_147; lean_object* x_148; +x_146 = lean_ctor_get(x_145, 0); +lean_inc(x_146); +x_147 = lean_ctor_get(x_145, 1); +lean_inc(x_147); +lean_dec(x_145); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_19); +x_148 = l_Lean_Meta_isExprDefEq(x_19, x_146, x_8, x_9, x_10, x_11, x_147); +if (lean_obj_tag(x_148) == 0) +{ +lean_object* x_149; uint8_t x_150; +x_149 = lean_ctor_get(x_148, 0); +lean_inc(x_149); +x_150 = lean_unbox(x_149); +lean_dec(x_149); +if (x_150 == 0) +{ +lean_object* x_151; lean_object* x_152; lean_object* x_153; +lean_dec(x_144); +x_151 = lean_ctor_get(x_148, 1); +lean_inc(x_151); +lean_dec(x_148); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_31); -x_133 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_132); -x_134 = lean_ctor_get(x_133, 0); -lean_inc(x_134); -if (lean_obj_tag(x_134) == 0) +x_152 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_151); +x_153 = lean_ctor_get(x_152, 0); +lean_inc(x_153); +if (lean_obj_tag(x_153) == 0) { -lean_object* x_135; lean_object* x_136; -lean_dec(x_116); -lean_dec(x_102); -lean_dec(x_54); -x_135 = lean_ctor_get(x_133, 1); -lean_inc(x_135); -lean_dec(x_133); +lean_object* x_154; lean_object* x_155; +lean_dec(x_135); +lean_dec(x_121); +lean_dec(x_58); +x_154 = lean_ctor_get(x_152, 1); +lean_inc(x_154); +lean_dec(x_152); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -15072,11 +15168,12 @@ lean_inc(x_4); lean_inc(x_22); lean_inc(x_19); lean_inc(x_1); -x_136 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_135); -if (lean_obj_tag(x_136) == 0) +x_155 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_154); +if (lean_obj_tag(x_155) == 0) { -lean_object* x_137; lean_object* x_138; lean_object* x_139; lean_object* x_140; -lean_dec(x_53); +lean_object* x_156; lean_object* x_157; lean_object* x_158; lean_object* x_159; +lean_dec(x_63); +lean_dec(x_57); lean_dec(x_32); lean_dec(x_31); lean_dec(x_22); @@ -15090,166 +15187,166 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -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_box(0); -x_140 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_140, 0, x_137); -lean_ctor_set(x_140, 1, x_139); -x_13 = x_140; -x_14 = x_138; +x_156 = lean_ctor_get(x_155, 0); +lean_inc(x_156); +x_157 = lean_ctor_get(x_155, 1); +lean_inc(x_157); +lean_dec(x_155); +x_158 = lean_box(0); +x_159 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_159, 0, x_156); +lean_ctor_set(x_159, 1, x_158); +x_13 = x_159; +x_14 = x_157; goto block_17; } else { -lean_object* x_141; -x_141 = lean_ctor_get(x_136, 1); -lean_inc(x_141); -lean_dec(x_136); -x_58 = x_141; -goto block_92; +lean_object* x_160; +x_160 = lean_ctor_get(x_155, 1); +lean_inc(x_160); +lean_dec(x_155); +x_64 = x_160; +goto block_109; } } else { -lean_object* x_142; lean_object* x_143; lean_object* x_144; -x_142 = lean_ctor_get(x_133, 1); -lean_inc(x_142); -lean_dec(x_133); -x_143 = lean_ctor_get(x_134, 0); -lean_inc(x_143); -lean_dec(x_134); +lean_object* x_161; lean_object* x_162; lean_object* x_163; +x_161 = lean_ctor_get(x_152, 1); +lean_inc(x_161); +lean_dec(x_152); +x_162 = lean_ctor_get(x_153, 0); +lean_inc(x_162); +lean_dec(x_153); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -lean_inc(x_54); -x_144 = l_Lean_Meta_getLevel(x_54, x_8, x_9, x_10, x_11, x_142); -if (lean_obj_tag(x_144) == 0) -{ -lean_object* x_145; lean_object* x_146; lean_object* x_147; -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_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_32); -x_147 = l_Lean_Meta_getLevel(x_32, x_8, x_9, x_10, x_11, x_146); -if (lean_obj_tag(x_147) == 0) -{ -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; uint8_t x_161; lean_object* x_162; lean_object* x_163; -x_148 = lean_ctor_get(x_147, 0); -lean_inc(x_148); -x_149 = lean_ctor_get(x_147, 1); -lean_inc(x_149); -lean_dec(x_147); -x_150 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_150, 0, x_148); -lean_ctor_set(x_150, 1, x_113); -x_151 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_151, 0, x_145); -lean_ctor_set(x_151, 1, x_150); -x_152 = l_Lean_Meta_isCoeDecl___closed__34; -x_153 = l_Lean_mkConst(x_152, x_151); -x_154 = l_Lean_Syntax_mkAntiquotNode___closed__9; -lean_inc(x_54); -x_155 = lean_array_push(x_154, x_54); -x_156 = l_Lean_Meta_commitWhen___at___private_Lean_Meta_ExprDefEq_0__Lean_Meta_isDefEqEta___spec__1___closed__1; -x_157 = lean_array_push(x_155, x_156); -lean_inc(x_32); -x_158 = lean_array_push(x_157, x_32); -x_159 = l_Lean_mkAppN(x_153, x_158); -lean_dec(x_158); -x_160 = l_Array_myMacro____x40_Init_Data_Array_Subarray___hyg_932____closed__4; -x_161 = 0; -lean_inc(x_54); -x_162 = l_Lean_mkForall(x_160, x_161, x_54, x_159); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_6); -x_163 = l_Lean_Elab_Term_synthesizeInst(x_162, x_6, x_7, x_8, x_9, x_10, x_11, x_149); +lean_inc(x_58); +x_163 = l_Lean_Meta_getLevel(x_58, x_8, x_9, x_10, x_11, x_161); if (lean_obj_tag(x_163) == 0) { -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; lean_object* x_176; lean_object* x_177; lean_object* x_178; +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_isCoeDecl___closed__43; -x_167 = l_Lean_mkConst(x_166, x_116); -x_168 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__5; -lean_inc(x_53); -x_169 = lean_array_push(x_168, x_53); -lean_inc(x_31); -x_170 = lean_array_push(x_169, x_31); -x_171 = lean_array_push(x_170, x_54); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); lean_inc(x_32); -x_172 = lean_array_push(x_171, x_32); -x_173 = lean_array_push(x_172, x_102); -x_174 = lean_array_push(x_173, x_164); -x_175 = lean_array_push(x_174, x_143); -lean_inc(x_4); -x_176 = lean_array_push(x_175, x_4); -x_177 = l_Lean_mkAppN(x_167, x_176); -lean_dec(x_176); +x_166 = l_Lean_Meta_getLevel(x_32, x_8, x_9, x_10, x_11, x_165); +if (lean_obj_tag(x_166) == 0) +{ +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; uint8_t x_180; lean_object* x_181; lean_object* x_182; +x_167 = lean_ctor_get(x_166, 0); +lean_inc(x_167); +x_168 = lean_ctor_get(x_166, 1); +lean_inc(x_168); +lean_dec(x_166); +x_169 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_169, 0, x_167); +lean_ctor_set(x_169, 1, x_132); +x_170 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_170, 0, x_164); +lean_ctor_set(x_170, 1, x_169); +x_171 = l_Lean_Meta_isCoeDecl___closed__34; +x_172 = l_Lean_mkConst(x_171, x_170); +x_173 = l_Lean_Syntax_mkAntiquotNode___closed__9; +lean_inc(x_58); +x_174 = lean_array_push(x_173, x_58); +x_175 = l_Lean_Meta_commitWhen___at___private_Lean_Meta_ExprDefEq_0__Lean_Meta_isDefEqEta___spec__1___closed__1; +x_176 = lean_array_push(x_174, x_175); +lean_inc(x_32); +x_177 = lean_array_push(x_176, x_32); +x_178 = l_Lean_mkAppN(x_172, x_177); +lean_dec(x_177); +x_179 = l_Array_myMacro____x40_Init_Data_Array_Subarray___hyg_932____closed__4; +x_180 = 0; +lean_inc(x_58); +x_181 = l_Lean_mkForall(x_179, x_180, x_58, x_178); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_178 = l_Lean_Meta_expandCoe(x_177, x_8, x_9, x_10, x_11, x_165); -if (lean_obj_tag(x_178) == 0) +lean_inc(x_6); +x_182 = l_Lean_Elab_Term_synthesizeInst(x_181, x_6, x_7, x_8, x_9, x_10, x_11, x_168); +if (lean_obj_tag(x_182) == 0) { -lean_object* x_179; lean_object* x_180; lean_object* x_181; -x_179 = lean_ctor_get(x_178, 0); -lean_inc(x_179); -x_180 = lean_ctor_get(x_178, 1); -lean_inc(x_180); -lean_dec(x_178); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_179); -x_181 = l_Lean_Meta_inferType(x_179, x_8, x_9, x_10, x_11, x_180); -if (lean_obj_tag(x_181) == 0) -{ -lean_object* x_182; lean_object* x_183; lean_object* x_184; -x_182 = lean_ctor_get(x_181, 0); -lean_inc(x_182); -x_183 = lean_ctor_get(x_181, 1); +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; +x_183 = lean_ctor_get(x_182, 0); lean_inc(x_183); -lean_dec(x_181); +x_184 = lean_ctor_get(x_182, 1); +lean_inc(x_184); +lean_dec(x_182); +x_185 = l_Lean_Meta_isCoeDecl___closed__43; +x_186 = l_Lean_mkConst(x_185, x_135); +x_187 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__5; +lean_inc(x_57); +x_188 = lean_array_push(x_187, x_57); +lean_inc(x_31); +x_189 = lean_array_push(x_188, x_31); +x_190 = lean_array_push(x_189, x_58); +lean_inc(x_32); +x_191 = lean_array_push(x_190, x_32); +x_192 = lean_array_push(x_191, x_121); +x_193 = lean_array_push(x_192, x_183); +x_194 = lean_array_push(x_193, x_162); +lean_inc(x_4); +x_195 = lean_array_push(x_194, x_4); +x_196 = l_Lean_mkAppN(x_186, x_195); +lean_dec(x_195); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_197 = l_Lean_Meta_expandCoe(x_196, x_8, x_9, x_10, x_11, x_184); +if (lean_obj_tag(x_197) == 0) +{ +lean_object* x_198; lean_object* x_199; lean_object* x_200; +x_198 = lean_ctor_get(x_197, 0); +lean_inc(x_198); +x_199 = lean_ctor_get(x_197, 1); +lean_inc(x_199); +lean_dec(x_197); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_198); +x_200 = l_Lean_Meta_inferType(x_198, x_8, x_9, x_10, x_11, x_199); +if (lean_obj_tag(x_200) == 0) +{ +lean_object* x_201; lean_object* x_202; lean_object* x_203; +x_201 = lean_ctor_get(x_200, 0); +lean_inc(x_201); +x_202 = lean_ctor_get(x_200, 1); +lean_inc(x_202); +lean_dec(x_200); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_19); -x_184 = l_Lean_Meta_isExprDefEq(x_19, x_182, x_8, x_9, x_10, x_11, x_183); -if (lean_obj_tag(x_184) == 0) +x_203 = l_Lean_Meta_isExprDefEq(x_19, x_201, x_8, x_9, x_10, x_11, x_202); +if (lean_obj_tag(x_203) == 0) { -lean_object* x_185; uint8_t x_186; -x_185 = lean_ctor_get(x_184, 0); -lean_inc(x_185); -x_186 = lean_unbox(x_185); -lean_dec(x_185); -if (x_186 == 0) +lean_object* x_204; uint8_t x_205; +x_204 = lean_ctor_get(x_203, 0); +lean_inc(x_204); +x_205 = lean_unbox(x_204); +lean_dec(x_204); +if (x_205 == 0) { -lean_object* x_187; lean_object* x_188; lean_object* x_189; lean_object* x_190; -lean_dec(x_179); -x_187 = lean_ctor_get(x_184, 1); -lean_inc(x_187); -lean_dec(x_184); -x_188 = lean_box(0); +lean_object* x_206; lean_object* x_207; lean_object* x_208; lean_object* x_209; +lean_dec(x_198); +x_206 = lean_ctor_get(x_203, 1); +lean_inc(x_206); +lean_dec(x_203); +x_207 = lean_box(0); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -15259,315 +15356,132 @@ lean_inc(x_5); lean_inc(x_4); lean_inc(x_22); lean_inc(x_19); -x_189 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_188, x_6, x_7, x_8, x_9, x_10, x_11, x_187); -x_190 = lean_ctor_get(x_189, 1); -lean_inc(x_190); -lean_dec(x_189); -x_58 = x_190; -goto block_92; -} -else -{ -lean_object* x_191; lean_object* x_192; lean_object* x_193; lean_object* x_194; lean_object* x_195; -lean_dec(x_53); -lean_dec(x_32); -lean_dec(x_31); -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_191 = lean_ctor_get(x_184, 1); -lean_inc(x_191); -lean_dec(x_184); -x_192 = lean_box(0); -x_193 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___lambda__1(x_179, x_192, x_6, x_7, x_8, x_9, x_10, x_11, x_191); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -x_194 = lean_ctor_get(x_193, 0); -lean_inc(x_194); -x_195 = lean_ctor_get(x_193, 1); -lean_inc(x_195); -lean_dec(x_193); -x_13 = x_194; -x_14 = x_195; -goto block_17; -} -} -else -{ -lean_object* x_196; -lean_dec(x_179); -x_196 = lean_ctor_get(x_184, 1); -lean_inc(x_196); -lean_dec(x_184); -x_58 = x_196; -goto block_92; -} -} -else -{ -lean_object* x_197; -lean_dec(x_179); -x_197 = lean_ctor_get(x_181, 1); -lean_inc(x_197); -lean_dec(x_181); -x_58 = x_197; -goto block_92; -} -} -else -{ -lean_object* x_198; -x_198 = lean_ctor_get(x_178, 1); -lean_inc(x_198); -lean_dec(x_178); -x_58 = x_198; -goto block_92; -} -} -else -{ -lean_object* x_199; -lean_dec(x_143); -lean_dec(x_116); -lean_dec(x_102); -lean_dec(x_54); -x_199 = lean_ctor_get(x_163, 1); -lean_inc(x_199); -lean_dec(x_163); -x_58 = x_199; -goto block_92; -} -} -else -{ -lean_object* x_200; -lean_dec(x_145); -lean_dec(x_143); -lean_dec(x_116); -lean_dec(x_102); -lean_dec(x_54); -x_200 = lean_ctor_get(x_147, 1); -lean_inc(x_200); -lean_dec(x_147); -x_58 = x_200; -goto block_92; -} -} -else -{ -lean_object* x_201; -lean_dec(x_143); -lean_dec(x_116); -lean_dec(x_102); -lean_dec(x_54); -x_201 = lean_ctor_get(x_144, 1); -lean_inc(x_201); -lean_dec(x_144); -x_58 = x_201; -goto block_92; -} -} -} -else -{ -lean_object* x_202; lean_object* x_203; lean_object* x_204; -lean_dec(x_116); -lean_dec(x_102); -lean_dec(x_54); -lean_dec(x_53); -lean_dec(x_32); -lean_dec(x_31); -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_202 = lean_ctor_get(x_129, 1); -lean_inc(x_202); -lean_dec(x_129); -x_203 = lean_box(0); -x_204 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_204, 0, x_125); -lean_ctor_set(x_204, 1, x_203); -x_13 = x_204; -x_14 = x_202; -goto block_17; -} -} -else -{ -lean_object* x_205; -lean_dec(x_125); -lean_dec(x_116); -lean_dec(x_102); -lean_dec(x_54); -x_205 = lean_ctor_get(x_129, 1); -lean_inc(x_205); -lean_dec(x_129); -x_58 = x_205; -goto block_92; -} -} -else -{ -lean_object* x_206; -lean_dec(x_125); -lean_dec(x_116); -lean_dec(x_102); -lean_dec(x_54); -x_206 = lean_ctor_get(x_126, 1); -lean_inc(x_206); -lean_dec(x_126); -x_58 = x_206; -goto block_92; -} -} -else -{ -lean_object* x_207; -lean_dec(x_108); -lean_dec(x_105); -lean_dec(x_102); -lean_dec(x_54); -x_207 = lean_ctor_get(x_110, 1); -lean_inc(x_207); -lean_dec(x_110); -x_58 = x_207; -goto block_92; -} -} -else -{ -lean_object* x_208; -lean_dec(x_105); -lean_dec(x_102); -lean_dec(x_54); -x_208 = lean_ctor_get(x_107, 1); -lean_inc(x_208); -lean_dec(x_107); -x_58 = x_208; -goto block_92; -} -} -else -{ -lean_object* x_209; -lean_dec(x_102); -lean_dec(x_54); -x_209 = lean_ctor_get(x_104, 1); +x_208 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_207, x_6, x_7, x_8, x_9, x_10, x_11, x_206); +x_209 = lean_ctor_get(x_208, 1); lean_inc(x_209); -lean_dec(x_104); -x_58 = x_209; -goto block_92; -} +lean_dec(x_208); +x_64 = x_209; +goto block_109; } else { -lean_object* x_210; -lean_dec(x_54); -x_210 = lean_ctor_get(x_101, 1); +lean_object* x_210; lean_object* x_211; lean_object* x_212; lean_object* x_213; lean_object* x_214; +lean_dec(x_63); +lean_dec(x_57); +lean_dec(x_32); +lean_dec(x_31); +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_210 = lean_ctor_get(x_203, 1); lean_inc(x_210); -lean_dec(x_101); -x_58 = x_210; -goto block_92; -} -} -else -{ -lean_object* x_211; -lean_dec(x_54); -x_211 = lean_ctor_get(x_98, 1); -lean_inc(x_211); -lean_dec(x_98); -x_58 = x_211; -goto block_92; -} -} -else -{ -lean_object* x_212; lean_object* x_213; -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_212 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_57); +lean_dec(x_203); +x_211 = lean_box(0); +x_212 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___lambda__1(x_198, x_211, x_6, x_7, x_8, x_9, x_10, x_11, x_210); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); x_213 = lean_ctor_get(x_212, 0); lean_inc(x_213); -if (lean_obj_tag(x_213) == 0) -{ -lean_object* x_214; lean_object* x_215; -lean_dec(x_54); -lean_dec(x_53); -lean_free_object(x_34); -lean_dec(x_32); -lean_free_object(x_25); x_214 = lean_ctor_get(x_212, 1); lean_inc(x_214); lean_dec(x_212); -x_215 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_214); -lean_dec(x_7); -return x_215; +x_13 = x_213; +x_14 = x_214; +goto block_17; +} } else { -lean_object* x_216; uint8_t x_217; -x_216 = lean_ctor_get(x_212, 1); +lean_object* x_215; +lean_dec(x_198); +x_215 = lean_ctor_get(x_203, 1); +lean_inc(x_215); +lean_dec(x_203); +x_64 = x_215; +goto block_109; +} +} +else +{ +lean_object* x_216; +lean_dec(x_198); +x_216 = lean_ctor_get(x_200, 1); lean_inc(x_216); -lean_dec(x_212); -x_217 = !lean_is_exclusive(x_213); -if (x_217 == 0) +lean_dec(x_200); +x_64 = x_216; +goto block_109; +} +} +else { -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; lean_object* x_228; lean_object* x_229; lean_object* x_230; -x_218 = lean_ctor_get(x_213, 0); -lean_ctor_set(x_213, 0, x_53); -lean_ctor_set(x_34, 0, x_54); -lean_ctor_set(x_25, 0, x_32); -x_219 = lean_box(0); -x_220 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_220, 0, x_218); -lean_inc(x_4); -x_221 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_221, 0, x_4); -x_222 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; -x_223 = lean_array_push(x_222, x_213); -x_224 = lean_array_push(x_223, x_34); -x_225 = lean_array_push(x_224, x_25); -x_226 = lean_array_push(x_225, x_219); -x_227 = lean_array_push(x_226, x_220); -x_228 = lean_array_push(x_227, x_221); -x_229 = l_Lean_Meta_isCoeDecl___closed__45; -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_230 = l_Lean_Meta_mkAppOptM(x_229, x_228, x_8, x_9, x_10, x_11, x_216); -if (lean_obj_tag(x_230) == 0) +lean_object* x_217; +x_217 = lean_ctor_get(x_197, 1); +lean_inc(x_217); +lean_dec(x_197); +x_64 = x_217; +goto block_109; +} +} +else { -lean_object* x_231; lean_object* x_232; lean_object* x_233; -x_231 = lean_ctor_get(x_230, 0); -lean_inc(x_231); -x_232 = lean_ctor_get(x_230, 1); -lean_inc(x_232); -lean_dec(x_230); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_233 = l_Lean_Meta_expandCoe(x_231, x_8, x_9, x_10, x_11, x_232); -if (lean_obj_tag(x_233) == 0) +lean_object* x_218; +lean_dec(x_162); +lean_dec(x_135); +lean_dec(x_121); +lean_dec(x_58); +x_218 = lean_ctor_get(x_182, 1); +lean_inc(x_218); +lean_dec(x_182); +x_64 = x_218; +goto block_109; +} +} +else { +lean_object* x_219; +lean_dec(x_164); +lean_dec(x_162); +lean_dec(x_135); +lean_dec(x_121); +lean_dec(x_58); +x_219 = lean_ctor_get(x_166, 1); +lean_inc(x_219); +lean_dec(x_166); +x_64 = x_219; +goto block_109; +} +} +else +{ +lean_object* x_220; +lean_dec(x_162); +lean_dec(x_135); +lean_dec(x_121); +lean_dec(x_58); +x_220 = lean_ctor_get(x_163, 1); +lean_inc(x_220); +lean_dec(x_163); +x_64 = x_220; +goto block_109; +} +} +} +else +{ +lean_object* x_221; lean_object* x_222; lean_object* x_223; +lean_dec(x_135); +lean_dec(x_121); +lean_dec(x_63); +lean_dec(x_58); +lean_dec(x_57); +lean_dec(x_32); +lean_dec(x_31); lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -15579,131 +15493,175 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -return x_233; -} -else -{ -lean_object* x_234; lean_object* x_235; -x_234 = lean_ctor_get(x_233, 1); -lean_inc(x_234); -lean_dec(x_233); -x_235 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_219, x_6, x_7, x_8, x_9, x_10, x_11, x_234); -lean_dec(x_7); -lean_dec(x_1); -return x_235; +x_221 = lean_ctor_get(x_148, 1); +lean_inc(x_221); +lean_dec(x_148); +x_222 = lean_box(0); +x_223 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_223, 0, x_144); +lean_ctor_set(x_223, 1, x_222); +x_13 = x_223; +x_14 = x_221; +goto block_17; } } else { -lean_object* x_236; lean_object* x_237; -x_236 = lean_ctor_get(x_230, 1); -lean_inc(x_236); -lean_dec(x_230); -x_237 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_219, x_6, x_7, x_8, x_9, x_10, x_11, x_236); -lean_dec(x_7); -lean_dec(x_1); -return x_237; +lean_object* x_224; +lean_dec(x_144); +lean_dec(x_135); +lean_dec(x_121); +lean_dec(x_58); +x_224 = lean_ctor_get(x_148, 1); +lean_inc(x_224); +lean_dec(x_148); +x_64 = x_224; +goto block_109; } } else { -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_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; lean_object* x_251; -x_238 = lean_ctor_get(x_213, 0); -lean_inc(x_238); -lean_dec(x_213); -x_239 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_239, 0, x_53); -lean_ctor_set(x_34, 0, x_54); -lean_ctor_set(x_25, 0, x_32); -x_240 = lean_box(0); -x_241 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_241, 0, x_238); -lean_inc(x_4); -x_242 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_242, 0, x_4); -x_243 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; -x_244 = lean_array_push(x_243, x_239); -x_245 = lean_array_push(x_244, x_34); -x_246 = lean_array_push(x_245, x_25); -x_247 = lean_array_push(x_246, x_240); -x_248 = lean_array_push(x_247, x_241); -x_249 = lean_array_push(x_248, x_242); -x_250 = l_Lean_Meta_isCoeDecl___closed__45; +lean_object* x_225; +lean_dec(x_144); +lean_dec(x_135); +lean_dec(x_121); +lean_dec(x_58); +x_225 = lean_ctor_get(x_145, 1); +lean_inc(x_225); +lean_dec(x_145); +x_64 = x_225; +goto block_109; +} +} +else +{ +lean_object* x_226; +lean_dec(x_127); +lean_dec(x_124); +lean_dec(x_121); +lean_dec(x_58); +x_226 = lean_ctor_get(x_129, 1); +lean_inc(x_226); +lean_dec(x_129); +x_64 = x_226; +goto block_109; +} +} +else +{ +lean_object* x_227; +lean_dec(x_124); +lean_dec(x_121); +lean_dec(x_58); +x_227 = lean_ctor_get(x_126, 1); +lean_inc(x_227); +lean_dec(x_126); +x_64 = x_227; +goto block_109; +} +} +else +{ +lean_object* x_228; +lean_dec(x_121); +lean_dec(x_58); +x_228 = lean_ctor_get(x_123, 1); +lean_inc(x_228); +lean_dec(x_123); +x_64 = x_228; +goto block_109; +} +} +else +{ +lean_object* x_229; +lean_dec(x_58); +x_229 = lean_ctor_get(x_120, 1); +lean_inc(x_229); +lean_dec(x_120); +x_64 = x_229; +goto block_109; +} +} +else +{ +lean_object* x_230; +lean_dec(x_58); +x_230 = lean_ctor_get(x_117, 1); +lean_inc(x_230); +lean_dec(x_117); +x_64 = x_230; +goto block_109; +} +} +block_109: +{ +lean_object* x_65; lean_object* x_66; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_251 = l_Lean_Meta_mkAppOptM(x_250, x_249, x_8, x_9, x_10, x_11, x_216); -if (lean_obj_tag(x_251) == 0) +x_65 = l_Lean_Meta_isMonad_x3f(x_57, x_8, x_9, x_10, x_11, x_64); +x_66 = lean_ctor_get(x_65, 0); +lean_inc(x_66); +if (lean_obj_tag(x_66) == 0) { -lean_object* x_252; lean_object* x_253; lean_object* x_254; -x_252 = lean_ctor_get(x_251, 0); -lean_inc(x_252); -x_253 = lean_ctor_get(x_251, 1); -lean_inc(x_253); -lean_dec(x_251); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_254 = l_Lean_Meta_expandCoe(x_252, x_8, x_9, x_10, x_11, x_253); -if (lean_obj_tag(x_254) == 0) +lean_object* x_67; lean_object* x_68; uint8_t x_69; +x_67 = lean_ctor_get(x_65, 1); +lean_inc(x_67); +lean_dec(x_65); +x_68 = l_Lean_Elab_Term_autoLift; +x_69 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_63, x_68); +lean_dec(x_63); +if (x_69 == 0) { -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); +lean_object* x_70; +lean_dec(x_32); +lean_dec(x_31); +x_70 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_67); lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -return x_254; +if (lean_obj_tag(x_70) == 0) +{ +lean_object* x_71; lean_object* x_72; lean_object* x_73; lean_object* x_74; +x_71 = lean_ctor_get(x_70, 0); +lean_inc(x_71); +x_72 = lean_ctor_get(x_70, 1); +lean_inc(x_72); +lean_dec(x_70); +x_73 = lean_box(0); +x_74 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_74, 0, x_71); +lean_ctor_set(x_74, 1, x_73); +x_13 = x_74; +x_14 = x_72; +goto block_17; } else { -lean_object* x_255; lean_object* x_256; -x_255 = lean_ctor_get(x_254, 1); -lean_inc(x_255); -lean_dec(x_254); -x_256 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_240, x_6, x_7, x_8, x_9, x_10, x_11, x_255); -lean_dec(x_7); -lean_dec(x_1); -return x_256; +uint8_t x_75; +x_75 = !lean_is_exclusive(x_70); +if (x_75 == 0) +{ +return x_70; +} +else +{ +lean_object* x_76; lean_object* x_77; lean_object* x_78; +x_76 = lean_ctor_get(x_70, 0); +x_77 = lean_ctor_get(x_70, 1); +lean_inc(x_77); +lean_inc(x_76); +lean_dec(x_70); +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_257; lean_object* x_258; -x_257 = lean_ctor_get(x_251, 1); -lean_inc(x_257); -lean_dec(x_251); -x_258 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_240, x_6, x_7, x_8, x_9, x_10, x_11, x_257); -lean_dec(x_7); -lean_dec(x_1); -return x_258; -} -} -} -} -block_92: -{ -lean_object* x_59; lean_object* x_60; -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_59 = l_Lean_Meta_isMonad_x3f(x_53, x_8, x_9, x_10, x_11, x_58); -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; -x_61 = lean_ctor_get(x_59, 1); -lean_inc(x_61); -lean_dec(x_59); +lean_object* x_79; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -15713,169 +15671,171 @@ lean_inc(x_6); lean_inc(x_4); lean_inc(x_22); lean_inc(x_1); -x_62 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_31, x_32, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_61); -if (lean_obj_tag(x_62) == 0) +x_79 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_31, x_32, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_67); +if (lean_obj_tag(x_79) == 0) { -lean_object* x_63; -x_63 = lean_ctor_get(x_62, 0); -lean_inc(x_63); -if (lean_obj_tag(x_63) == 0) -{ -lean_object* x_64; lean_object* x_65; -x_64 = lean_ctor_get(x_62, 1); -lean_inc(x_64); -lean_dec(x_62); -x_65 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_64); -lean_dec(x_7); -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); -lean_dec(x_65); -x_68 = lean_box(0); -x_69 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_69, 0, x_66); -lean_ctor_set(x_69, 1, x_68); -x_13 = x_69; -x_14 = x_67; -goto block_17; -} -else -{ -uint8_t x_70; -x_70 = !lean_is_exclusive(x_65); -if (x_70 == 0) -{ -return x_65; -} -else -{ -lean_object* x_71; lean_object* x_72; lean_object* x_73; -x_71 = lean_ctor_get(x_65, 0); -x_72 = lean_ctor_get(x_65, 1); -lean_inc(x_72); -lean_inc(x_71); -lean_dec(x_65); -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_74; lean_object* x_75; lean_object* x_76; lean_object* x_77; -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_74 = lean_ctor_get(x_62, 1); -lean_inc(x_74); -lean_dec(x_62); -x_75 = lean_ctor_get(x_63, 0); -lean_inc(x_75); -lean_dec(x_63); -x_76 = lean_box(0); -x_77 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_77, 0, x_75); -lean_ctor_set(x_77, 1, x_76); -x_13 = x_77; -x_14 = x_74; -goto block_17; -} -} -else -{ -uint8_t x_78; -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_78 = !lean_is_exclusive(x_62); -if (x_78 == 0) -{ -return x_62; -} -else -{ -lean_object* x_79; lean_object* x_80; lean_object* x_81; -x_79 = lean_ctor_get(x_62, 0); -x_80 = lean_ctor_get(x_62, 1); +lean_object* x_80; +x_80 = lean_ctor_get(x_79, 0); lean_inc(x_80); -lean_inc(x_79); -lean_dec(x_62); -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; +if (lean_obj_tag(x_80) == 0) +{ +lean_object* x_81; lean_object* x_82; +x_81 = lean_ctor_get(x_79, 1); +lean_inc(x_81); +lean_dec(x_79); +x_82 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_81); +lean_dec(x_7); +if (lean_obj_tag(x_82) == 0) +{ +lean_object* x_83; lean_object* x_84; lean_object* x_85; lean_object* x_86; +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_box(0); +x_86 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_86, 0, x_83); +lean_ctor_set(x_86, 1, x_85); +x_13 = x_86; +x_14 = x_84; +goto block_17; +} +else +{ +uint8_t x_87; +x_87 = !lean_is_exclusive(x_82); +if (x_87 == 0) +{ +return x_82; +} +else +{ +lean_object* x_88; lean_object* x_89; lean_object* x_90; +x_88 = lean_ctor_get(x_82, 0); +x_89 = lean_ctor_get(x_82, 1); +lean_inc(x_89); +lean_inc(x_88); +lean_dec(x_82); +x_90 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_90, 0, x_88); +lean_ctor_set(x_90, 1, x_89); +return x_90; } } } else { -lean_object* x_82; lean_object* x_83; -lean_dec(x_60); +lean_object* x_91; lean_object* x_92; lean_object* x_93; lean_object* x_94; +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +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_1); +x_91 = lean_ctor_get(x_79, 1); +lean_inc(x_91); +lean_dec(x_79); +x_92 = lean_ctor_get(x_80, 0); +lean_inc(x_92); +lean_dec(x_80); +x_93 = lean_box(0); +x_94 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_94, 0, x_92); +lean_ctor_set(x_94, 1, x_93); +x_13 = x_94; +x_14 = x_91; +goto block_17; +} +} +else +{ +uint8_t x_95; +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +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_1); +x_95 = !lean_is_exclusive(x_79); +if (x_95 == 0) +{ +return x_79; +} +else +{ +lean_object* x_96; lean_object* x_97; lean_object* x_98; +x_96 = lean_ctor_get(x_79, 0); +x_97 = lean_ctor_get(x_79, 1); +lean_inc(x_97); +lean_inc(x_96); +lean_dec(x_79); +x_98 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_98, 0, x_96); +lean_ctor_set(x_98, 1, x_97); +return x_98; +} +} +} +} +else +{ +lean_object* x_99; lean_object* x_100; +lean_dec(x_66); +lean_dec(x_63); lean_dec(x_32); lean_dec(x_31); -x_82 = lean_ctor_get(x_59, 1); -lean_inc(x_82); -lean_dec(x_59); -x_83 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_82); +x_99 = lean_ctor_get(x_65, 1); +lean_inc(x_99); +lean_dec(x_65); +x_100 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_99); lean_dec(x_7); -if (lean_obj_tag(x_83) == 0) +if (lean_obj_tag(x_100) == 0) { -lean_object* x_84; lean_object* x_85; lean_object* x_86; lean_object* x_87; -x_84 = lean_ctor_get(x_83, 0); -lean_inc(x_84); -x_85 = lean_ctor_get(x_83, 1); -lean_inc(x_85); -lean_dec(x_83); -x_86 = lean_box(0); -x_87 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_87, 0, x_84); -lean_ctor_set(x_87, 1, x_86); -x_13 = x_87; -x_14 = x_85; +lean_object* x_101; lean_object* x_102; lean_object* x_103; lean_object* x_104; +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 = lean_box(0); +x_104 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_104, 0, x_101); +lean_ctor_set(x_104, 1, x_103); +x_13 = x_104; +x_14 = x_102; goto block_17; } else { -uint8_t x_88; -x_88 = !lean_is_exclusive(x_83); -if (x_88 == 0) +uint8_t x_105; +x_105 = !lean_is_exclusive(x_100); +if (x_105 == 0) { -return x_83; +return x_100; } else { -lean_object* x_89; lean_object* x_90; lean_object* x_91; -x_89 = lean_ctor_get(x_83, 0); -x_90 = lean_ctor_get(x_83, 1); -lean_inc(x_90); -lean_inc(x_89); -lean_dec(x_83); -x_91 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_91, 0, x_89); -lean_ctor_set(x_91, 1, x_90); -return x_91; +lean_object* x_106; lean_object* x_107; lean_object* x_108; +x_106 = lean_ctor_get(x_100, 0); +x_107 = lean_ctor_get(x_100, 1); +lean_inc(x_107); +lean_inc(x_106); +lean_dec(x_100); +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; } } } @@ -15883,9 +15843,206 @@ return x_91; } else { -uint8_t x_259; -lean_dec(x_54); -lean_dec(x_53); +lean_object* x_231; lean_object* x_232; lean_object* x_233; +x_231 = lean_ctor_get(x_59, 1); +lean_inc(x_231); +lean_dec(x_59); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_232 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_231); +x_233 = lean_ctor_get(x_232, 0); +lean_inc(x_233); +if (lean_obj_tag(x_233) == 0) +{ +lean_object* x_234; lean_object* x_235; +lean_dec(x_58); +lean_dec(x_57); +lean_free_object(x_34); +lean_dec(x_32); +lean_free_object(x_25); +x_234 = lean_ctor_get(x_232, 1); +lean_inc(x_234); +lean_dec(x_232); +x_235 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_234); +lean_dec(x_7); +return x_235; +} +else +{ +lean_object* x_236; uint8_t x_237; +x_236 = lean_ctor_get(x_232, 1); +lean_inc(x_236); +lean_dec(x_232); +x_237 = !lean_is_exclusive(x_233); +if (x_237 == 0) +{ +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_object* x_244; lean_object* x_245; lean_object* x_246; lean_object* x_247; lean_object* x_248; lean_object* x_249; lean_object* x_250; +x_238 = lean_ctor_get(x_233, 0); +lean_ctor_set(x_233, 0, x_57); +lean_ctor_set(x_34, 0, x_58); +lean_ctor_set(x_25, 0, x_32); +x_239 = lean_box(0); +x_240 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_240, 0, x_238); +lean_inc(x_4); +x_241 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_241, 0, x_4); +x_242 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; +x_243 = lean_array_push(x_242, x_233); +x_244 = lean_array_push(x_243, x_34); +x_245 = lean_array_push(x_244, x_25); +x_246 = lean_array_push(x_245, x_239); +x_247 = lean_array_push(x_246, x_240); +x_248 = lean_array_push(x_247, x_241); +x_249 = l_Lean_Meta_isCoeDecl___closed__45; +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_250 = l_Lean_Meta_mkAppOptM(x_249, x_248, x_8, x_9, x_10, x_11, x_236); +if (lean_obj_tag(x_250) == 0) +{ +lean_object* x_251; lean_object* x_252; lean_object* x_253; +x_251 = lean_ctor_get(x_250, 0); +lean_inc(x_251); +x_252 = lean_ctor_get(x_250, 1); +lean_inc(x_252); +lean_dec(x_250); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_253 = l_Lean_Meta_expandCoe(x_251, x_8, x_9, x_10, x_11, x_252); +if (lean_obj_tag(x_253) == 0) +{ +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +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_1); +return x_253; +} +else +{ +lean_object* x_254; lean_object* x_255; +x_254 = lean_ctor_get(x_253, 1); +lean_inc(x_254); +lean_dec(x_253); +x_255 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_239, x_6, x_7, x_8, x_9, x_10, x_11, x_254); +lean_dec(x_7); +lean_dec(x_1); +return x_255; +} +} +else +{ +lean_object* x_256; lean_object* x_257; +x_256 = lean_ctor_get(x_250, 1); +lean_inc(x_256); +lean_dec(x_250); +x_257 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_239, x_6, x_7, x_8, x_9, x_10, x_11, x_256); +lean_dec(x_7); +lean_dec(x_1); +return x_257; +} +} +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; 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; +x_258 = lean_ctor_get(x_233, 0); +lean_inc(x_258); +lean_dec(x_233); +x_259 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_259, 0, x_57); +lean_ctor_set(x_34, 0, x_58); +lean_ctor_set(x_25, 0, x_32); +x_260 = lean_box(0); +x_261 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_261, 0, x_258); +lean_inc(x_4); +x_262 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_262, 0, x_4); +x_263 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; +x_264 = lean_array_push(x_263, x_259); +x_265 = lean_array_push(x_264, x_34); +x_266 = lean_array_push(x_265, x_25); +x_267 = lean_array_push(x_266, x_260); +x_268 = lean_array_push(x_267, x_261); +x_269 = lean_array_push(x_268, x_262); +x_270 = l_Lean_Meta_isCoeDecl___closed__45; +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_271 = l_Lean_Meta_mkAppOptM(x_270, x_269, x_8, x_9, x_10, x_11, x_236); +if (lean_obj_tag(x_271) == 0) +{ +lean_object* x_272; lean_object* x_273; lean_object* x_274; +x_272 = lean_ctor_get(x_271, 0); +lean_inc(x_272); +x_273 = lean_ctor_get(x_271, 1); +lean_inc(x_273); +lean_dec(x_271); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_274 = l_Lean_Meta_expandCoe(x_272, x_8, x_9, x_10, x_11, x_273); +if (lean_obj_tag(x_274) == 0) +{ +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +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_1); +return x_274; +} +else +{ +lean_object* x_275; lean_object* x_276; +x_275 = lean_ctor_get(x_274, 1); +lean_inc(x_275); +lean_dec(x_274); +x_276 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_260, x_6, x_7, x_8, x_9, x_10, x_11, x_275); +lean_dec(x_7); +lean_dec(x_1); +return x_276; +} +} +else +{ +lean_object* x_277; lean_object* x_278; +x_277 = lean_ctor_get(x_271, 1); +lean_inc(x_277); +lean_dec(x_271); +x_278 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_260, x_6, x_7, x_8, x_9, x_10, x_11, x_277); +lean_dec(x_7); +lean_dec(x_1); +return x_278; +} +} +} +} +} +else +{ +uint8_t x_279; +lean_dec(x_58); +lean_dec(x_57); lean_free_object(x_34); lean_dec(x_32); lean_dec(x_31); @@ -15901,210 +16058,96 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_259 = !lean_is_exclusive(x_55); -if (x_259 == 0) +x_279 = !lean_is_exclusive(x_59); +if (x_279 == 0) { -return x_55; +return x_59; } else { -lean_object* x_260; lean_object* x_261; lean_object* x_262; -x_260 = lean_ctor_get(x_55, 0); -x_261 = lean_ctor_get(x_55, 1); -lean_inc(x_261); -lean_inc(x_260); -lean_dec(x_55); -x_262 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_262, 0, x_260); -lean_ctor_set(x_262, 1, x_261); -return x_262; +lean_object* x_280; lean_object* x_281; lean_object* x_282; +x_280 = lean_ctor_get(x_59, 0); +x_281 = lean_ctor_get(x_59, 1); +lean_inc(x_281); +lean_inc(x_280); +lean_dec(x_59); +x_282 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_282, 0, x_280); +lean_ctor_set(x_282, 1, x_281); +return x_282; } } } else { -lean_object* x_263; lean_object* x_264; lean_object* x_265; lean_object* x_266; lean_object* x_267; -x_263 = lean_ctor_get(x_34, 0); -lean_inc(x_263); +lean_object* x_283; lean_object* x_284; lean_object* x_285; lean_object* x_286; lean_object* x_287; +x_283 = lean_ctor_get(x_34, 0); +lean_inc(x_283); lean_dec(x_34); -x_264 = lean_ctor_get(x_33, 1); -lean_inc(x_264); +x_284 = lean_ctor_get(x_33, 1); +lean_inc(x_284); lean_dec(x_33); -x_265 = lean_ctor_get(x_263, 0); -lean_inc(x_265); -x_266 = lean_ctor_get(x_263, 1); -lean_inc(x_266); -lean_dec(x_263); +x_285 = lean_ctor_get(x_283, 0); +lean_inc(x_285); +x_286 = lean_ctor_get(x_283, 1); +lean_inc(x_286); +lean_dec(x_283); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_31); -lean_inc(x_265); -x_267 = l_Lean_Meta_isExprDefEq(x_265, x_31, x_8, x_9, x_10, x_11, x_264); -if (lean_obj_tag(x_267) == 0) +lean_inc(x_285); +x_287 = l_Lean_Meta_isExprDefEq(x_285, x_31, x_8, x_9, x_10, x_11, x_284); +if (lean_obj_tag(x_287) == 0) { -lean_object* x_268; lean_object* x_269; lean_object* x_270; uint8_t x_305; -x_268 = lean_ctor_get(x_267, 0); -lean_inc(x_268); -x_269 = lean_ctor_get(x_267, 1); -lean_inc(x_269); -lean_dec(x_267); -x_305 = lean_unbox(x_268); -lean_dec(x_268); -if (x_305 == 0) +lean_object* x_288; uint8_t x_289; +x_288 = lean_ctor_get(x_287, 0); +lean_inc(x_288); +x_289 = lean_unbox(x_288); +lean_dec(x_288); +if (x_289 == 0) { -lean_object* x_306; lean_object* x_307; lean_object* x_308; lean_object* x_309; lean_object* x_310; +lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_338; uint8_t x_339; lean_free_object(x_25); -x_306 = l_Lean_Syntax_mkApp___closed__1; -lean_inc(x_265); -x_307 = lean_array_push(x_306, x_265); +x_290 = lean_ctor_get(x_287, 1); +lean_inc(x_290); +lean_dec(x_287); +x_291 = lean_ctor_get(x_10, 0); +lean_inc(x_291); +x_338 = l_Lean_Elab_Term_autoLift; +x_339 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_291, x_338); +if (x_339 == 0) +{ +lean_object* x_340; +lean_dec(x_291); +lean_dec(x_286); +lean_dec(x_285); +lean_dec(x_32); +lean_dec(x_31); +x_340 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_290); +lean_dec(x_7); +return x_340; +} +else +{ +lean_object* x_341; lean_object* x_342; lean_object* x_343; lean_object* x_344; lean_object* x_345; +x_341 = l_Lean_Syntax_mkApp___closed__1; +lean_inc(x_285); +x_342 = lean_array_push(x_341, x_285); lean_inc(x_31); -x_308 = lean_array_push(x_307, x_31); -x_309 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__2; +x_343 = lean_array_push(x_342, x_31); +x_344 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__2; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_310 = l_Lean_Meta_mkAppM(x_309, x_308, x_8, x_9, x_10, x_11, x_269); -if (lean_obj_tag(x_310) == 0) +x_345 = l_Lean_Meta_mkAppM(x_344, x_343, x_8, x_9, x_10, x_11, x_290); +if (lean_obj_tag(x_345) == 0) { -lean_object* x_311; lean_object* x_312; lean_object* x_313; -x_311 = lean_ctor_get(x_310, 0); -lean_inc(x_311); -x_312 = lean_ctor_get(x_310, 1); -lean_inc(x_312); -lean_dec(x_310); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_6); -x_313 = l_Lean_Elab_Term_synthesizeInst(x_311, x_6, x_7, x_8, x_9, x_10, x_11, x_312); -if (lean_obj_tag(x_313) == 0) -{ -lean_object* x_314; lean_object* x_315; lean_object* x_316; -x_314 = lean_ctor_get(x_313, 0); -lean_inc(x_314); -x_315 = lean_ctor_get(x_313, 1); -lean_inc(x_315); -lean_dec(x_313); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_266); -x_316 = l_Lean_Meta_getDecLevel(x_266, x_8, x_9, x_10, x_11, x_315); -if (lean_obj_tag(x_316) == 0) -{ -lean_object* x_317; lean_object* x_318; lean_object* x_319; -x_317 = lean_ctor_get(x_316, 0); -lean_inc(x_317); -x_318 = lean_ctor_get(x_316, 1); -lean_inc(x_318); -lean_dec(x_316); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_22); -x_319 = l_Lean_Meta_getDecLevel(x_22, x_8, x_9, x_10, x_11, x_318); -if (lean_obj_tag(x_319) == 0) -{ -lean_object* x_320; lean_object* x_321; lean_object* x_322; -x_320 = lean_ctor_get(x_319, 0); -lean_inc(x_320); -x_321 = lean_ctor_get(x_319, 1); -lean_inc(x_321); -lean_dec(x_319); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_19); -x_322 = l_Lean_Meta_getDecLevel(x_19, x_8, x_9, x_10, x_11, x_321); -if (lean_obj_tag(x_322) == 0) -{ -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; lean_object* x_335; lean_object* x_336; lean_object* x_337; lean_object* x_338; -x_323 = lean_ctor_get(x_322, 0); -lean_inc(x_323); -x_324 = lean_ctor_get(x_322, 1); -lean_inc(x_324); -lean_dec(x_322); -x_325 = lean_box(0); -x_326 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_326, 0, x_323); -lean_ctor_set(x_326, 1, x_325); -x_327 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_327, 0, x_320); -lean_ctor_set(x_327, 1, x_326); -x_328 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_328, 0, x_317); -lean_ctor_set(x_328, 1, x_327); -x_329 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__4; -lean_inc(x_328); -x_330 = l_Lean_mkConst(x_329, x_328); -x_331 = l_Lean_Elab_Term_mkExplicitBinder___closed__1; -lean_inc(x_265); -x_332 = lean_array_push(x_331, x_265); -lean_inc(x_31); -x_333 = lean_array_push(x_332, x_31); -lean_inc(x_314); -x_334 = lean_array_push(x_333, x_314); -lean_inc(x_266); -x_335 = lean_array_push(x_334, x_266); -lean_inc(x_4); -x_336 = lean_array_push(x_335, x_4); -x_337 = l_Lean_mkAppN(x_330, x_336); -lean_dec(x_336); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_337); -x_338 = l_Lean_Meta_inferType(x_337, x_8, x_9, x_10, x_11, x_324); -if (lean_obj_tag(x_338) == 0) -{ -lean_object* x_339; lean_object* x_340; lean_object* x_341; -x_339 = lean_ctor_get(x_338, 0); -lean_inc(x_339); -x_340 = lean_ctor_get(x_338, 1); -lean_inc(x_340); -lean_dec(x_338); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_19); -x_341 = l_Lean_Meta_isExprDefEq(x_19, x_339, x_8, x_9, x_10, x_11, x_340); -if (lean_obj_tag(x_341) == 0) -{ -lean_object* x_342; uint8_t x_343; -x_342 = lean_ctor_get(x_341, 0); -lean_inc(x_342); -x_343 = lean_unbox(x_342); -lean_dec(x_342); -if (x_343 == 0) -{ -lean_object* x_344; lean_object* x_345; lean_object* x_346; -lean_dec(x_337); -x_344 = lean_ctor_get(x_341, 1); -lean_inc(x_344); -lean_dec(x_341); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_31); -x_345 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_344); +lean_object* x_346; lean_object* x_347; lean_object* x_348; x_346 = lean_ctor_get(x_345, 0); lean_inc(x_346); -if (lean_obj_tag(x_346) == 0) -{ -lean_object* x_347; lean_object* x_348; -lean_dec(x_328); -lean_dec(x_314); -lean_dec(x_266); x_347 = lean_ctor_get(x_345, 1); lean_inc(x_347); lean_dec(x_345); @@ -16113,189 +16156,134 @@ lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_6); -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_22); -lean_inc(x_19); -lean_inc(x_1); -x_348 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_347); +x_348 = l_Lean_Elab_Term_synthesizeInst(x_346, x_6, x_7, x_8, x_9, x_10, x_11, x_347); if (lean_obj_tag(x_348) == 0) { -lean_object* x_349; lean_object* x_350; lean_object* x_351; lean_object* x_352; -lean_dec(x_265); -lean_dec(x_32); -lean_dec(x_31); -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -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_1); +lean_object* x_349; lean_object* x_350; lean_object* x_351; 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); -x_351 = lean_box(0); -x_352 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_352, 0, x_349); -lean_ctor_set(x_352, 1, x_351); -x_13 = x_352; -x_14 = x_350; -goto block_17; -} -else +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_286); +x_351 = l_Lean_Meta_getDecLevel(x_286, x_8, x_9, x_10, x_11, x_350); +if (lean_obj_tag(x_351) == 0) { -lean_object* x_353; -x_353 = lean_ctor_get(x_348, 1); +lean_object* x_352; lean_object* x_353; lean_object* x_354; +x_352 = lean_ctor_get(x_351, 0); +lean_inc(x_352); +x_353 = lean_ctor_get(x_351, 1); lean_inc(x_353); -lean_dec(x_348); -x_270 = x_353; -goto block_304; -} -} -else +lean_dec(x_351); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_22); +x_354 = l_Lean_Meta_getDecLevel(x_22, x_8, x_9, x_10, x_11, x_353); +if (lean_obj_tag(x_354) == 0) { -lean_object* x_354; lean_object* x_355; lean_object* x_356; -x_354 = lean_ctor_get(x_345, 1); -lean_inc(x_354); -lean_dec(x_345); -x_355 = lean_ctor_get(x_346, 0); +lean_object* x_355; lean_object* x_356; lean_object* x_357; +x_355 = lean_ctor_get(x_354, 0); lean_inc(x_355); -lean_dec(x_346); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_266); -x_356 = l_Lean_Meta_getLevel(x_266, x_8, x_9, x_10, x_11, x_354); -if (lean_obj_tag(x_356) == 0) -{ -lean_object* x_357; lean_object* x_358; lean_object* x_359; -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_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_32); -x_359 = l_Lean_Meta_getLevel(x_32, x_8, x_9, x_10, x_11, x_358); -if (lean_obj_tag(x_359) == 0) -{ -lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; uint8_t x_373; lean_object* x_374; lean_object* x_375; -x_360 = lean_ctor_get(x_359, 0); -lean_inc(x_360); -x_361 = lean_ctor_get(x_359, 1); -lean_inc(x_361); -lean_dec(x_359); -x_362 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_362, 0, x_360); -lean_ctor_set(x_362, 1, x_325); -x_363 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_363, 0, x_357); -lean_ctor_set(x_363, 1, x_362); -x_364 = l_Lean_Meta_isCoeDecl___closed__34; -x_365 = l_Lean_mkConst(x_364, x_363); -x_366 = l_Lean_Syntax_mkAntiquotNode___closed__9; -lean_inc(x_266); -x_367 = lean_array_push(x_366, x_266); -x_368 = l_Lean_Meta_commitWhen___at___private_Lean_Meta_ExprDefEq_0__Lean_Meta_isDefEqEta___spec__1___closed__1; -x_369 = lean_array_push(x_367, x_368); -lean_inc(x_32); -x_370 = lean_array_push(x_369, x_32); -x_371 = l_Lean_mkAppN(x_365, x_370); -lean_dec(x_370); -x_372 = l_Array_myMacro____x40_Init_Data_Array_Subarray___hyg_932____closed__4; -x_373 = 0; -lean_inc(x_266); -x_374 = l_Lean_mkForall(x_372, x_373, x_266, x_371); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_6); -x_375 = l_Lean_Elab_Term_synthesizeInst(x_374, x_6, x_7, x_8, x_9, x_10, x_11, x_361); -if (lean_obj_tag(x_375) == 0) -{ -lean_object* x_376; lean_object* x_377; lean_object* x_378; lean_object* x_379; lean_object* x_380; lean_object* x_381; lean_object* x_382; 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_object* x_389; lean_object* x_390; -x_376 = lean_ctor_get(x_375, 0); -lean_inc(x_376); -x_377 = lean_ctor_get(x_375, 1); -lean_inc(x_377); -lean_dec(x_375); -x_378 = l_Lean_Meta_isCoeDecl___closed__43; -x_379 = l_Lean_mkConst(x_378, x_328); -x_380 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__5; -lean_inc(x_265); -x_381 = lean_array_push(x_380, x_265); -lean_inc(x_31); -x_382 = lean_array_push(x_381, x_31); -x_383 = lean_array_push(x_382, x_266); -lean_inc(x_32); -x_384 = lean_array_push(x_383, x_32); -x_385 = lean_array_push(x_384, x_314); -x_386 = lean_array_push(x_385, x_376); -x_387 = lean_array_push(x_386, x_355); -lean_inc(x_4); -x_388 = lean_array_push(x_387, x_4); -x_389 = l_Lean_mkAppN(x_379, x_388); -lean_dec(x_388); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_390 = l_Lean_Meta_expandCoe(x_389, x_8, x_9, x_10, x_11, x_377); -if (lean_obj_tag(x_390) == 0) -{ -lean_object* x_391; lean_object* x_392; lean_object* x_393; -x_391 = lean_ctor_get(x_390, 0); -lean_inc(x_391); -x_392 = lean_ctor_get(x_390, 1); -lean_inc(x_392); -lean_dec(x_390); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_391); -x_393 = l_Lean_Meta_inferType(x_391, x_8, x_9, x_10, x_11, x_392); -if (lean_obj_tag(x_393) == 0) -{ -lean_object* x_394; lean_object* x_395; lean_object* x_396; -x_394 = lean_ctor_get(x_393, 0); -lean_inc(x_394); -x_395 = lean_ctor_get(x_393, 1); -lean_inc(x_395); -lean_dec(x_393); +x_356 = lean_ctor_get(x_354, 1); +lean_inc(x_356); +lean_dec(x_354); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_19); -x_396 = l_Lean_Meta_isExprDefEq(x_19, x_394, x_8, x_9, x_10, x_11, x_395); -if (lean_obj_tag(x_396) == 0) +x_357 = l_Lean_Meta_getDecLevel(x_19, x_8, x_9, x_10, x_11, x_356); +if (lean_obj_tag(x_357) == 0) { -lean_object* x_397; uint8_t x_398; -x_397 = lean_ctor_get(x_396, 0); -lean_inc(x_397); -x_398 = lean_unbox(x_397); -lean_dec(x_397); -if (x_398 == 0) +lean_object* x_358; lean_object* x_359; lean_object* x_360; lean_object* x_361; lean_object* x_362; lean_object* x_363; lean_object* x_364; lean_object* x_365; lean_object* x_366; lean_object* x_367; lean_object* x_368; lean_object* x_369; lean_object* x_370; lean_object* x_371; lean_object* x_372; lean_object* x_373; +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_360 = lean_box(0); +x_361 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_361, 0, x_358); +lean_ctor_set(x_361, 1, x_360); +x_362 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_362, 0, x_355); +lean_ctor_set(x_362, 1, x_361); +x_363 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_363, 0, x_352); +lean_ctor_set(x_363, 1, x_362); +x_364 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__4; +lean_inc(x_363); +x_365 = l_Lean_mkConst(x_364, x_363); +x_366 = l_Lean_Elab_Term_mkExplicitBinder___closed__1; +lean_inc(x_285); +x_367 = lean_array_push(x_366, x_285); +lean_inc(x_31); +x_368 = lean_array_push(x_367, x_31); +lean_inc(x_349); +x_369 = lean_array_push(x_368, x_349); +lean_inc(x_286); +x_370 = lean_array_push(x_369, x_286); +lean_inc(x_4); +x_371 = lean_array_push(x_370, x_4); +x_372 = l_Lean_mkAppN(x_365, x_371); +lean_dec(x_371); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_372); +x_373 = l_Lean_Meta_inferType(x_372, x_8, x_9, x_10, x_11, x_359); +if (lean_obj_tag(x_373) == 0) { -lean_object* x_399; lean_object* x_400; lean_object* x_401; lean_object* x_402; -lean_dec(x_391); -x_399 = lean_ctor_get(x_396, 1); -lean_inc(x_399); -lean_dec(x_396); -x_400 = lean_box(0); +lean_object* x_374; lean_object* x_375; lean_object* x_376; +x_374 = lean_ctor_get(x_373, 0); +lean_inc(x_374); +x_375 = lean_ctor_get(x_373, 1); +lean_inc(x_375); +lean_dec(x_373); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_19); +x_376 = l_Lean_Meta_isExprDefEq(x_19, x_374, x_8, x_9, x_10, x_11, x_375); +if (lean_obj_tag(x_376) == 0) +{ +lean_object* x_377; uint8_t x_378; +x_377 = lean_ctor_get(x_376, 0); +lean_inc(x_377); +x_378 = lean_unbox(x_377); +lean_dec(x_377); +if (x_378 == 0) +{ +lean_object* x_379; lean_object* x_380; lean_object* x_381; +lean_dec(x_372); +x_379 = lean_ctor_get(x_376, 1); +lean_inc(x_379); +lean_dec(x_376); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_31); +x_380 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_379); +x_381 = lean_ctor_get(x_380, 0); +lean_inc(x_381); +if (lean_obj_tag(x_381) == 0) +{ +lean_object* x_382; lean_object* x_383; +lean_dec(x_363); +lean_dec(x_349); +lean_dec(x_286); +x_382 = lean_ctor_get(x_380, 1); +lean_inc(x_382); +lean_dec(x_380); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -16305,128 +16293,13 @@ lean_inc(x_5); lean_inc(x_4); lean_inc(x_22); lean_inc(x_19); -x_401 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_400, x_6, x_7, x_8, x_9, x_10, x_11, x_399); -x_402 = lean_ctor_get(x_401, 1); -lean_inc(x_402); -lean_dec(x_401); -x_270 = x_402; -goto block_304; -} -else +lean_inc(x_1); +x_383 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_382); +if (lean_obj_tag(x_383) == 0) { -lean_object* x_403; lean_object* x_404; lean_object* x_405; lean_object* x_406; lean_object* x_407; -lean_dec(x_265); -lean_dec(x_32); -lean_dec(x_31); -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_403 = lean_ctor_get(x_396, 1); -lean_inc(x_403); -lean_dec(x_396); -x_404 = lean_box(0); -x_405 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___lambda__1(x_391, x_404, x_6, x_7, x_8, x_9, x_10, x_11, x_403); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); -lean_dec(x_7); -lean_dec(x_6); -x_406 = lean_ctor_get(x_405, 0); -lean_inc(x_406); -x_407 = lean_ctor_get(x_405, 1); -lean_inc(x_407); -lean_dec(x_405); -x_13 = x_406; -x_14 = x_407; -goto block_17; -} -} -else -{ -lean_object* x_408; -lean_dec(x_391); -x_408 = lean_ctor_get(x_396, 1); -lean_inc(x_408); -lean_dec(x_396); -x_270 = x_408; -goto block_304; -} -} -else -{ -lean_object* x_409; -lean_dec(x_391); -x_409 = lean_ctor_get(x_393, 1); -lean_inc(x_409); -lean_dec(x_393); -x_270 = x_409; -goto block_304; -} -} -else -{ -lean_object* x_410; -x_410 = lean_ctor_get(x_390, 1); -lean_inc(x_410); -lean_dec(x_390); -x_270 = x_410; -goto block_304; -} -} -else -{ -lean_object* x_411; -lean_dec(x_355); -lean_dec(x_328); -lean_dec(x_314); -lean_dec(x_266); -x_411 = lean_ctor_get(x_375, 1); -lean_inc(x_411); -lean_dec(x_375); -x_270 = x_411; -goto block_304; -} -} -else -{ -lean_object* x_412; -lean_dec(x_357); -lean_dec(x_355); -lean_dec(x_328); -lean_dec(x_314); -lean_dec(x_266); -x_412 = lean_ctor_get(x_359, 1); -lean_inc(x_412); -lean_dec(x_359); -x_270 = x_412; -goto block_304; -} -} -else -{ -lean_object* x_413; -lean_dec(x_355); -lean_dec(x_328); -lean_dec(x_314); -lean_dec(x_266); -x_413 = lean_ctor_get(x_356, 1); -lean_inc(x_413); -lean_dec(x_356); -x_270 = x_413; -goto block_304; -} -} -} -else -{ -lean_object* x_414; lean_object* x_415; lean_object* x_416; -lean_dec(x_328); -lean_dec(x_314); -lean_dec(x_266); -lean_dec(x_265); +lean_object* x_384; lean_object* x_385; lean_object* x_386; lean_object* x_387; +lean_dec(x_291); +lean_dec(x_285); lean_dec(x_32); lean_dec(x_31); lean_dec(x_22); @@ -16440,189 +16313,301 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_414 = lean_ctor_get(x_341, 1); -lean_inc(x_414); -lean_dec(x_341); -x_415 = lean_box(0); -x_416 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_416, 0, x_337); -lean_ctor_set(x_416, 1, x_415); -x_13 = x_416; -x_14 = x_414; +x_384 = lean_ctor_get(x_383, 0); +lean_inc(x_384); +x_385 = lean_ctor_get(x_383, 1); +lean_inc(x_385); +lean_dec(x_383); +x_386 = lean_box(0); +x_387 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_387, 0, x_384); +lean_ctor_set(x_387, 1, x_386); +x_13 = x_387; +x_14 = x_385; goto block_17; } -} else { -lean_object* x_417; -lean_dec(x_337); -lean_dec(x_328); -lean_dec(x_314); -lean_dec(x_266); -x_417 = lean_ctor_get(x_341, 1); -lean_inc(x_417); -lean_dec(x_341); -x_270 = x_417; -goto block_304; +lean_object* x_388; +x_388 = lean_ctor_get(x_383, 1); +lean_inc(x_388); +lean_dec(x_383); +x_292 = x_388; +goto block_337; } } else { -lean_object* x_418; -lean_dec(x_337); -lean_dec(x_328); -lean_dec(x_314); -lean_dec(x_266); -x_418 = lean_ctor_get(x_338, 1); -lean_inc(x_418); -lean_dec(x_338); -x_270 = x_418; -goto block_304; -} -} -else -{ -lean_object* x_419; -lean_dec(x_320); -lean_dec(x_317); -lean_dec(x_314); -lean_dec(x_266); -x_419 = lean_ctor_get(x_322, 1); -lean_inc(x_419); -lean_dec(x_322); -x_270 = x_419; -goto block_304; -} -} -else -{ -lean_object* x_420; -lean_dec(x_317); -lean_dec(x_314); -lean_dec(x_266); -x_420 = lean_ctor_get(x_319, 1); -lean_inc(x_420); -lean_dec(x_319); -x_270 = x_420; -goto block_304; -} -} -else -{ -lean_object* x_421; -lean_dec(x_314); -lean_dec(x_266); -x_421 = lean_ctor_get(x_316, 1); -lean_inc(x_421); -lean_dec(x_316); -x_270 = x_421; -goto block_304; -} -} -else -{ -lean_object* x_422; -lean_dec(x_266); -x_422 = lean_ctor_get(x_313, 1); -lean_inc(x_422); -lean_dec(x_313); -x_270 = x_422; -goto block_304; -} -} -else -{ -lean_object* x_423; -lean_dec(x_266); -x_423 = lean_ctor_get(x_310, 1); -lean_inc(x_423); -lean_dec(x_310); -x_270 = x_423; -goto block_304; -} -} -else -{ -lean_object* x_424; lean_object* x_425; +lean_object* x_389; lean_object* x_390; lean_object* x_391; +x_389 = lean_ctor_get(x_380, 1); +lean_inc(x_389); +lean_dec(x_380); +x_390 = lean_ctor_get(x_381, 0); +lean_inc(x_390); +lean_dec(x_381); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_424 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_269); -x_425 = lean_ctor_get(x_424, 0); -lean_inc(x_425); +lean_inc(x_286); +x_391 = l_Lean_Meta_getLevel(x_286, x_8, x_9, x_10, x_11, x_389); +if (lean_obj_tag(x_391) == 0) +{ +lean_object* x_392; lean_object* x_393; lean_object* x_394; +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_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_32); +x_394 = l_Lean_Meta_getLevel(x_32, x_8, x_9, x_10, x_11, x_393); +if (lean_obj_tag(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_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; uint8_t x_408; lean_object* x_409; lean_object* x_410; +x_395 = lean_ctor_get(x_394, 0); +lean_inc(x_395); +x_396 = lean_ctor_get(x_394, 1); +lean_inc(x_396); +lean_dec(x_394); +x_397 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_397, 0, x_395); +lean_ctor_set(x_397, 1, x_360); +x_398 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_398, 0, x_392); +lean_ctor_set(x_398, 1, x_397); +x_399 = l_Lean_Meta_isCoeDecl___closed__34; +x_400 = l_Lean_mkConst(x_399, x_398); +x_401 = l_Lean_Syntax_mkAntiquotNode___closed__9; +lean_inc(x_286); +x_402 = lean_array_push(x_401, x_286); +x_403 = l_Lean_Meta_commitWhen___at___private_Lean_Meta_ExprDefEq_0__Lean_Meta_isDefEqEta___spec__1___closed__1; +x_404 = lean_array_push(x_402, x_403); +lean_inc(x_32); +x_405 = lean_array_push(x_404, x_32); +x_406 = l_Lean_mkAppN(x_400, x_405); +lean_dec(x_405); +x_407 = l_Array_myMacro____x40_Init_Data_Array_Subarray___hyg_932____closed__4; +x_408 = 0; +lean_inc(x_286); +x_409 = l_Lean_mkForall(x_407, x_408, x_286, x_406); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_6); +x_410 = l_Lean_Elab_Term_synthesizeInst(x_409, x_6, x_7, x_8, x_9, x_10, x_11, x_396); +if (lean_obj_tag(x_410) == 0) +{ +lean_object* x_411; 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_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; +x_411 = lean_ctor_get(x_410, 0); +lean_inc(x_411); +x_412 = lean_ctor_get(x_410, 1); +lean_inc(x_412); +lean_dec(x_410); +x_413 = l_Lean_Meta_isCoeDecl___closed__43; +x_414 = l_Lean_mkConst(x_413, x_363); +x_415 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__5; +lean_inc(x_285); +x_416 = lean_array_push(x_415, x_285); +lean_inc(x_31); +x_417 = lean_array_push(x_416, x_31); +x_418 = lean_array_push(x_417, x_286); +lean_inc(x_32); +x_419 = lean_array_push(x_418, x_32); +x_420 = lean_array_push(x_419, x_349); +x_421 = lean_array_push(x_420, x_411); +x_422 = lean_array_push(x_421, x_390); +lean_inc(x_4); +x_423 = lean_array_push(x_422, x_4); +x_424 = l_Lean_mkAppN(x_414, x_423); +lean_dec(x_423); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_425 = l_Lean_Meta_expandCoe(x_424, x_8, x_9, x_10, x_11, x_412); if (lean_obj_tag(x_425) == 0) { -lean_object* x_426; lean_object* x_427; -lean_dec(x_266); -lean_dec(x_265); -lean_dec(x_32); -lean_free_object(x_25); -x_426 = lean_ctor_get(x_424, 1); +lean_object* x_426; lean_object* x_427; lean_object* x_428; +x_426 = lean_ctor_get(x_425, 0); lean_inc(x_426); -lean_dec(x_424); -x_427 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_426); -lean_dec(x_7); -return x_427; +x_427 = lean_ctor_get(x_425, 1); +lean_inc(x_427); +lean_dec(x_425); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_426); +x_428 = l_Lean_Meta_inferType(x_426, x_8, x_9, x_10, x_11, x_427); +if (lean_obj_tag(x_428) == 0) +{ +lean_object* x_429; lean_object* x_430; lean_object* x_431; +x_429 = lean_ctor_get(x_428, 0); +lean_inc(x_429); +x_430 = lean_ctor_get(x_428, 1); +lean_inc(x_430); +lean_dec(x_428); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_19); +x_431 = l_Lean_Meta_isExprDefEq(x_19, x_429, x_8, x_9, x_10, x_11, x_430); +if (lean_obj_tag(x_431) == 0) +{ +lean_object* x_432; uint8_t x_433; +x_432 = lean_ctor_get(x_431, 0); +lean_inc(x_432); +x_433 = lean_unbox(x_432); +lean_dec(x_432); +if (x_433 == 0) +{ +lean_object* x_434; lean_object* x_435; lean_object* x_436; lean_object* x_437; +lean_dec(x_426); +x_434 = lean_ctor_get(x_431, 1); +lean_inc(x_434); +lean_dec(x_431); +x_435 = lean_box(0); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_6); +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_22); +lean_inc(x_19); +x_436 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_435, x_6, x_7, x_8, x_9, x_10, x_11, x_434); +x_437 = lean_ctor_get(x_436, 1); +lean_inc(x_437); +lean_dec(x_436); +x_292 = x_437; +goto block_337; } else { -lean_object* x_428; lean_object* x_429; lean_object* x_430; lean_object* x_431; 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; lean_object* x_441; lean_object* x_442; lean_object* x_443; lean_object* x_444; -x_428 = lean_ctor_get(x_424, 1); -lean_inc(x_428); -lean_dec(x_424); -x_429 = lean_ctor_get(x_425, 0); -lean_inc(x_429); -if (lean_is_exclusive(x_425)) { - lean_ctor_release(x_425, 0); - x_430 = x_425; -} else { - lean_dec_ref(x_425); - x_430 = lean_box(0); +lean_object* x_438; lean_object* x_439; lean_object* x_440; lean_object* x_441; lean_object* x_442; +lean_dec(x_291); +lean_dec(x_285); +lean_dec(x_32); +lean_dec(x_31); +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_438 = lean_ctor_get(x_431, 1); +lean_inc(x_438); +lean_dec(x_431); +x_439 = lean_box(0); +x_440 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___lambda__1(x_426, x_439, x_6, x_7, x_8, x_9, x_10, x_11, x_438); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +x_441 = lean_ctor_get(x_440, 0); +lean_inc(x_441); +x_442 = lean_ctor_get(x_440, 1); +lean_inc(x_442); +lean_dec(x_440); +x_13 = x_441; +x_14 = x_442; +goto block_17; } -if (lean_is_scalar(x_430)) { - x_431 = lean_alloc_ctor(1, 1, 0); -} else { - x_431 = x_430; } -lean_ctor_set(x_431, 0, x_265); -x_432 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_432, 0, x_266); -lean_ctor_set(x_25, 0, x_32); -x_433 = lean_box(0); -x_434 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_434, 0, x_429); -lean_inc(x_4); -x_435 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_435, 0, x_4); -x_436 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; -x_437 = lean_array_push(x_436, x_431); -x_438 = lean_array_push(x_437, x_432); -x_439 = lean_array_push(x_438, x_25); -x_440 = lean_array_push(x_439, x_433); -x_441 = lean_array_push(x_440, x_434); -x_442 = lean_array_push(x_441, x_435); -x_443 = l_Lean_Meta_isCoeDecl___closed__45; -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_444 = l_Lean_Meta_mkAppOptM(x_443, x_442, x_8, x_9, x_10, x_11, x_428); -if (lean_obj_tag(x_444) == 0) +else { -lean_object* x_445; lean_object* x_446; lean_object* x_447; -x_445 = lean_ctor_get(x_444, 0); +lean_object* x_443; +lean_dec(x_426); +x_443 = lean_ctor_get(x_431, 1); +lean_inc(x_443); +lean_dec(x_431); +x_292 = x_443; +goto block_337; +} +} +else +{ +lean_object* x_444; +lean_dec(x_426); +x_444 = lean_ctor_get(x_428, 1); +lean_inc(x_444); +lean_dec(x_428); +x_292 = x_444; +goto block_337; +} +} +else +{ +lean_object* x_445; +x_445 = lean_ctor_get(x_425, 1); lean_inc(x_445); -x_446 = lean_ctor_get(x_444, 1); -lean_inc(x_446); -lean_dec(x_444); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_447 = l_Lean_Meta_expandCoe(x_445, x_8, x_9, x_10, x_11, x_446); -if (lean_obj_tag(x_447) == 0) +lean_dec(x_425); +x_292 = x_445; +goto block_337; +} +} +else { +lean_object* x_446; +lean_dec(x_390); +lean_dec(x_363); +lean_dec(x_349); +lean_dec(x_286); +x_446 = lean_ctor_get(x_410, 1); +lean_inc(x_446); +lean_dec(x_410); +x_292 = x_446; +goto block_337; +} +} +else +{ +lean_object* x_447; +lean_dec(x_392); +lean_dec(x_390); +lean_dec(x_363); +lean_dec(x_349); +lean_dec(x_286); +x_447 = lean_ctor_get(x_394, 1); +lean_inc(x_447); +lean_dec(x_394); +x_292 = x_447; +goto block_337; +} +} +else +{ +lean_object* x_448; +lean_dec(x_390); +lean_dec(x_363); +lean_dec(x_349); +lean_dec(x_286); +x_448 = lean_ctor_get(x_391, 1); +lean_inc(x_448); +lean_dec(x_391); +x_292 = x_448; +goto block_337; +} +} +} +else +{ +lean_object* x_449; lean_object* x_450; lean_object* x_451; +lean_dec(x_363); +lean_dec(x_349); +lean_dec(x_291); +lean_dec(x_286); +lean_dec(x_285); +lean_dec(x_32); +lean_dec(x_31); lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -16634,49 +16619,177 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -return x_447; -} -else -{ -lean_object* x_448; lean_object* x_449; -x_448 = lean_ctor_get(x_447, 1); -lean_inc(x_448); -lean_dec(x_447); -x_449 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_433, x_6, x_7, x_8, x_9, x_10, x_11, x_448); -lean_dec(x_7); -lean_dec(x_1); -return x_449; +x_449 = lean_ctor_get(x_376, 1); +lean_inc(x_449); +lean_dec(x_376); +x_450 = lean_box(0); +x_451 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_451, 0, x_372); +lean_ctor_set(x_451, 1, x_450); +x_13 = x_451; +x_14 = x_449; +goto block_17; } } else { -lean_object* x_450; lean_object* x_451; -x_450 = lean_ctor_get(x_444, 1); -lean_inc(x_450); -lean_dec(x_444); -x_451 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_433, x_6, x_7, x_8, x_9, x_10, x_11, x_450); -lean_dec(x_7); -lean_dec(x_1); -return x_451; +lean_object* x_452; +lean_dec(x_372); +lean_dec(x_363); +lean_dec(x_349); +lean_dec(x_286); +x_452 = lean_ctor_get(x_376, 1); +lean_inc(x_452); +lean_dec(x_376); +x_292 = x_452; +goto block_337; } } -} -block_304: +else { -lean_object* x_271; lean_object* x_272; +lean_object* x_453; +lean_dec(x_372); +lean_dec(x_363); +lean_dec(x_349); +lean_dec(x_286); +x_453 = lean_ctor_get(x_373, 1); +lean_inc(x_453); +lean_dec(x_373); +x_292 = x_453; +goto block_337; +} +} +else +{ +lean_object* x_454; +lean_dec(x_355); +lean_dec(x_352); +lean_dec(x_349); +lean_dec(x_286); +x_454 = lean_ctor_get(x_357, 1); +lean_inc(x_454); +lean_dec(x_357); +x_292 = x_454; +goto block_337; +} +} +else +{ +lean_object* x_455; +lean_dec(x_352); +lean_dec(x_349); +lean_dec(x_286); +x_455 = lean_ctor_get(x_354, 1); +lean_inc(x_455); +lean_dec(x_354); +x_292 = x_455; +goto block_337; +} +} +else +{ +lean_object* x_456; +lean_dec(x_349); +lean_dec(x_286); +x_456 = lean_ctor_get(x_351, 1); +lean_inc(x_456); +lean_dec(x_351); +x_292 = x_456; +goto block_337; +} +} +else +{ +lean_object* x_457; +lean_dec(x_286); +x_457 = lean_ctor_get(x_348, 1); +lean_inc(x_457); +lean_dec(x_348); +x_292 = x_457; +goto block_337; +} +} +else +{ +lean_object* x_458; +lean_dec(x_286); +x_458 = lean_ctor_get(x_345, 1); +lean_inc(x_458); +lean_dec(x_345); +x_292 = x_458; +goto block_337; +} +} +block_337: +{ +lean_object* x_293; lean_object* x_294; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_271 = l_Lean_Meta_isMonad_x3f(x_265, x_8, x_9, x_10, x_11, x_270); -x_272 = lean_ctor_get(x_271, 0); -lean_inc(x_272); -if (lean_obj_tag(x_272) == 0) +x_293 = l_Lean_Meta_isMonad_x3f(x_285, x_8, x_9, x_10, x_11, x_292); +x_294 = lean_ctor_get(x_293, 0); +lean_inc(x_294); +if (lean_obj_tag(x_294) == 0) { -lean_object* x_273; lean_object* x_274; -x_273 = lean_ctor_get(x_271, 1); -lean_inc(x_273); -lean_dec(x_271); +lean_object* x_295; lean_object* x_296; uint8_t x_297; +x_295 = lean_ctor_get(x_293, 1); +lean_inc(x_295); +lean_dec(x_293); +x_296 = l_Lean_Elab_Term_autoLift; +x_297 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_291, x_296); +lean_dec(x_291); +if (x_297 == 0) +{ +lean_object* x_298; +lean_dec(x_32); +lean_dec(x_31); +x_298 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_295); +lean_dec(x_7); +if (lean_obj_tag(x_298) == 0) +{ +lean_object* x_299; lean_object* x_300; lean_object* x_301; lean_object* x_302; +x_299 = lean_ctor_get(x_298, 0); +lean_inc(x_299); +x_300 = lean_ctor_get(x_298, 1); +lean_inc(x_300); +lean_dec(x_298); +x_301 = lean_box(0); +x_302 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_302, 0, x_299); +lean_ctor_set(x_302, 1, x_301); +x_13 = x_302; +x_14 = x_300; +goto block_17; +} +else +{ +lean_object* x_303; lean_object* x_304; lean_object* x_305; lean_object* x_306; +x_303 = lean_ctor_get(x_298, 0); +lean_inc(x_303); +x_304 = lean_ctor_get(x_298, 1); +lean_inc(x_304); +if (lean_is_exclusive(x_298)) { + lean_ctor_release(x_298, 0); + lean_ctor_release(x_298, 1); + x_305 = x_298; +} else { + lean_dec_ref(x_298); + x_305 = lean_box(0); +} +if (lean_is_scalar(x_305)) { + x_306 = lean_alloc_ctor(1, 2, 0); +} else { + x_306 = x_305; +} +lean_ctor_set(x_306, 0, x_303); +lean_ctor_set(x_306, 1, x_304); +return x_306; +} +} +else +{ +lean_object* x_307; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -16686,64 +16799,64 @@ lean_inc(x_6); lean_inc(x_4); lean_inc(x_22); lean_inc(x_1); -x_274 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_31, x_32, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_273); -if (lean_obj_tag(x_274) == 0) +x_307 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_31, x_32, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_295); +if (lean_obj_tag(x_307) == 0) { -lean_object* x_275; -x_275 = lean_ctor_get(x_274, 0); -lean_inc(x_275); -if (lean_obj_tag(x_275) == 0) +lean_object* x_308; +x_308 = lean_ctor_get(x_307, 0); +lean_inc(x_308); +if (lean_obj_tag(x_308) == 0) { -lean_object* x_276; lean_object* x_277; -x_276 = lean_ctor_get(x_274, 1); -lean_inc(x_276); -lean_dec(x_274); -x_277 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_276); +lean_object* x_309; lean_object* x_310; +x_309 = lean_ctor_get(x_307, 1); +lean_inc(x_309); +lean_dec(x_307); +x_310 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_309); lean_dec(x_7); -if (lean_obj_tag(x_277) == 0) +if (lean_obj_tag(x_310) == 0) { -lean_object* x_278; lean_object* x_279; lean_object* x_280; lean_object* x_281; -x_278 = lean_ctor_get(x_277, 0); -lean_inc(x_278); -x_279 = lean_ctor_get(x_277, 1); -lean_inc(x_279); -lean_dec(x_277); -x_280 = lean_box(0); -x_281 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_281, 0, x_278); -lean_ctor_set(x_281, 1, x_280); -x_13 = x_281; -x_14 = x_279; +lean_object* x_311; lean_object* x_312; lean_object* x_313; lean_object* x_314; +x_311 = lean_ctor_get(x_310, 0); +lean_inc(x_311); +x_312 = lean_ctor_get(x_310, 1); +lean_inc(x_312); +lean_dec(x_310); +x_313 = lean_box(0); +x_314 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_314, 0, x_311); +lean_ctor_set(x_314, 1, x_313); +x_13 = x_314; +x_14 = x_312; goto block_17; } else { -lean_object* x_282; lean_object* x_283; lean_object* x_284; lean_object* x_285; -x_282 = lean_ctor_get(x_277, 0); -lean_inc(x_282); -x_283 = lean_ctor_get(x_277, 1); -lean_inc(x_283); -if (lean_is_exclusive(x_277)) { - lean_ctor_release(x_277, 0); - lean_ctor_release(x_277, 1); - x_284 = x_277; +lean_object* x_315; lean_object* x_316; lean_object* x_317; lean_object* x_318; +x_315 = lean_ctor_get(x_310, 0); +lean_inc(x_315); +x_316 = lean_ctor_get(x_310, 1); +lean_inc(x_316); +if (lean_is_exclusive(x_310)) { + lean_ctor_release(x_310, 0); + lean_ctor_release(x_310, 1); + x_317 = x_310; } else { - lean_dec_ref(x_277); - x_284 = lean_box(0); + lean_dec_ref(x_310); + x_317 = lean_box(0); } -if (lean_is_scalar(x_284)) { - x_285 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_317)) { + x_318 = lean_alloc_ctor(1, 2, 0); } else { - x_285 = x_284; + x_318 = x_317; } -lean_ctor_set(x_285, 0, x_282); -lean_ctor_set(x_285, 1, x_283); -return x_285; +lean_ctor_set(x_318, 0, x_315); +lean_ctor_set(x_318, 1, x_316); +return x_318; } } else { -lean_object* x_286; lean_object* x_287; lean_object* x_288; lean_object* x_289; +lean_object* x_319; lean_object* x_320; lean_object* x_321; lean_object* x_322; lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -16755,24 +16868,24 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_286 = lean_ctor_get(x_274, 1); -lean_inc(x_286); -lean_dec(x_274); -x_287 = lean_ctor_get(x_275, 0); -lean_inc(x_287); -lean_dec(x_275); -x_288 = lean_box(0); -x_289 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_289, 0, x_287); -lean_ctor_set(x_289, 1, x_288); -x_13 = x_289; -x_14 = x_286; +x_319 = lean_ctor_get(x_307, 1); +lean_inc(x_319); +lean_dec(x_307); +x_320 = lean_ctor_get(x_308, 0); +lean_inc(x_320); +lean_dec(x_308); +x_321 = lean_box(0); +x_322 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_322, 0, x_320); +lean_ctor_set(x_322, 1, x_321); +x_13 = x_322; +x_14 = x_319; goto block_17; } } else { -lean_object* x_290; lean_object* x_291; lean_object* x_292; lean_object* x_293; +lean_object* x_323; lean_object* x_324; lean_object* x_325; lean_object* x_326; lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -16784,87 +16897,213 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_290 = lean_ctor_get(x_274, 0); -lean_inc(x_290); -x_291 = lean_ctor_get(x_274, 1); -lean_inc(x_291); -if (lean_is_exclusive(x_274)) { - lean_ctor_release(x_274, 0); - lean_ctor_release(x_274, 1); - x_292 = x_274; +x_323 = lean_ctor_get(x_307, 0); +lean_inc(x_323); +x_324 = lean_ctor_get(x_307, 1); +lean_inc(x_324); +if (lean_is_exclusive(x_307)) { + lean_ctor_release(x_307, 0); + lean_ctor_release(x_307, 1); + x_325 = x_307; } else { - lean_dec_ref(x_274); - x_292 = lean_box(0); + lean_dec_ref(x_307); + x_325 = lean_box(0); } -if (lean_is_scalar(x_292)) { - x_293 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_325)) { + x_326 = lean_alloc_ctor(1, 2, 0); } else { - x_293 = x_292; + x_326 = x_325; +} +lean_ctor_set(x_326, 0, x_323); +lean_ctor_set(x_326, 1, x_324); +return x_326; } -lean_ctor_set(x_293, 0, x_290); -lean_ctor_set(x_293, 1, x_291); -return x_293; } } else { -lean_object* x_294; lean_object* x_295; -lean_dec(x_272); +lean_object* x_327; lean_object* x_328; +lean_dec(x_294); +lean_dec(x_291); lean_dec(x_32); lean_dec(x_31); -x_294 = lean_ctor_get(x_271, 1); -lean_inc(x_294); -lean_dec(x_271); -x_295 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_294); +x_327 = lean_ctor_get(x_293, 1); +lean_inc(x_327); +lean_dec(x_293); +x_328 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_327); lean_dec(x_7); -if (lean_obj_tag(x_295) == 0) +if (lean_obj_tag(x_328) == 0) { -lean_object* x_296; lean_object* x_297; lean_object* x_298; lean_object* x_299; -x_296 = lean_ctor_get(x_295, 0); -lean_inc(x_296); -x_297 = lean_ctor_get(x_295, 1); -lean_inc(x_297); -lean_dec(x_295); -x_298 = lean_box(0); -x_299 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_299, 0, x_296); -lean_ctor_set(x_299, 1, x_298); -x_13 = x_299; -x_14 = x_297; +lean_object* x_329; lean_object* x_330; lean_object* x_331; lean_object* x_332; +x_329 = lean_ctor_get(x_328, 0); +lean_inc(x_329); +x_330 = lean_ctor_get(x_328, 1); +lean_inc(x_330); +lean_dec(x_328); +x_331 = lean_box(0); +x_332 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_332, 0, x_329); +lean_ctor_set(x_332, 1, x_331); +x_13 = x_332; +x_14 = x_330; goto block_17; } else { -lean_object* x_300; lean_object* x_301; lean_object* x_302; lean_object* x_303; -x_300 = lean_ctor_get(x_295, 0); -lean_inc(x_300); -x_301 = lean_ctor_get(x_295, 1); -lean_inc(x_301); -if (lean_is_exclusive(x_295)) { - lean_ctor_release(x_295, 0); - lean_ctor_release(x_295, 1); - x_302 = x_295; +lean_object* x_333; lean_object* x_334; lean_object* x_335; lean_object* x_336; +x_333 = lean_ctor_get(x_328, 0); +lean_inc(x_333); +x_334 = lean_ctor_get(x_328, 1); +lean_inc(x_334); +if (lean_is_exclusive(x_328)) { + lean_ctor_release(x_328, 0); + lean_ctor_release(x_328, 1); + x_335 = x_328; } else { - lean_dec_ref(x_295); - x_302 = lean_box(0); + lean_dec_ref(x_328); + x_335 = lean_box(0); } -if (lean_is_scalar(x_302)) { - x_303 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_335)) { + x_336 = lean_alloc_ctor(1, 2, 0); } else { - x_303 = x_302; + x_336 = x_335; } -lean_ctor_set(x_303, 0, x_300); -lean_ctor_set(x_303, 1, x_301); -return x_303; +lean_ctor_set(x_336, 0, x_333); +lean_ctor_set(x_336, 1, x_334); +return x_336; } } } } else { -lean_object* x_452; lean_object* x_453; lean_object* x_454; lean_object* x_455; -lean_dec(x_266); -lean_dec(x_265); +lean_object* x_459; lean_object* x_460; lean_object* x_461; +x_459 = lean_ctor_get(x_287, 1); +lean_inc(x_459); +lean_dec(x_287); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_460 = l_Lean_Meta_isMonad_x3f(x_31, x_8, x_9, x_10, x_11, x_459); +x_461 = lean_ctor_get(x_460, 0); +lean_inc(x_461); +if (lean_obj_tag(x_461) == 0) +{ +lean_object* x_462; lean_object* x_463; +lean_dec(x_286); +lean_dec(x_285); +lean_dec(x_32); +lean_free_object(x_25); +x_462 = lean_ctor_get(x_460, 1); +lean_inc(x_462); +lean_dec(x_460); +x_463 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_462); +lean_dec(x_7); +return x_463; +} +else +{ +lean_object* x_464; lean_object* x_465; lean_object* x_466; lean_object* x_467; lean_object* x_468; lean_object* x_469; lean_object* x_470; lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; lean_object* x_479; lean_object* x_480; +x_464 = lean_ctor_get(x_460, 1); +lean_inc(x_464); +lean_dec(x_460); +x_465 = lean_ctor_get(x_461, 0); +lean_inc(x_465); +if (lean_is_exclusive(x_461)) { + lean_ctor_release(x_461, 0); + x_466 = x_461; +} else { + lean_dec_ref(x_461); + x_466 = lean_box(0); +} +if (lean_is_scalar(x_466)) { + x_467 = lean_alloc_ctor(1, 1, 0); +} else { + x_467 = x_466; +} +lean_ctor_set(x_467, 0, x_285); +x_468 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_468, 0, x_286); +lean_ctor_set(x_25, 0, x_32); +x_469 = lean_box(0); +x_470 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_470, 0, x_465); +lean_inc(x_4); +x_471 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_471, 0, x_4); +x_472 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; +x_473 = lean_array_push(x_472, x_467); +x_474 = lean_array_push(x_473, x_468); +x_475 = lean_array_push(x_474, x_25); +x_476 = lean_array_push(x_475, x_469); +x_477 = lean_array_push(x_476, x_470); +x_478 = lean_array_push(x_477, x_471); +x_479 = l_Lean_Meta_isCoeDecl___closed__45; +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_480 = l_Lean_Meta_mkAppOptM(x_479, x_478, x_8, x_9, x_10, x_11, x_464); +if (lean_obj_tag(x_480) == 0) +{ +lean_object* x_481; lean_object* x_482; lean_object* 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); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_483 = l_Lean_Meta_expandCoe(x_481, x_8, x_9, x_10, x_11, x_482); +if (lean_obj_tag(x_483) == 0) +{ +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +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_1); +return x_483; +} +else +{ +lean_object* x_484; lean_object* x_485; +x_484 = lean_ctor_get(x_483, 1); +lean_inc(x_484); +lean_dec(x_483); +x_485 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_469, x_6, x_7, x_8, x_9, x_10, x_11, x_484); +lean_dec(x_7); +lean_dec(x_1); +return x_485; +} +} +else +{ +lean_object* x_486; lean_object* x_487; +x_486 = lean_ctor_get(x_480, 1); +lean_inc(x_486); +lean_dec(x_480); +x_487 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_469, x_6, x_7, x_8, x_9, x_10, x_11, x_486); +lean_dec(x_7); +lean_dec(x_1); +return x_487; +} +} +} +} +else +{ +lean_object* x_488; lean_object* x_489; lean_object* x_490; lean_object* x_491; +lean_dec(x_286); +lean_dec(x_285); lean_dec(x_32); lean_dec(x_31); lean_free_object(x_25); @@ -16879,33 +17118,33 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_452 = lean_ctor_get(x_267, 0); -lean_inc(x_452); -x_453 = lean_ctor_get(x_267, 1); -lean_inc(x_453); -if (lean_is_exclusive(x_267)) { - lean_ctor_release(x_267, 0); - lean_ctor_release(x_267, 1); - x_454 = x_267; +x_488 = lean_ctor_get(x_287, 0); +lean_inc(x_488); +x_489 = lean_ctor_get(x_287, 1); +lean_inc(x_489); +if (lean_is_exclusive(x_287)) { + lean_ctor_release(x_287, 0); + lean_ctor_release(x_287, 1); + x_490 = x_287; } else { - lean_dec_ref(x_267); - x_454 = lean_box(0); + lean_dec_ref(x_287); + x_490 = lean_box(0); } -if (lean_is_scalar(x_454)) { - x_455 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_490)) { + x_491 = lean_alloc_ctor(1, 2, 0); } else { - x_455 = x_454; + x_491 = x_490; } -lean_ctor_set(x_455, 0, x_452); -lean_ctor_set(x_455, 1, x_453); -return x_455; +lean_ctor_set(x_491, 0, x_488); +lean_ctor_set(x_491, 1, x_489); +return x_491; } } } } else { -uint8_t x_456; +uint8_t x_492; lean_dec(x_32); lean_dec(x_31); lean_free_object(x_25); @@ -16920,57 +17159,74 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_456 = !lean_is_exclusive(x_33); -if (x_456 == 0) +x_492 = !lean_is_exclusive(x_33); +if (x_492 == 0) { return x_33; } else { -lean_object* x_457; lean_object* x_458; lean_object* x_459; -x_457 = lean_ctor_get(x_33, 0); -x_458 = lean_ctor_get(x_33, 1); -lean_inc(x_458); -lean_inc(x_457); +lean_object* x_493; lean_object* x_494; lean_object* x_495; +x_493 = lean_ctor_get(x_33, 0); +x_494 = lean_ctor_get(x_33, 1); +lean_inc(x_494); +lean_inc(x_493); lean_dec(x_33); -x_459 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_459, 0, x_457); -lean_ctor_set(x_459, 1, x_458); -return x_459; +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_460; lean_object* x_461; lean_object* x_462; lean_object* x_463; lean_object* x_464; -x_460 = lean_ctor_get(x_25, 0); -lean_inc(x_460); +lean_object* x_496; lean_object* x_497; lean_object* x_498; lean_object* x_499; lean_object* x_500; +x_496 = lean_ctor_get(x_25, 0); +lean_inc(x_496); lean_dec(x_25); -x_461 = lean_ctor_get(x_24, 1); -lean_inc(x_461); +x_497 = lean_ctor_get(x_24, 1); +lean_inc(x_497); lean_dec(x_24); -x_462 = lean_ctor_get(x_460, 0); -lean_inc(x_462); -x_463 = lean_ctor_get(x_460, 1); -lean_inc(x_463); -lean_dec(x_460); +x_498 = lean_ctor_get(x_496, 0); +lean_inc(x_498); +x_499 = lean_ctor_get(x_496, 1); +lean_inc(x_499); +lean_dec(x_496); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_22); -x_464 = l_Lean_Elab_Term_isTypeApp_x3f(x_22, x_6, x_7, x_8, x_9, x_10, x_11, x_461); -if (lean_obj_tag(x_464) == 0) +x_500 = l_Lean_Elab_Term_isTypeApp_x3f(x_22, x_6, x_7, x_8, x_9, x_10, x_11, x_497); +if (lean_obj_tag(x_500) == 0) { -lean_object* x_465; -x_465 = lean_ctor_get(x_464, 0); -lean_inc(x_465); -if (lean_obj_tag(x_465) == 0) +lean_object* x_501; +x_501 = lean_ctor_get(x_500, 0); +lean_inc(x_501); +if (lean_obj_tag(x_501) == 0) { -lean_object* x_466; lean_object* x_467; -x_466 = lean_ctor_get(x_464, 1); -lean_inc(x_466); -lean_dec(x_464); +lean_object* x_502; lean_object* x_503; lean_object* x_504; uint8_t x_505; +x_502 = lean_ctor_get(x_500, 1); +lean_inc(x_502); +lean_dec(x_500); +x_503 = lean_ctor_get(x_10, 0); +lean_inc(x_503); +x_504 = l_Lean_Elab_Term_autoLift; +x_505 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_503, x_504); +lean_dec(x_503); +if (x_505 == 0) +{ +lean_object* x_506; +lean_dec(x_499); +lean_dec(x_498); +x_506 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_502); +lean_dec(x_7); +return x_506; +} +else +{ +lean_object* x_507; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -16980,25 +17236,25 @@ lean_inc(x_6); lean_inc(x_4); lean_inc(x_22); lean_inc(x_1); -x_467 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_462, x_463, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_466); -if (lean_obj_tag(x_467) == 0) +x_507 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_498, x_499, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_502); +if (lean_obj_tag(x_507) == 0) { -lean_object* x_468; -x_468 = lean_ctor_get(x_467, 0); -lean_inc(x_468); -if (lean_obj_tag(x_468) == 0) +lean_object* x_508; +x_508 = lean_ctor_get(x_507, 0); +lean_inc(x_508); +if (lean_obj_tag(x_508) == 0) { -lean_object* x_469; lean_object* x_470; -x_469 = lean_ctor_get(x_467, 1); -lean_inc(x_469); -lean_dec(x_467); -x_470 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_469); +lean_object* x_509; lean_object* x_510; +x_509 = lean_ctor_get(x_507, 1); +lean_inc(x_509); +lean_dec(x_507); +x_510 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_509); lean_dec(x_7); -return x_470; +return x_510; } else { -lean_object* x_471; lean_object* x_472; lean_object* x_473; lean_object* x_474; +lean_object* x_511; lean_object* x_512; lean_object* x_513; lean_object* x_514; lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -17010,32 +17266,32 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_471 = lean_ctor_get(x_467, 1); -lean_inc(x_471); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - x_472 = x_467; +x_511 = lean_ctor_get(x_507, 1); +lean_inc(x_511); +if (lean_is_exclusive(x_507)) { + lean_ctor_release(x_507, 0); + lean_ctor_release(x_507, 1); + x_512 = x_507; } else { - lean_dec_ref(x_467); - x_472 = lean_box(0); + lean_dec_ref(x_507); + x_512 = lean_box(0); } -x_473 = lean_ctor_get(x_468, 0); -lean_inc(x_473); -lean_dec(x_468); -if (lean_is_scalar(x_472)) { - x_474 = lean_alloc_ctor(0, 2, 0); +x_513 = lean_ctor_get(x_508, 0); +lean_inc(x_513); +lean_dec(x_508); +if (lean_is_scalar(x_512)) { + x_514 = lean_alloc_ctor(0, 2, 0); } else { - x_474 = x_472; + x_514 = x_512; } -lean_ctor_set(x_474, 0, x_473); -lean_ctor_set(x_474, 1, x_471); -return x_474; +lean_ctor_set(x_514, 0, x_513); +lean_ctor_set(x_514, 1, x_511); +return x_514; } } else { -lean_object* x_475; lean_object* x_476; lean_object* x_477; lean_object* x_478; +lean_object* x_515; lean_object* x_516; lean_object* x_517; lean_object* x_518; lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -17047,380 +17303,196 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_475 = lean_ctor_get(x_467, 0); -lean_inc(x_475); -x_476 = lean_ctor_get(x_467, 1); -lean_inc(x_476); -if (lean_is_exclusive(x_467)) { - lean_ctor_release(x_467, 0); - lean_ctor_release(x_467, 1); - x_477 = x_467; +x_515 = lean_ctor_get(x_507, 0); +lean_inc(x_515); +x_516 = lean_ctor_get(x_507, 1); +lean_inc(x_516); +if (lean_is_exclusive(x_507)) { + lean_ctor_release(x_507, 0); + lean_ctor_release(x_507, 1); + x_517 = x_507; } else { - lean_dec_ref(x_467); - x_477 = lean_box(0); + lean_dec_ref(x_507); + x_517 = lean_box(0); } -if (lean_is_scalar(x_477)) { - x_478 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_517)) { + x_518 = lean_alloc_ctor(1, 2, 0); } else { - x_478 = x_477; + x_518 = x_517; +} +lean_ctor_set(x_518, 0, x_515); +lean_ctor_set(x_518, 1, x_516); +return x_518; } -lean_ctor_set(x_478, 0, x_475); -lean_ctor_set(x_478, 1, x_476); -return x_478; } } else { -lean_object* x_479; lean_object* x_480; lean_object* x_481; lean_object* x_482; lean_object* x_483; lean_object* x_484; -x_479 = lean_ctor_get(x_465, 0); -lean_inc(x_479); -if (lean_is_exclusive(x_465)) { - lean_ctor_release(x_465, 0); - x_480 = x_465; +lean_object* x_519; lean_object* x_520; lean_object* x_521; lean_object* x_522; lean_object* x_523; lean_object* x_524; +x_519 = lean_ctor_get(x_501, 0); +lean_inc(x_519); +if (lean_is_exclusive(x_501)) { + lean_ctor_release(x_501, 0); + x_520 = x_501; } else { - lean_dec_ref(x_465); - x_480 = lean_box(0); + lean_dec_ref(x_501); + x_520 = lean_box(0); } -x_481 = lean_ctor_get(x_464, 1); -lean_inc(x_481); -lean_dec(x_464); -x_482 = lean_ctor_get(x_479, 0); -lean_inc(x_482); -x_483 = lean_ctor_get(x_479, 1); -lean_inc(x_483); -lean_dec(x_479); +x_521 = lean_ctor_get(x_500, 1); +lean_inc(x_521); +lean_dec(x_500); +x_522 = lean_ctor_get(x_519, 0); +lean_inc(x_522); +x_523 = lean_ctor_get(x_519, 1); +lean_inc(x_523); +lean_dec(x_519); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -lean_inc(x_462); -lean_inc(x_482); -x_484 = l_Lean_Meta_isExprDefEq(x_482, x_462, x_8, x_9, x_10, x_11, x_481); -if (lean_obj_tag(x_484) == 0) +lean_inc(x_498); +lean_inc(x_522); +x_524 = l_Lean_Meta_isExprDefEq(x_522, x_498, x_8, x_9, x_10, x_11, x_521); +if (lean_obj_tag(x_524) == 0) { -lean_object* x_485; lean_object* x_486; lean_object* x_487; uint8_t x_522; -x_485 = lean_ctor_get(x_484, 0); -lean_inc(x_485); -x_486 = lean_ctor_get(x_484, 1); -lean_inc(x_486); -lean_dec(x_484); -x_522 = lean_unbox(x_485); -lean_dec(x_485); -if (x_522 == 0) +lean_object* x_525; uint8_t x_526; +x_525 = lean_ctor_get(x_524, 0); +lean_inc(x_525); +x_526 = lean_unbox(x_525); +lean_dec(x_525); +if (x_526 == 0) { -lean_object* x_523; lean_object* x_524; lean_object* x_525; lean_object* x_526; lean_object* x_527; -lean_dec(x_480); -x_523 = l_Lean_Syntax_mkApp___closed__1; -lean_inc(x_482); -x_524 = lean_array_push(x_523, x_482); -lean_inc(x_462); -x_525 = lean_array_push(x_524, x_462); -x_526 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__2; -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -x_527 = l_Lean_Meta_mkAppM(x_526, x_525, x_8, x_9, x_10, x_11, x_486); -if (lean_obj_tag(x_527) == 0) -{ -lean_object* x_528; lean_object* x_529; lean_object* x_530; -x_528 = lean_ctor_get(x_527, 0); +lean_object* x_527; lean_object* x_528; lean_object* x_529; lean_object* x_575; uint8_t x_576; +lean_dec(x_520); +x_527 = lean_ctor_get(x_524, 1); +lean_inc(x_527); +lean_dec(x_524); +x_528 = lean_ctor_get(x_10, 0); lean_inc(x_528); -x_529 = lean_ctor_get(x_527, 1); -lean_inc(x_529); -lean_dec(x_527); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_6); -x_530 = l_Lean_Elab_Term_synthesizeInst(x_528, x_6, x_7, x_8, x_9, x_10, x_11, x_529); -if (lean_obj_tag(x_530) == 0) +x_575 = l_Lean_Elab_Term_autoLift; +x_576 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_528, x_575); +if (x_576 == 0) { -lean_object* x_531; lean_object* x_532; lean_object* x_533; -x_531 = lean_ctor_get(x_530, 0); -lean_inc(x_531); -x_532 = lean_ctor_get(x_530, 1); -lean_inc(x_532); -lean_dec(x_530); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_483); -x_533 = l_Lean_Meta_getDecLevel(x_483, x_8, x_9, x_10, x_11, x_532); -if (lean_obj_tag(x_533) == 0) -{ -lean_object* x_534; lean_object* x_535; lean_object* x_536; -x_534 = lean_ctor_get(x_533, 0); -lean_inc(x_534); -x_535 = lean_ctor_get(x_533, 1); -lean_inc(x_535); -lean_dec(x_533); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_22); -x_536 = l_Lean_Meta_getDecLevel(x_22, x_8, x_9, x_10, x_11, x_535); -if (lean_obj_tag(x_536) == 0) -{ -lean_object* x_537; lean_object* x_538; lean_object* x_539; -x_537 = lean_ctor_get(x_536, 0); -lean_inc(x_537); -x_538 = lean_ctor_get(x_536, 1); -lean_inc(x_538); -lean_dec(x_536); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_19); -x_539 = l_Lean_Meta_getDecLevel(x_19, x_8, x_9, x_10, x_11, x_538); -if (lean_obj_tag(x_539) == 0) -{ -lean_object* x_540; lean_object* x_541; 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; lean_object* x_551; lean_object* x_552; lean_object* x_553; lean_object* x_554; lean_object* x_555; -x_540 = lean_ctor_get(x_539, 0); -lean_inc(x_540); -x_541 = lean_ctor_get(x_539, 1); -lean_inc(x_541); -lean_dec(x_539); -x_542 = lean_box(0); -x_543 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_543, 0, x_540); -lean_ctor_set(x_543, 1, x_542); -x_544 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_544, 0, x_537); -lean_ctor_set(x_544, 1, x_543); -x_545 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_545, 0, x_534); -lean_ctor_set(x_545, 1, x_544); -x_546 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__4; -lean_inc(x_545); -x_547 = l_Lean_mkConst(x_546, x_545); -x_548 = l_Lean_Elab_Term_mkExplicitBinder___closed__1; -lean_inc(x_482); -x_549 = lean_array_push(x_548, x_482); -lean_inc(x_462); -x_550 = lean_array_push(x_549, x_462); -lean_inc(x_531); -x_551 = lean_array_push(x_550, x_531); -lean_inc(x_483); -x_552 = lean_array_push(x_551, x_483); -lean_inc(x_4); -x_553 = lean_array_push(x_552, x_4); -x_554 = l_Lean_mkAppN(x_547, x_553); -lean_dec(x_553); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_554); -x_555 = l_Lean_Meta_inferType(x_554, x_8, x_9, x_10, x_11, x_541); -if (lean_obj_tag(x_555) == 0) -{ -lean_object* x_556; lean_object* x_557; lean_object* x_558; -x_556 = lean_ctor_get(x_555, 0); -lean_inc(x_556); -x_557 = lean_ctor_get(x_555, 1); -lean_inc(x_557); -lean_dec(x_555); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_19); -x_558 = l_Lean_Meta_isExprDefEq(x_19, x_556, x_8, x_9, x_10, x_11, x_557); -if (lean_obj_tag(x_558) == 0) -{ -lean_object* x_559; uint8_t x_560; -x_559 = lean_ctor_get(x_558, 0); -lean_inc(x_559); -x_560 = lean_unbox(x_559); -lean_dec(x_559); -if (x_560 == 0) -{ -lean_object* x_561; lean_object* x_562; lean_object* x_563; -lean_dec(x_554); -x_561 = lean_ctor_get(x_558, 1); -lean_inc(x_561); -lean_dec(x_558); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_462); -x_562 = l_Lean_Meta_isMonad_x3f(x_462, x_8, x_9, x_10, x_11, x_561); -x_563 = lean_ctor_get(x_562, 0); -lean_inc(x_563); -if (lean_obj_tag(x_563) == 0) -{ -lean_object* x_564; lean_object* x_565; -lean_dec(x_545); -lean_dec(x_531); -lean_dec(x_483); -x_564 = lean_ctor_get(x_562, 1); -lean_inc(x_564); -lean_dec(x_562); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_6); -lean_inc(x_5); -lean_inc(x_4); -lean_inc(x_22); -lean_inc(x_19); -lean_inc(x_1); -x_565 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_564); -if (lean_obj_tag(x_565) == 0) -{ -lean_object* x_566; lean_object* x_567; lean_object* x_568; lean_object* x_569; -lean_dec(x_482); -lean_dec(x_463); -lean_dec(x_462); -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -lean_dec(x_9); -lean_dec(x_8); +lean_object* x_577; +lean_dec(x_528); +lean_dec(x_523); +lean_dec(x_522); +lean_dec(x_499); +lean_dec(x_498); +x_577 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_527); lean_dec(x_7); -lean_dec(x_6); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_566 = lean_ctor_get(x_565, 0); -lean_inc(x_566); -x_567 = lean_ctor_get(x_565, 1); -lean_inc(x_567); -lean_dec(x_565); -x_568 = lean_box(0); -x_569 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_569, 0, x_566); -lean_ctor_set(x_569, 1, x_568); -x_13 = x_569; -x_14 = x_567; -goto block_17; +return x_577; } else { -lean_object* x_570; -x_570 = lean_ctor_get(x_565, 1); -lean_inc(x_570); -lean_dec(x_565); -x_487 = x_570; -goto block_521; -} -} -else -{ -lean_object* x_571; lean_object* x_572; lean_object* x_573; -x_571 = lean_ctor_get(x_562, 1); -lean_inc(x_571); -lean_dec(x_562); -x_572 = lean_ctor_get(x_563, 0); -lean_inc(x_572); -lean_dec(x_563); +lean_object* x_578; lean_object* x_579; lean_object* x_580; lean_object* x_581; lean_object* x_582; +x_578 = l_Lean_Syntax_mkApp___closed__1; +lean_inc(x_522); +x_579 = lean_array_push(x_578, x_522); +lean_inc(x_498); +x_580 = lean_array_push(x_579, x_498); +x_581 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__2; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -lean_inc(x_483); -x_573 = l_Lean_Meta_getLevel(x_483, x_8, x_9, x_10, x_11, x_571); -if (lean_obj_tag(x_573) == 0) +x_582 = l_Lean_Meta_mkAppM(x_581, x_580, x_8, x_9, x_10, x_11, x_527); +if (lean_obj_tag(x_582) == 0) { -lean_object* x_574; lean_object* x_575; lean_object* x_576; -x_574 = lean_ctor_get(x_573, 0); -lean_inc(x_574); -x_575 = lean_ctor_get(x_573, 1); -lean_inc(x_575); -lean_dec(x_573); -lean_inc(x_11); -lean_inc(x_10); -lean_inc(x_9); -lean_inc(x_8); -lean_inc(x_463); -x_576 = l_Lean_Meta_getLevel(x_463, x_8, x_9, x_10, x_11, x_575); -if (lean_obj_tag(x_576) == 0) -{ -lean_object* x_577; lean_object* x_578; lean_object* x_579; lean_object* x_580; lean_object* x_581; lean_object* x_582; lean_object* x_583; lean_object* x_584; lean_object* x_585; lean_object* x_586; lean_object* x_587; lean_object* x_588; lean_object* x_589; uint8_t x_590; lean_object* x_591; lean_object* x_592; -x_577 = lean_ctor_get(x_576, 0); -lean_inc(x_577); -x_578 = lean_ctor_get(x_576, 1); -lean_inc(x_578); -lean_dec(x_576); -x_579 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_579, 0, x_577); -lean_ctor_set(x_579, 1, x_542); -x_580 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_580, 0, x_574); -lean_ctor_set(x_580, 1, x_579); -x_581 = l_Lean_Meta_isCoeDecl___closed__34; -x_582 = l_Lean_mkConst(x_581, x_580); -x_583 = l_Lean_Syntax_mkAntiquotNode___closed__9; -lean_inc(x_483); -x_584 = lean_array_push(x_583, x_483); -x_585 = l_Lean_Meta_commitWhen___at___private_Lean_Meta_ExprDefEq_0__Lean_Meta_isDefEqEta___spec__1___closed__1; -x_586 = lean_array_push(x_584, x_585); -lean_inc(x_463); -x_587 = lean_array_push(x_586, x_463); -x_588 = l_Lean_mkAppN(x_582, x_587); -lean_dec(x_587); -x_589 = l_Array_myMacro____x40_Init_Data_Array_Subarray___hyg_932____closed__4; -x_590 = 0; -lean_inc(x_483); -x_591 = l_Lean_mkForall(x_589, x_590, x_483, x_588); +lean_object* x_583; lean_object* x_584; lean_object* x_585; +x_583 = lean_ctor_get(x_582, 0); +lean_inc(x_583); +x_584 = lean_ctor_get(x_582, 1); +lean_inc(x_584); +lean_dec(x_582); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); lean_inc(x_6); -x_592 = l_Lean_Elab_Term_synthesizeInst(x_591, x_6, x_7, x_8, x_9, x_10, x_11, x_578); -if (lean_obj_tag(x_592) == 0) +x_585 = l_Lean_Elab_Term_synthesizeInst(x_583, x_6, x_7, x_8, x_9, x_10, x_11, x_584); +if (lean_obj_tag(x_585) == 0) { -lean_object* x_593; lean_object* x_594; lean_object* x_595; lean_object* x_596; lean_object* x_597; lean_object* x_598; lean_object* x_599; lean_object* x_600; lean_object* x_601; lean_object* x_602; lean_object* x_603; lean_object* x_604; lean_object* x_605; lean_object* x_606; lean_object* x_607; -x_593 = lean_ctor_get(x_592, 0); +lean_object* x_586; lean_object* x_587; lean_object* x_588; +x_586 = lean_ctor_get(x_585, 0); +lean_inc(x_586); +x_587 = lean_ctor_get(x_585, 1); +lean_inc(x_587); +lean_dec(x_585); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_523); +x_588 = l_Lean_Meta_getDecLevel(x_523, x_8, x_9, x_10, x_11, x_587); +if (lean_obj_tag(x_588) == 0) +{ +lean_object* x_589; lean_object* x_590; lean_object* x_591; +x_589 = lean_ctor_get(x_588, 0); +lean_inc(x_589); +x_590 = lean_ctor_get(x_588, 1); +lean_inc(x_590); +lean_dec(x_588); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_22); +x_591 = l_Lean_Meta_getDecLevel(x_22, x_8, x_9, x_10, x_11, x_590); +if (lean_obj_tag(x_591) == 0) +{ +lean_object* x_592; lean_object* x_593; lean_object* x_594; +x_592 = lean_ctor_get(x_591, 0); +lean_inc(x_592); +x_593 = lean_ctor_get(x_591, 1); lean_inc(x_593); -x_594 = lean_ctor_get(x_592, 1); -lean_inc(x_594); -lean_dec(x_592); -x_595 = l_Lean_Meta_isCoeDecl___closed__43; -x_596 = l_Lean_mkConst(x_595, x_545); -x_597 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__5; -lean_inc(x_482); -x_598 = lean_array_push(x_597, x_482); -lean_inc(x_462); -x_599 = lean_array_push(x_598, x_462); -x_600 = lean_array_push(x_599, x_483); -lean_inc(x_463); -x_601 = lean_array_push(x_600, x_463); -x_602 = lean_array_push(x_601, x_531); -x_603 = lean_array_push(x_602, x_593); -x_604 = lean_array_push(x_603, x_572); -lean_inc(x_4); -x_605 = lean_array_push(x_604, x_4); -x_606 = l_Lean_mkAppN(x_596, x_605); -lean_dec(x_605); +lean_dec(x_591); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_607 = l_Lean_Meta_expandCoe(x_606, x_8, x_9, x_10, x_11, x_594); -if (lean_obj_tag(x_607) == 0) +lean_inc(x_19); +x_594 = l_Lean_Meta_getDecLevel(x_19, x_8, x_9, x_10, x_11, x_593); +if (lean_obj_tag(x_594) == 0) { -lean_object* x_608; lean_object* x_609; lean_object* x_610; -x_608 = lean_ctor_get(x_607, 0); -lean_inc(x_608); -x_609 = lean_ctor_get(x_607, 1); -lean_inc(x_609); -lean_dec(x_607); +lean_object* x_595; lean_object* x_596; lean_object* x_597; lean_object* x_598; lean_object* x_599; lean_object* x_600; lean_object* x_601; lean_object* x_602; lean_object* x_603; lean_object* x_604; lean_object* x_605; lean_object* x_606; lean_object* x_607; lean_object* x_608; lean_object* x_609; lean_object* x_610; +x_595 = lean_ctor_get(x_594, 0); +lean_inc(x_595); +x_596 = lean_ctor_get(x_594, 1); +lean_inc(x_596); +lean_dec(x_594); +x_597 = lean_box(0); +x_598 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_598, 0, x_595); +lean_ctor_set(x_598, 1, x_597); +x_599 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_599, 0, x_592); +lean_ctor_set(x_599, 1, x_598); +x_600 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_600, 0, x_589); +lean_ctor_set(x_600, 1, x_599); +x_601 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__4; +lean_inc(x_600); +x_602 = l_Lean_mkConst(x_601, x_600); +x_603 = l_Lean_Elab_Term_mkExplicitBinder___closed__1; +lean_inc(x_522); +x_604 = lean_array_push(x_603, x_522); +lean_inc(x_498); +x_605 = lean_array_push(x_604, x_498); +lean_inc(x_586); +x_606 = lean_array_push(x_605, x_586); +lean_inc(x_523); +x_607 = lean_array_push(x_606, x_523); +lean_inc(x_4); +x_608 = lean_array_push(x_607, x_4); +x_609 = l_Lean_mkAppN(x_602, x_608); +lean_dec(x_608); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -lean_inc(x_608); -x_610 = l_Lean_Meta_inferType(x_608, x_8, x_9, x_10, x_11, x_609); +lean_inc(x_609); +x_610 = l_Lean_Meta_inferType(x_609, x_8, x_9, x_10, x_11, x_596); if (lean_obj_tag(x_610) == 0) { lean_object* x_611; lean_object* x_612; lean_object* x_613; @@ -17444,12 +17516,28 @@ x_615 = lean_unbox(x_614); lean_dec(x_614); if (x_615 == 0) { -lean_object* x_616; lean_object* x_617; lean_object* x_618; lean_object* x_619; -lean_dec(x_608); +lean_object* x_616; lean_object* x_617; lean_object* x_618; +lean_dec(x_609); x_616 = lean_ctor_get(x_613, 1); lean_inc(x_616); lean_dec(x_613); -x_617 = lean_box(0); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_498); +x_617 = l_Lean_Meta_isMonad_x3f(x_498, x_8, x_9, x_10, x_11, x_616); +x_618 = lean_ctor_get(x_617, 0); +lean_inc(x_618); +if (lean_obj_tag(x_618) == 0) +{ +lean_object* x_619; lean_object* x_620; +lean_dec(x_600); +lean_dec(x_586); +lean_dec(x_523); +x_619 = lean_ctor_get(x_617, 1); +lean_inc(x_619); +lean_dec(x_617); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -17459,314 +17547,143 @@ lean_inc(x_5); lean_inc(x_4); lean_inc(x_22); lean_inc(x_19); -x_618 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_617, x_6, x_7, x_8, x_9, x_10, x_11, x_616); -x_619 = lean_ctor_get(x_618, 1); -lean_inc(x_619); -lean_dec(x_618); -x_487 = x_619; -goto block_521; -} -else +lean_inc(x_1); +x_620 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_619); +if (lean_obj_tag(x_620) == 0) { -lean_object* x_620; lean_object* x_621; lean_object* x_622; lean_object* x_623; lean_object* x_624; -lean_dec(x_482); -lean_dec(x_463); -lean_dec(x_462); +lean_object* x_621; lean_object* x_622; lean_object* x_623; lean_object* x_624; +lean_dec(x_528); +lean_dec(x_522); +lean_dec(x_499); +lean_dec(x_498); lean_dec(x_22); lean_dec(x_19); -lean_dec(x_5); -lean_dec(x_4); -lean_dec(x_1); -x_620 = lean_ctor_get(x_613, 1); -lean_inc(x_620); -lean_dec(x_613); -x_621 = lean_box(0); -x_622 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___lambda__1(x_608, x_621, x_6, x_7, x_8, x_9, x_10, x_11, x_620); lean_dec(x_11); lean_dec(x_10); lean_dec(x_9); lean_dec(x_8); lean_dec(x_7); lean_dec(x_6); -x_623 = lean_ctor_get(x_622, 0); -lean_inc(x_623); -x_624 = lean_ctor_get(x_622, 1); -lean_inc(x_624); -lean_dec(x_622); -x_13 = x_623; -x_14 = x_624; +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_621 = lean_ctor_get(x_620, 0); +lean_inc(x_621); +x_622 = lean_ctor_get(x_620, 1); +lean_inc(x_622); +lean_dec(x_620); +x_623 = lean_box(0); +x_624 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_624, 0, x_621); +lean_ctor_set(x_624, 1, x_623); +x_13 = x_624; +x_14 = x_622; goto block_17; } -} else { lean_object* x_625; -lean_dec(x_608); -x_625 = lean_ctor_get(x_613, 1); +x_625 = lean_ctor_get(x_620, 1); lean_inc(x_625); -lean_dec(x_613); -x_487 = x_625; -goto block_521; +lean_dec(x_620); +x_529 = x_625; +goto block_574; } } else { -lean_object* x_626; -lean_dec(x_608); -x_626 = lean_ctor_get(x_610, 1); +lean_object* x_626; lean_object* x_627; lean_object* x_628; +x_626 = lean_ctor_get(x_617, 1); lean_inc(x_626); -lean_dec(x_610); -x_487 = x_626; -goto block_521; -} -} -else -{ -lean_object* x_627; -x_627 = lean_ctor_get(x_607, 1); +lean_dec(x_617); +x_627 = lean_ctor_get(x_618, 0); lean_inc(x_627); -lean_dec(x_607); -x_487 = x_627; -goto block_521; -} -} -else +lean_dec(x_618); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_523); +x_628 = l_Lean_Meta_getLevel(x_523, x_8, x_9, x_10, x_11, x_626); +if (lean_obj_tag(x_628) == 0) { -lean_object* x_628; -lean_dec(x_572); -lean_dec(x_545); -lean_dec(x_531); -lean_dec(x_483); -x_628 = lean_ctor_get(x_592, 1); -lean_inc(x_628); -lean_dec(x_592); -x_487 = x_628; -goto block_521; -} -} -else -{ -lean_object* x_629; -lean_dec(x_574); -lean_dec(x_572); -lean_dec(x_545); -lean_dec(x_531); -lean_dec(x_483); -x_629 = lean_ctor_get(x_576, 1); +lean_object* x_629; lean_object* x_630; lean_object* x_631; +x_629 = lean_ctor_get(x_628, 0); lean_inc(x_629); -lean_dec(x_576); -x_487 = x_629; -goto block_521; -} -} -else -{ -lean_object* x_630; -lean_dec(x_572); -lean_dec(x_545); -lean_dec(x_531); -lean_dec(x_483); -x_630 = lean_ctor_get(x_573, 1); +x_630 = lean_ctor_get(x_628, 1); lean_inc(x_630); -lean_dec(x_573); -x_487 = x_630; -goto block_521; -} -} -} -else -{ -lean_object* x_631; lean_object* x_632; lean_object* x_633; -lean_dec(x_545); -lean_dec(x_531); -lean_dec(x_483); -lean_dec(x_482); -lean_dec(x_463); -lean_dec(x_462); -lean_dec(x_22); -lean_dec(x_19); -lean_dec(x_11); -lean_dec(x_10); -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_1); -x_631 = lean_ctor_get(x_558, 1); -lean_inc(x_631); -lean_dec(x_558); -x_632 = lean_box(0); -x_633 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_633, 0, x_554); -lean_ctor_set(x_633, 1, x_632); -x_13 = x_633; -x_14 = x_631; -goto block_17; -} -} -else -{ -lean_object* x_634; -lean_dec(x_554); -lean_dec(x_545); -lean_dec(x_531); -lean_dec(x_483); -x_634 = lean_ctor_get(x_558, 1); -lean_inc(x_634); -lean_dec(x_558); -x_487 = x_634; -goto block_521; -} -} -else -{ -lean_object* x_635; -lean_dec(x_554); -lean_dec(x_545); -lean_dec(x_531); -lean_dec(x_483); -x_635 = lean_ctor_get(x_555, 1); -lean_inc(x_635); -lean_dec(x_555); -x_487 = x_635; -goto block_521; -} -} -else -{ -lean_object* x_636; -lean_dec(x_537); -lean_dec(x_534); -lean_dec(x_531); -lean_dec(x_483); -x_636 = lean_ctor_get(x_539, 1); -lean_inc(x_636); -lean_dec(x_539); -x_487 = x_636; -goto block_521; -} -} -else -{ -lean_object* x_637; -lean_dec(x_534); -lean_dec(x_531); -lean_dec(x_483); -x_637 = lean_ctor_get(x_536, 1); -lean_inc(x_637); -lean_dec(x_536); -x_487 = x_637; -goto block_521; -} -} -else -{ -lean_object* x_638; -lean_dec(x_531); -lean_dec(x_483); -x_638 = lean_ctor_get(x_533, 1); -lean_inc(x_638); -lean_dec(x_533); -x_487 = x_638; -goto block_521; -} -} -else -{ -lean_object* x_639; -lean_dec(x_483); -x_639 = lean_ctor_get(x_530, 1); -lean_inc(x_639); -lean_dec(x_530); -x_487 = x_639; -goto block_521; -} -} -else -{ -lean_object* x_640; -lean_dec(x_483); -x_640 = lean_ctor_get(x_527, 1); -lean_inc(x_640); -lean_dec(x_527); -x_487 = x_640; -goto block_521; -} -} -else -{ -lean_object* x_641; lean_object* x_642; +lean_dec(x_628); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_641 = l_Lean_Meta_isMonad_x3f(x_462, x_8, x_9, x_10, x_11, x_486); -x_642 = lean_ctor_get(x_641, 0); -lean_inc(x_642); -if (lean_obj_tag(x_642) == 0) +lean_inc(x_499); +x_631 = l_Lean_Meta_getLevel(x_499, x_8, x_9, x_10, x_11, x_630); +if (lean_obj_tag(x_631) == 0) { -lean_object* x_643; lean_object* x_644; -lean_dec(x_483); -lean_dec(x_482); -lean_dec(x_480); -lean_dec(x_463); -x_643 = lean_ctor_get(x_641, 1); -lean_inc(x_643); -lean_dec(x_641); -x_644 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_643); -lean_dec(x_7); -return x_644; -} -else +lean_object* x_632; lean_object* x_633; lean_object* x_634; lean_object* x_635; 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_object* x_644; uint8_t x_645; lean_object* x_646; lean_object* x_647; +x_632 = lean_ctor_get(x_631, 0); +lean_inc(x_632); +x_633 = lean_ctor_get(x_631, 1); +lean_inc(x_633); +lean_dec(x_631); +x_634 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_634, 0, x_632); +lean_ctor_set(x_634, 1, x_597); +x_635 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_635, 0, x_629); +lean_ctor_set(x_635, 1, x_634); +x_636 = l_Lean_Meta_isCoeDecl___closed__34; +x_637 = l_Lean_mkConst(x_636, x_635); +x_638 = l_Lean_Syntax_mkAntiquotNode___closed__9; +lean_inc(x_523); +x_639 = lean_array_push(x_638, x_523); +x_640 = l_Lean_Meta_commitWhen___at___private_Lean_Meta_ExprDefEq_0__Lean_Meta_isDefEqEta___spec__1___closed__1; +x_641 = lean_array_push(x_639, x_640); +lean_inc(x_499); +x_642 = lean_array_push(x_641, x_499); +x_643 = l_Lean_mkAppN(x_637, x_642); +lean_dec(x_642); +x_644 = l_Array_myMacro____x40_Init_Data_Array_Subarray___hyg_932____closed__4; +x_645 = 0; +lean_inc(x_523); +x_646 = l_Lean_mkForall(x_644, x_645, x_523, x_643); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_6); +x_647 = l_Lean_Elab_Term_synthesizeInst(x_646, x_6, x_7, x_8, x_9, x_10, x_11, x_633); +if (lean_obj_tag(x_647) == 0) { -lean_object* x_645; lean_object* x_646; lean_object* x_647; 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_object* x_657; lean_object* x_658; lean_object* x_659; lean_object* x_660; lean_object* x_661; lean_object* x_662; -x_645 = lean_ctor_get(x_641, 1); -lean_inc(x_645); -lean_dec(x_641); -x_646 = lean_ctor_get(x_642, 0); -lean_inc(x_646); -if (lean_is_exclusive(x_642)) { - lean_ctor_release(x_642, 0); - x_647 = x_642; -} else { - lean_dec_ref(x_642); - x_647 = lean_box(0); -} -if (lean_is_scalar(x_647)) { - x_648 = lean_alloc_ctor(1, 1, 0); -} else { - x_648 = x_647; -} -lean_ctor_set(x_648, 0, x_482); -if (lean_is_scalar(x_480)) { - x_649 = lean_alloc_ctor(1, 1, 0); -} else { - x_649 = x_480; -} -lean_ctor_set(x_649, 0, x_483); -x_650 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_650, 0, x_463); -x_651 = lean_box(0); -x_652 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_652, 0, x_646); +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_object* x_657; lean_object* x_658; lean_object* x_659; lean_object* x_660; lean_object* x_661; lean_object* x_662; +x_648 = lean_ctor_get(x_647, 0); +lean_inc(x_648); +x_649 = lean_ctor_get(x_647, 1); +lean_inc(x_649); +lean_dec(x_647); +x_650 = l_Lean_Meta_isCoeDecl___closed__43; +x_651 = l_Lean_mkConst(x_650, x_600); +x_652 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___closed__5; +lean_inc(x_522); +x_653 = lean_array_push(x_652, x_522); +lean_inc(x_498); +x_654 = lean_array_push(x_653, x_498); +x_655 = lean_array_push(x_654, x_523); +lean_inc(x_499); +x_656 = lean_array_push(x_655, x_499); +x_657 = lean_array_push(x_656, x_586); +x_658 = lean_array_push(x_657, x_648); +x_659 = lean_array_push(x_658, x_627); lean_inc(x_4); -x_653 = lean_alloc_ctor(1, 1, 0); -lean_ctor_set(x_653, 0, x_4); -x_654 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; -x_655 = lean_array_push(x_654, x_648); -x_656 = lean_array_push(x_655, x_649); -x_657 = lean_array_push(x_656, x_650); -x_658 = lean_array_push(x_657, x_651); -x_659 = lean_array_push(x_658, x_652); -x_660 = lean_array_push(x_659, x_653); -x_661 = l_Lean_Meta_isCoeDecl___closed__45; +x_660 = lean_array_push(x_659, x_4); +x_661 = l_Lean_mkAppN(x_651, x_660); +lean_dec(x_660); lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_662 = l_Lean_Meta_mkAppOptM(x_661, x_660, x_8, x_9, x_10, x_11, x_645); +x_662 = l_Lean_Meta_expandCoe(x_661, x_8, x_9, x_10, x_11, x_649); if (lean_obj_tag(x_662) == 0) { lean_object* x_663; lean_object* x_664; lean_object* x_665; @@ -17779,9 +17696,172 @@ lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_665 = l_Lean_Meta_expandCoe(x_663, x_8, x_9, x_10, x_11, x_664); +lean_inc(x_663); +x_665 = l_Lean_Meta_inferType(x_663, x_8, x_9, x_10, x_11, x_664); if (lean_obj_tag(x_665) == 0) { +lean_object* x_666; lean_object* x_667; lean_object* x_668; +x_666 = lean_ctor_get(x_665, 0); +lean_inc(x_666); +x_667 = lean_ctor_get(x_665, 1); +lean_inc(x_667); +lean_dec(x_665); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_19); +x_668 = l_Lean_Meta_isExprDefEq(x_19, x_666, x_8, x_9, x_10, x_11, x_667); +if (lean_obj_tag(x_668) == 0) +{ +lean_object* x_669; uint8_t x_670; +x_669 = lean_ctor_get(x_668, 0); +lean_inc(x_669); +x_670 = lean_unbox(x_669); +lean_dec(x_669); +if (x_670 == 0) +{ +lean_object* x_671; lean_object* x_672; lean_object* x_673; lean_object* x_674; +lean_dec(x_663); +x_671 = lean_ctor_get(x_668, 1); +lean_inc(x_671); +lean_dec(x_668); +x_672 = lean_box(0); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +lean_inc(x_6); +lean_inc(x_5); +lean_inc(x_4); +lean_inc(x_22); +lean_inc(x_19); +x_673 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_672, x_6, x_7, x_8, x_9, x_10, x_11, x_671); +x_674 = lean_ctor_get(x_673, 1); +lean_inc(x_674); +lean_dec(x_673); +x_529 = x_674; +goto block_574; +} +else +{ +lean_object* x_675; lean_object* x_676; lean_object* x_677; lean_object* x_678; lean_object* x_679; +lean_dec(x_528); +lean_dec(x_522); +lean_dec(x_499); +lean_dec(x_498); +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_5); +lean_dec(x_4); +lean_dec(x_1); +x_675 = lean_ctor_get(x_668, 1); +lean_inc(x_675); +lean_dec(x_668); +x_676 = lean_box(0); +x_677 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryLiftAndCoe___lambda__1(x_663, x_676, x_6, x_7, x_8, x_9, x_10, x_11, x_675); +lean_dec(x_11); +lean_dec(x_10); +lean_dec(x_9); +lean_dec(x_8); +lean_dec(x_7); +lean_dec(x_6); +x_678 = lean_ctor_get(x_677, 0); +lean_inc(x_678); +x_679 = lean_ctor_get(x_677, 1); +lean_inc(x_679); +lean_dec(x_677); +x_13 = x_678; +x_14 = x_679; +goto block_17; +} +} +else +{ +lean_object* x_680; +lean_dec(x_663); +x_680 = lean_ctor_get(x_668, 1); +lean_inc(x_680); +lean_dec(x_668); +x_529 = x_680; +goto block_574; +} +} +else +{ +lean_object* x_681; +lean_dec(x_663); +x_681 = lean_ctor_get(x_665, 1); +lean_inc(x_681); +lean_dec(x_665); +x_529 = x_681; +goto block_574; +} +} +else +{ +lean_object* x_682; +x_682 = lean_ctor_get(x_662, 1); +lean_inc(x_682); +lean_dec(x_662); +x_529 = x_682; +goto block_574; +} +} +else +{ +lean_object* x_683; +lean_dec(x_627); +lean_dec(x_600); +lean_dec(x_586); +lean_dec(x_523); +x_683 = lean_ctor_get(x_647, 1); +lean_inc(x_683); +lean_dec(x_647); +x_529 = x_683; +goto block_574; +} +} +else +{ +lean_object* x_684; +lean_dec(x_629); +lean_dec(x_627); +lean_dec(x_600); +lean_dec(x_586); +lean_dec(x_523); +x_684 = lean_ctor_get(x_631, 1); +lean_inc(x_684); +lean_dec(x_631); +x_529 = x_684; +goto block_574; +} +} +else +{ +lean_object* x_685; +lean_dec(x_627); +lean_dec(x_600); +lean_dec(x_586); +lean_dec(x_523); +x_685 = lean_ctor_get(x_628, 1); +lean_inc(x_685); +lean_dec(x_628); +x_529 = x_685; +goto block_574; +} +} +} +else +{ +lean_object* x_686; lean_object* x_687; lean_object* x_688; +lean_dec(x_600); +lean_dec(x_586); +lean_dec(x_528); +lean_dec(x_523); +lean_dec(x_522); +lean_dec(x_499); +lean_dec(x_498); lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -17793,49 +17873,177 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -return x_665; -} -else -{ -lean_object* x_666; lean_object* x_667; -x_666 = lean_ctor_get(x_665, 1); -lean_inc(x_666); -lean_dec(x_665); -x_667 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_651, x_6, x_7, x_8, x_9, x_10, x_11, x_666); -lean_dec(x_7); -lean_dec(x_1); -return x_667; +x_686 = lean_ctor_get(x_613, 1); +lean_inc(x_686); +lean_dec(x_613); +x_687 = lean_box(0); +x_688 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_688, 0, x_609); +lean_ctor_set(x_688, 1, x_687); +x_13 = x_688; +x_14 = x_686; +goto block_17; } } else { -lean_object* x_668; lean_object* x_669; -x_668 = lean_ctor_get(x_662, 1); -lean_inc(x_668); -lean_dec(x_662); -x_669 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_651, x_6, x_7, x_8, x_9, x_10, x_11, x_668); -lean_dec(x_7); -lean_dec(x_1); -return x_669; +lean_object* x_689; +lean_dec(x_609); +lean_dec(x_600); +lean_dec(x_586); +lean_dec(x_523); +x_689 = lean_ctor_get(x_613, 1); +lean_inc(x_689); +lean_dec(x_613); +x_529 = x_689; +goto block_574; } } -} -block_521: +else { -lean_object* x_488; lean_object* x_489; +lean_object* x_690; +lean_dec(x_609); +lean_dec(x_600); +lean_dec(x_586); +lean_dec(x_523); +x_690 = lean_ctor_get(x_610, 1); +lean_inc(x_690); +lean_dec(x_610); +x_529 = x_690; +goto block_574; +} +} +else +{ +lean_object* x_691; +lean_dec(x_592); +lean_dec(x_589); +lean_dec(x_586); +lean_dec(x_523); +x_691 = lean_ctor_get(x_594, 1); +lean_inc(x_691); +lean_dec(x_594); +x_529 = x_691; +goto block_574; +} +} +else +{ +lean_object* x_692; +lean_dec(x_589); +lean_dec(x_586); +lean_dec(x_523); +x_692 = lean_ctor_get(x_591, 1); +lean_inc(x_692); +lean_dec(x_591); +x_529 = x_692; +goto block_574; +} +} +else +{ +lean_object* x_693; +lean_dec(x_586); +lean_dec(x_523); +x_693 = lean_ctor_get(x_588, 1); +lean_inc(x_693); +lean_dec(x_588); +x_529 = x_693; +goto block_574; +} +} +else +{ +lean_object* x_694; +lean_dec(x_523); +x_694 = lean_ctor_get(x_585, 1); +lean_inc(x_694); +lean_dec(x_585); +x_529 = x_694; +goto block_574; +} +} +else +{ +lean_object* x_695; +lean_dec(x_523); +x_695 = lean_ctor_get(x_582, 1); +lean_inc(x_695); +lean_dec(x_582); +x_529 = x_695; +goto block_574; +} +} +block_574: +{ +lean_object* x_530; lean_object* x_531; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); lean_inc(x_8); -x_488 = l_Lean_Meta_isMonad_x3f(x_482, x_8, x_9, x_10, x_11, x_487); -x_489 = lean_ctor_get(x_488, 0); -lean_inc(x_489); -if (lean_obj_tag(x_489) == 0) +x_530 = l_Lean_Meta_isMonad_x3f(x_522, x_8, x_9, x_10, x_11, x_529); +x_531 = lean_ctor_get(x_530, 0); +lean_inc(x_531); +if (lean_obj_tag(x_531) == 0) { -lean_object* x_490; lean_object* x_491; -x_490 = lean_ctor_get(x_488, 1); -lean_inc(x_490); -lean_dec(x_488); +lean_object* x_532; lean_object* x_533; uint8_t x_534; +x_532 = lean_ctor_get(x_530, 1); +lean_inc(x_532); +lean_dec(x_530); +x_533 = l_Lean_Elab_Term_autoLift; +x_534 = l_Lean_Option_get___at_Lean_Elab_addMacroStack___spec__1(x_528, x_533); +lean_dec(x_528); +if (x_534 == 0) +{ +lean_object* x_535; +lean_dec(x_499); +lean_dec(x_498); +x_535 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_532); +lean_dec(x_7); +if (lean_obj_tag(x_535) == 0) +{ +lean_object* x_536; lean_object* x_537; lean_object* x_538; lean_object* x_539; +x_536 = lean_ctor_get(x_535, 0); +lean_inc(x_536); +x_537 = lean_ctor_get(x_535, 1); +lean_inc(x_537); +lean_dec(x_535); +x_538 = lean_box(0); +x_539 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_539, 0, x_536); +lean_ctor_set(x_539, 1, x_538); +x_13 = x_539; +x_14 = x_537; +goto block_17; +} +else +{ +lean_object* x_540; lean_object* x_541; lean_object* x_542; lean_object* x_543; +x_540 = lean_ctor_get(x_535, 0); +lean_inc(x_540); +x_541 = lean_ctor_get(x_535, 1); +lean_inc(x_541); +if (lean_is_exclusive(x_535)) { + lean_ctor_release(x_535, 0); + lean_ctor_release(x_535, 1); + x_542 = x_535; +} else { + lean_dec_ref(x_535); + x_542 = lean_box(0); +} +if (lean_is_scalar(x_542)) { + x_543 = lean_alloc_ctor(1, 2, 0); +} else { + x_543 = x_542; +} +lean_ctor_set(x_543, 0, x_540); +lean_ctor_set(x_543, 1, x_541); +return x_543; +} +} +else +{ +lean_object* x_544; lean_inc(x_11); lean_inc(x_10); lean_inc(x_9); @@ -17845,64 +18053,64 @@ lean_inc(x_6); lean_inc(x_4); lean_inc(x_22); lean_inc(x_1); -x_491 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_462, x_463, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_490); -if (lean_obj_tag(x_491) == 0) +x_544 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryPureCoe_x3f(x_1, x_498, x_499, x_22, x_4, x_6, x_7, x_8, x_9, x_10, x_11, x_532); +if (lean_obj_tag(x_544) == 0) { -lean_object* x_492; -x_492 = lean_ctor_get(x_491, 0); -lean_inc(x_492); -if (lean_obj_tag(x_492) == 0) +lean_object* x_545; +x_545 = lean_ctor_get(x_544, 0); +lean_inc(x_545); +if (lean_obj_tag(x_545) == 0) { -lean_object* x_493; lean_object* x_494; -x_493 = lean_ctor_get(x_491, 1); -lean_inc(x_493); -lean_dec(x_491); -x_494 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_493); +lean_object* x_546; lean_object* x_547; +x_546 = lean_ctor_get(x_544, 1); +lean_inc(x_546); +lean_dec(x_544); +x_547 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_546); lean_dec(x_7); -if (lean_obj_tag(x_494) == 0) +if (lean_obj_tag(x_547) == 0) { -lean_object* x_495; lean_object* x_496; lean_object* x_497; lean_object* x_498; -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_box(0); -x_498 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_498, 0, x_495); -lean_ctor_set(x_498, 1, x_497); -x_13 = x_498; -x_14 = x_496; +lean_object* x_548; lean_object* x_549; lean_object* x_550; lean_object* x_551; +x_548 = lean_ctor_get(x_547, 0); +lean_inc(x_548); +x_549 = lean_ctor_get(x_547, 1); +lean_inc(x_549); +lean_dec(x_547); +x_550 = lean_box(0); +x_551 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_551, 0, x_548); +lean_ctor_set(x_551, 1, x_550); +x_13 = x_551; +x_14 = x_549; goto block_17; } else { -lean_object* x_499; lean_object* x_500; lean_object* x_501; lean_object* x_502; -x_499 = lean_ctor_get(x_494, 0); -lean_inc(x_499); -x_500 = lean_ctor_get(x_494, 1); -lean_inc(x_500); -if (lean_is_exclusive(x_494)) { - lean_ctor_release(x_494, 0); - lean_ctor_release(x_494, 1); - x_501 = x_494; +lean_object* x_552; lean_object* x_553; lean_object* x_554; lean_object* x_555; +x_552 = lean_ctor_get(x_547, 0); +lean_inc(x_552); +x_553 = lean_ctor_get(x_547, 1); +lean_inc(x_553); +if (lean_is_exclusive(x_547)) { + lean_ctor_release(x_547, 0); + lean_ctor_release(x_547, 1); + x_554 = x_547; } else { - lean_dec_ref(x_494); - x_501 = lean_box(0); + lean_dec_ref(x_547); + x_554 = lean_box(0); } -if (lean_is_scalar(x_501)) { - x_502 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_554)) { + x_555 = lean_alloc_ctor(1, 2, 0); } else { - x_502 = x_501; + x_555 = x_554; } -lean_ctor_set(x_502, 0, x_499); -lean_ctor_set(x_502, 1, x_500); -return x_502; +lean_ctor_set(x_555, 0, x_552); +lean_ctor_set(x_555, 1, x_553); +return x_555; } } else { -lean_object* x_503; lean_object* x_504; lean_object* x_505; lean_object* x_506; +lean_object* x_556; lean_object* x_557; lean_object* x_558; lean_object* x_559; lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -17914,24 +18122,24 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_503 = lean_ctor_get(x_491, 1); -lean_inc(x_503); -lean_dec(x_491); -x_504 = lean_ctor_get(x_492, 0); -lean_inc(x_504); -lean_dec(x_492); -x_505 = lean_box(0); -x_506 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_506, 0, x_504); -lean_ctor_set(x_506, 1, x_505); -x_13 = x_506; -x_14 = x_503; +x_556 = lean_ctor_get(x_544, 1); +lean_inc(x_556); +lean_dec(x_544); +x_557 = lean_ctor_get(x_545, 0); +lean_inc(x_557); +lean_dec(x_545); +x_558 = lean_box(0); +x_559 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_559, 0, x_557); +lean_ctor_set(x_559, 1, x_558); +x_13 = x_559; +x_14 = x_556; goto block_17; } } else { -lean_object* x_507; lean_object* x_508; lean_object* x_509; lean_object* x_510; +lean_object* x_560; lean_object* x_561; lean_object* x_562; lean_object* x_563; lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -17943,90 +18151,174 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_507 = lean_ctor_get(x_491, 0); -lean_inc(x_507); -x_508 = lean_ctor_get(x_491, 1); -lean_inc(x_508); -if (lean_is_exclusive(x_491)) { - lean_ctor_release(x_491, 0); - lean_ctor_release(x_491, 1); - x_509 = x_491; +x_560 = lean_ctor_get(x_544, 0); +lean_inc(x_560); +x_561 = lean_ctor_get(x_544, 1); +lean_inc(x_561); +if (lean_is_exclusive(x_544)) { + lean_ctor_release(x_544, 0); + lean_ctor_release(x_544, 1); + x_562 = x_544; } else { - lean_dec_ref(x_491); - x_509 = lean_box(0); + lean_dec_ref(x_544); + x_562 = lean_box(0); } -if (lean_is_scalar(x_509)) { - x_510 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_562)) { + x_563 = lean_alloc_ctor(1, 2, 0); } else { - x_510 = x_509; + x_563 = x_562; +} +lean_ctor_set(x_563, 0, x_560); +lean_ctor_set(x_563, 1, x_561); +return x_563; } -lean_ctor_set(x_510, 0, x_507); -lean_ctor_set(x_510, 1, x_508); -return x_510; } } else { -lean_object* x_511; lean_object* x_512; -lean_dec(x_489); -lean_dec(x_463); -lean_dec(x_462); -x_511 = lean_ctor_get(x_488, 1); -lean_inc(x_511); -lean_dec(x_488); -x_512 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_511); +lean_object* x_564; lean_object* x_565; +lean_dec(x_531); +lean_dec(x_528); +lean_dec(x_499); +lean_dec(x_498); +x_564 = lean_ctor_get(x_530, 1); +lean_inc(x_564); +lean_dec(x_530); +x_565 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_564); lean_dec(x_7); -if (lean_obj_tag(x_512) == 0) +if (lean_obj_tag(x_565) == 0) { -lean_object* x_513; lean_object* x_514; lean_object* x_515; lean_object* x_516; -x_513 = lean_ctor_get(x_512, 0); -lean_inc(x_513); -x_514 = lean_ctor_get(x_512, 1); -lean_inc(x_514); -lean_dec(x_512); -x_515 = lean_box(0); -x_516 = lean_alloc_ctor(0, 2, 0); -lean_ctor_set(x_516, 0, x_513); -lean_ctor_set(x_516, 1, x_515); -x_13 = x_516; -x_14 = x_514; +lean_object* x_566; lean_object* x_567; lean_object* x_568; lean_object* x_569; +x_566 = lean_ctor_get(x_565, 0); +lean_inc(x_566); +x_567 = lean_ctor_get(x_565, 1); +lean_inc(x_567); +lean_dec(x_565); +x_568 = lean_box(0); +x_569 = lean_alloc_ctor(0, 2, 0); +lean_ctor_set(x_569, 0, x_566); +lean_ctor_set(x_569, 1, x_568); +x_13 = x_569; +x_14 = x_567; goto block_17; } else { -lean_object* x_517; lean_object* x_518; lean_object* x_519; lean_object* x_520; -x_517 = lean_ctor_get(x_512, 0); -lean_inc(x_517); -x_518 = lean_ctor_get(x_512, 1); -lean_inc(x_518); -if (lean_is_exclusive(x_512)) { - lean_ctor_release(x_512, 0); - lean_ctor_release(x_512, 1); - x_519 = x_512; +lean_object* x_570; lean_object* x_571; lean_object* x_572; lean_object* x_573; +x_570 = lean_ctor_get(x_565, 0); +lean_inc(x_570); +x_571 = lean_ctor_get(x_565, 1); +lean_inc(x_571); +if (lean_is_exclusive(x_565)) { + lean_ctor_release(x_565, 0); + lean_ctor_release(x_565, 1); + x_572 = x_565; } else { - lean_dec_ref(x_512); - x_519 = lean_box(0); + lean_dec_ref(x_565); + x_572 = lean_box(0); } -if (lean_is_scalar(x_519)) { - x_520 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_572)) { + x_573 = lean_alloc_ctor(1, 2, 0); } else { - x_520 = x_519; + x_573 = x_572; } -lean_ctor_set(x_520, 0, x_517); -lean_ctor_set(x_520, 1, x_518); -return x_520; +lean_ctor_set(x_573, 0, x_570); +lean_ctor_set(x_573, 1, x_571); +return x_573; } } } } else { -lean_object* x_670; lean_object* x_671; lean_object* x_672; lean_object* x_673; -lean_dec(x_483); -lean_dec(x_482); -lean_dec(x_480); -lean_dec(x_463); -lean_dec(x_462); +lean_object* x_696; lean_object* x_697; lean_object* x_698; +x_696 = lean_ctor_get(x_524, 1); +lean_inc(x_696); +lean_dec(x_524); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_697 = l_Lean_Meta_isMonad_x3f(x_498, x_8, x_9, x_10, x_11, x_696); +x_698 = lean_ctor_get(x_697, 0); +lean_inc(x_698); +if (lean_obj_tag(x_698) == 0) +{ +lean_object* x_699; lean_object* x_700; +lean_dec(x_523); +lean_dec(x_522); +lean_dec(x_520); +lean_dec(x_499); +x_699 = lean_ctor_get(x_697, 1); +lean_inc(x_699); +lean_dec(x_697); +x_700 = l___private_Lean_Elab_Term_0__Lean_Elab_Term_tryCoe(x_1, x_19, x_22, x_4, x_5, x_6, x_7, x_8, x_9, x_10, x_11, x_699); +lean_dec(x_7); +return x_700; +} +else +{ +lean_object* x_701; lean_object* x_702; lean_object* x_703; lean_object* x_704; lean_object* x_705; lean_object* x_706; lean_object* x_707; lean_object* x_708; lean_object* x_709; lean_object* x_710; lean_object* x_711; lean_object* x_712; lean_object* x_713; lean_object* x_714; lean_object* x_715; lean_object* x_716; lean_object* x_717; lean_object* x_718; +x_701 = lean_ctor_get(x_697, 1); +lean_inc(x_701); +lean_dec(x_697); +x_702 = lean_ctor_get(x_698, 0); +lean_inc(x_702); +if (lean_is_exclusive(x_698)) { + lean_ctor_release(x_698, 0); + x_703 = x_698; +} else { + lean_dec_ref(x_698); + x_703 = lean_box(0); +} +if (lean_is_scalar(x_703)) { + x_704 = lean_alloc_ctor(1, 1, 0); +} else { + x_704 = x_703; +} +lean_ctor_set(x_704, 0, x_522); +if (lean_is_scalar(x_520)) { + x_705 = lean_alloc_ctor(1, 1, 0); +} else { + x_705 = x_520; +} +lean_ctor_set(x_705, 0, x_523); +x_706 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_706, 0, x_499); +x_707 = lean_box(0); +x_708 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_708, 0, x_702); +lean_inc(x_4); +x_709 = lean_alloc_ctor(1, 1, 0); +lean_ctor_set(x_709, 0, x_4); +x_710 = l_Lean_Syntax_mkAntiquotSpliceNode___closed__5; +x_711 = lean_array_push(x_710, x_704); +x_712 = lean_array_push(x_711, x_705); +x_713 = lean_array_push(x_712, x_706); +x_714 = lean_array_push(x_713, x_707); +x_715 = lean_array_push(x_714, x_708); +x_716 = lean_array_push(x_715, x_709); +x_717 = l_Lean_Meta_isCoeDecl___closed__45; +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_718 = l_Lean_Meta_mkAppOptM(x_717, x_716, x_8, x_9, x_10, x_11, x_701); +if (lean_obj_tag(x_718) == 0) +{ +lean_object* x_719; lean_object* x_720; lean_object* x_721; +x_719 = lean_ctor_get(x_718, 0); +lean_inc(x_719); +x_720 = lean_ctor_get(x_718, 1); +lean_inc(x_720); +lean_dec(x_718); +lean_inc(x_11); +lean_inc(x_10); +lean_inc(x_9); +lean_inc(x_8); +x_721 = l_Lean_Meta_expandCoe(x_719, x_8, x_9, x_10, x_11, x_720); +if (lean_obj_tag(x_721) == 0) +{ lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -18038,34 +18330,42 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_670 = lean_ctor_get(x_484, 0); -lean_inc(x_670); -x_671 = lean_ctor_get(x_484, 1); -lean_inc(x_671); -if (lean_is_exclusive(x_484)) { - lean_ctor_release(x_484, 0); - lean_ctor_release(x_484, 1); - x_672 = x_484; -} else { - lean_dec_ref(x_484); - x_672 = lean_box(0); +return x_721; } -if (lean_is_scalar(x_672)) { - x_673 = lean_alloc_ctor(1, 2, 0); -} else { - x_673 = x_672; +else +{ +lean_object* x_722; lean_object* x_723; +x_722 = lean_ctor_get(x_721, 1); +lean_inc(x_722); +lean_dec(x_721); +x_723 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_707, x_6, x_7, x_8, x_9, x_10, x_11, x_722); +lean_dec(x_7); +lean_dec(x_1); +return x_723; +} +} +else +{ +lean_object* x_724; lean_object* x_725; +x_724 = lean_ctor_get(x_718, 1); +lean_inc(x_724); +lean_dec(x_718); +x_725 = l_Lean_Elab_Term_throwTypeMismatchError___rarg(x_1, x_19, x_22, x_4, x_5, x_707, x_6, x_7, x_8, x_9, x_10, x_11, x_724); +lean_dec(x_7); +lean_dec(x_1); +return x_725; } -lean_ctor_set(x_673, 0, x_670); -lean_ctor_set(x_673, 1, x_671); -return x_673; } } } else { -lean_object* x_674; lean_object* x_675; lean_object* x_676; lean_object* x_677; -lean_dec(x_463); -lean_dec(x_462); +lean_object* x_726; lean_object* x_727; lean_object* x_728; lean_object* x_729; +lean_dec(x_523); +lean_dec(x_522); +lean_dec(x_520); +lean_dec(x_499); +lean_dec(x_498); lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -18077,33 +18377,34 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_674 = lean_ctor_get(x_464, 0); -lean_inc(x_674); -x_675 = lean_ctor_get(x_464, 1); -lean_inc(x_675); -if (lean_is_exclusive(x_464)) { - lean_ctor_release(x_464, 0); - lean_ctor_release(x_464, 1); - x_676 = x_464; +x_726 = lean_ctor_get(x_524, 0); +lean_inc(x_726); +x_727 = lean_ctor_get(x_524, 1); +lean_inc(x_727); +if (lean_is_exclusive(x_524)) { + lean_ctor_release(x_524, 0); + lean_ctor_release(x_524, 1); + x_728 = x_524; } else { - lean_dec_ref(x_464); - x_676 = lean_box(0); + lean_dec_ref(x_524); + x_728 = lean_box(0); } -if (lean_is_scalar(x_676)) { - x_677 = lean_alloc_ctor(1, 2, 0); +if (lean_is_scalar(x_728)) { + x_729 = lean_alloc_ctor(1, 2, 0); } else { - x_677 = x_676; -} -lean_ctor_set(x_677, 0, x_674); -lean_ctor_set(x_677, 1, x_675); -return x_677; + x_729 = x_728; } +lean_ctor_set(x_729, 0, x_726); +lean_ctor_set(x_729, 1, x_727); +return x_729; } } } else { -uint8_t x_678; +lean_object* x_730; lean_object* x_731; lean_object* x_732; lean_object* x_733; +lean_dec(x_499); +lean_dec(x_498); lean_dec(x_22); lean_dec(x_19); lean_dec(x_11); @@ -18115,29 +18416,67 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_678 = !lean_is_exclusive(x_24); -if (x_678 == 0) +x_730 = lean_ctor_get(x_500, 0); +lean_inc(x_730); +x_731 = lean_ctor_get(x_500, 1); +lean_inc(x_731); +if (lean_is_exclusive(x_500)) { + lean_ctor_release(x_500, 0); + lean_ctor_release(x_500, 1); + x_732 = x_500; +} else { + lean_dec_ref(x_500); + x_732 = lean_box(0); +} +if (lean_is_scalar(x_732)) { + x_733 = lean_alloc_ctor(1, 2, 0); +} else { + x_733 = x_732; +} +lean_ctor_set(x_733, 0, x_730); +lean_ctor_set(x_733, 1, x_731); +return x_733; +} +} +} +} +else +{ +uint8_t x_734; +lean_dec(x_22); +lean_dec(x_19); +lean_dec(x_11); +lean_dec(x_10); +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_1); +x_734 = !lean_is_exclusive(x_24); +if (x_734 == 0) { return x_24; } else { -lean_object* x_679; lean_object* x_680; lean_object* x_681; -x_679 = lean_ctor_get(x_24, 0); -x_680 = lean_ctor_get(x_24, 1); -lean_inc(x_680); -lean_inc(x_679); +lean_object* x_735; lean_object* x_736; lean_object* x_737; +x_735 = lean_ctor_get(x_24, 0); +x_736 = lean_ctor_get(x_24, 1); +lean_inc(x_736); +lean_inc(x_735); lean_dec(x_24); -x_681 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_681, 0, x_679); -lean_ctor_set(x_681, 1, x_680); -return x_681; +x_737 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_737, 0, x_735); +lean_ctor_set(x_737, 1, x_736); +return x_737; } } } else { -uint8_t x_682; +uint8_t x_738; lean_dec(x_19); lean_dec(x_11); lean_dec(x_10); @@ -18148,29 +18487,29 @@ lean_dec(x_6); lean_dec(x_5); lean_dec(x_4); lean_dec(x_1); -x_682 = !lean_is_exclusive(x_21); -if (x_682 == 0) +x_738 = !lean_is_exclusive(x_21); +if (x_738 == 0) { return x_21; } else { -lean_object* x_683; lean_object* x_684; lean_object* x_685; -x_683 = lean_ctor_get(x_21, 0); -x_684 = lean_ctor_get(x_21, 1); -lean_inc(x_684); -lean_inc(x_683); +lean_object* x_739; lean_object* x_740; lean_object* x_741; +x_739 = lean_ctor_get(x_21, 0); +x_740 = lean_ctor_get(x_21, 1); +lean_inc(x_740); +lean_inc(x_739); lean_dec(x_21); -x_685 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_685, 0, x_683); -lean_ctor_set(x_685, 1, x_684); -return x_685; +x_741 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_741, 0, x_739); +lean_ctor_set(x_741, 1, x_740); +return x_741; } } } else { -uint8_t x_686; +uint8_t x_742; lean_dec(x_11); lean_dec(x_10); lean_dec(x_9); @@ -18181,23 +18520,23 @@ lean_dec(x_5); lean_dec(x_4); lean_dec(x_3); lean_dec(x_1); -x_686 = !lean_is_exclusive(x_18); -if (x_686 == 0) +x_742 = !lean_is_exclusive(x_18); +if (x_742 == 0) { return x_18; } else { -lean_object* x_687; lean_object* x_688; lean_object* x_689; -x_687 = lean_ctor_get(x_18, 0); -x_688 = lean_ctor_get(x_18, 1); -lean_inc(x_688); -lean_inc(x_687); +lean_object* x_743; lean_object* x_744; lean_object* x_745; +x_743 = lean_ctor_get(x_18, 0); +x_744 = lean_ctor_get(x_18, 1); +lean_inc(x_744); +lean_inc(x_743); lean_dec(x_18); -x_689 = lean_alloc_ctor(1, 2, 0); -lean_ctor_set(x_689, 0, x_687); -lean_ctor_set(x_689, 1, x_688); -return x_689; +x_745 = lean_alloc_ctor(1, 2, 0); +lean_ctor_set(x_745, 0, x_743); +lean_ctor_set(x_745, 1, x_744); +return x_745; } } block_17: @@ -30873,7 +31212,7 @@ lean_dec(x_3); return x_9; } } -static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1() { +static lean_object* _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -30883,11 +31222,11 @@ x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445_(lean_object* x_1) { +lean_object* l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501_(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; -x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1; +x_2 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1; x_3 = l_Lean_registerTraceClass(x_2, x_1); return x_3; } @@ -31058,7 +31397,7 @@ lean_object* x_97; lean_object* x_98; lean_object* x_99; lean_object* x_100; lea x_97 = lean_ctor_get(x_91, 1); lean_inc(x_97); lean_dec(x_91); -x_98 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1; +x_98 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1; x_99 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_98, x_2, x_3, x_4, x_5, x_6, x_7, x_97); x_100 = lean_ctor_get(x_99, 0); lean_inc(x_100); @@ -31100,7 +31439,7 @@ lean_object* x_53; lean_object* x_54; lean_object* x_55; lean_object* x_56; lean x_53 = lean_ctor_get(x_47, 1); lean_inc(x_53); lean_dec(x_47); -x_54 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1; +x_54 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1; x_55 = l___private_Lean_Util_Trace_0__Lean_checkTraceOptionM___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__2(x_54, x_2, x_3, x_4, x_5, x_6, x_7, x_53); x_56 = lean_ctor_get(x_55, 0); lean_inc(x_56); @@ -31181,7 +31520,7 @@ x_41 = l_Lean_KernelException_toMessageData___closed__15; x_42 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_42, 0, x_40); lean_ctor_set(x_42, 1, x_41); -x_43 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1; +x_43 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1; x_44 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_43, x_42, x_2, x_3, x_4, x_5, x_6, x_7, x_36); x_45 = lean_ctor_get(x_44, 1); lean_inc(x_45); @@ -31243,7 +31582,7 @@ x_79 = l_Lean_KernelException_toMessageData___closed__15; x_80 = lean_alloc_ctor(10, 2, 0); lean_ctor_set(x_80, 0, x_78); lean_ctor_set(x_80, 1, x_79); -x_81 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1; +x_81 = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1; x_82 = l_Lean_addTrace___at___private_Lean_Elab_Term_0__Lean_Elab_Term_postponeElabTerm___spec__1(x_81, x_80, x_2, x_3, x_4, x_5, x_6, x_7, x_61); x_83 = lean_ctor_get(x_82, 1); lean_inc(x_83); @@ -35572,7 +35911,7 @@ _start: lean_object* x_1; lean_object* x_2; lean_object* x_3; lean_object* x_4; lean_object* x_5; lean_object* x_6; x_1 = l_Lean_Elab_Term_getFVarLocalDecl_x21___closed__2; x_2 = l_List_mapM___at_Lean_Elab_Term_resolveName_x27___spec__6___closed__2; -x_3 = lean_unsigned_to_nat(1303u); +x_3 = lean_unsigned_to_nat(1313u); x_4 = lean_unsigned_to_nat(31u); x_5 = l_Lean_Name_getString_x21___closed__3; x_6 = l___private_Init_Util_0__mkPanicMessageWithDecl(x_1, x_2, x_3, x_4, x_5); @@ -43137,7 +43476,7 @@ lean_dec(x_1); return x_10; } } -static lean_object* _init_l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199____closed__1() { +static lean_object* _init_l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255____closed__1() { _start: { lean_object* x_1; lean_object* x_2; lean_object* x_3; @@ -43147,7 +43486,7 @@ x_3 = lean_name_mk_string(x_1, x_2); return x_3; } } -lean_object* l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199_(lean_object* x_1) { +lean_object* l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255_(lean_object* x_1) { _start: { lean_object* x_2; lean_object* x_3; @@ -43159,7 +43498,7 @@ lean_object* x_4; lean_object* x_5; lean_object* x_6; x_4 = lean_ctor_get(x_3, 1); lean_inc(x_4); lean_dec(x_3); -x_5 = l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199____closed__1; +x_5 = l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255____closed__1; x_6 = l_Lean_registerTraceClass(x_5, x_4); if (lean_obj_tag(x_6) == 0) { @@ -43505,6 +43844,19 @@ l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207____closed__4 = _init_l_ lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207____closed__4); res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3207_(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; +l_Lean_Elab_Term_autoLift = lean_io_result_get_value(res); +lean_mark_persistent(l_Lean_Elab_Term_autoLift); +lean_dec_ref(res); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__1 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__1); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__2 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__2(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__2); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__3 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__3(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__3); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__4 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__4(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229____closed__4); +res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_3229_(lean_io_mk_world()); +if (lean_io_result_is_error(res)) return res; l_Lean_Elab_Term_maxCoeSize = lean_io_result_get_value(res); lean_mark_persistent(l_Lean_Elab_Term_maxCoeSize); lean_dec_ref(res); @@ -43600,9 +43952,9 @@ l_Lean_Elab_Term_mkAuxName___closed__2 = _init_l_Lean_Elab_Term_mkAuxName___clos lean_mark_persistent(l_Lean_Elab_Term_mkAuxName___closed__2); l_Lean_Elab_Term_mkAuxName___closed__3 = _init_l_Lean_Elab_Term_mkAuxName___closed__3(); lean_mark_persistent(l_Lean_Elab_Term_mkAuxName___closed__3); -l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1(); -lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445____closed__1); -res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7445_(lean_io_mk_world()); +l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1 = _init_l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1(); +lean_mark_persistent(l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501____closed__1); +res = l_Lean_Elab_Term_initFn____x40_Lean_Elab_Term___hyg_7501_(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); l_Lean_Elab_Term_isLetRecAuxMVar___closed__1 = _init_l_Lean_Elab_Term_isLetRecAuxMVar___closed__1(); @@ -43802,9 +44154,9 @@ l_Lean_Elab_Term_evalExpr___rarg___closed__3 = _init_l_Lean_Elab_Term_evalExpr__ lean_mark_persistent(l_Lean_Elab_Term_evalExpr___rarg___closed__3); l_Lean_Elab_Term_evalExpr___rarg___closed__4 = _init_l_Lean_Elab_Term_evalExpr___rarg___closed__4(); lean_mark_persistent(l_Lean_Elab_Term_evalExpr___rarg___closed__4); -l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199____closed__1 = _init_l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199____closed__1(); -lean_mark_persistent(l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199____closed__1); -res = l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10199_(lean_io_mk_world()); +l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255____closed__1 = _init_l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255____closed__1(); +lean_mark_persistent(l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255____closed__1); +res = l_Lean_Elab_initFn____x40_Lean_Elab_Term___hyg_10255_(lean_io_mk_world()); if (lean_io_result_is_error(res)) return res; lean_dec_ref(res); return lean_io_result_mk_ok(lean_box(0));